tx · 3CsZe6Z4PNZaZAGHSDYqK99r38DPEWUAa9y5Cu2TMjY8 3N4vqUXWw8tf23LDWDbSEpJZH6dent3ETFu: -0.04000000 Waves 2022.01.02 21:06 [1861608] smart account 3N4vqUXWw8tf23LDWDbSEpJZH6dent3ETFu > SELF 0.00000000 Waves
{ "type": 13, "id": "3CsZe6Z4PNZaZAGHSDYqK99r38DPEWUAa9y5Cu2TMjY8", "fee": 4000000, "feeAssetId": null, "timestamp": 1641146796779, "version": 2, "chainId": 84, "sender": "3N4vqUXWw8tf23LDWDbSEpJZH6dent3ETFu", "senderPublicKey": "D4v2S9mjah7eEEmuQVBNd4WipC3scs8V4PjuDBweWatE", "proofs": [ "5HFTHtW2vajBFAqUqD4ppBy9uM5SJEcTM2tmh57uQuncZKi2YAhoWKgDDtdSPmhsMKVCVw39jicvcUeuRiwqHnCw" ], "script": "base64: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", "height": 1861608, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 78wYCmHzcFtE4VJUVCF3VW7yxP4dfHJQS7c3eGstpmen Next: 53RkWwevsdJ3Et8DPcsMEoKj8j57LGytqv5gkYwDhNGp Diff:
Old | New | Differences | |
---|---|---|---|
63 | 63 | ||
64 | 64 | ||
65 | 65 | func getXyReturn (xy,gen) = { | |
66 | - | let $ | |
67 | - | let x = $ | |
68 | - | let y = $ | |
66 | + | let $t012941309 = xy | |
67 | + | let x = $t012941309._1 | |
68 | + | let y = $t012941309._2 | |
69 | 69 | $Tuple3(x, y, (gen + 1)) | |
70 | 70 | } | |
71 | 71 | ||
72 | 72 | ||
73 | 73 | func getXy (xyg,ownerId) = { | |
74 | 74 | let checkList = getBoundCoords(xyg) | |
75 | - | let $ | |
76 | - | let x = $ | |
77 | - | let y = $ | |
78 | - | let gen = $ | |
75 | + | let $t014251446 = xyg | |
76 | + | let x = $t014251446._1 | |
77 | + | let y = $t014251446._2 | |
78 | + | let gen = $t014251446._3 | |
79 | 79 | let genStr = toString(gen) | |
80 | 80 | if (checkSquareForEvolve(checkList[0], genStr, ownerId)) | |
81 | 81 | then getXyReturn(checkList[0]._1, gen) | |
82 | - | else if (checkSquareForEvolve(checkList[1], genStr, ownerId)) | |
83 | - | then getXyReturn(checkList[1]._1, gen) | |
84 | - | else if (checkSquareForEvolve(checkList[2], genStr, ownerId)) | |
85 | - | then getXyReturn(checkList[2]._1, gen) | |
86 | - | else if (checkSquareForEvolve(checkList[3], genStr, ownerId)) | |
87 | - | then getXyReturn(checkList[3]._1, gen) | |
88 | - | else xyg | |
82 | + | else throw(((((toString(x) + ",") + toString(y)) + ",") + ownerId)) | |
89 | 83 | } | |
90 | 84 | ||
91 | 85 | ||
92 | 86 | @Callable(i) | |
93 | 87 | func purchase (x,y) = { | |
94 | 88 | let ownerId = toBase58String(i.caller.bytes) | |
95 | - | let $ | |
96 | - | let resolvedX = $ | |
97 | - | let resolvedY = $ | |
98 | - | let resolvedGen = $ | |
89 | + | let $t021482245 = getXy($Tuple3(parseIntValue(x), parseIntValue(y), 1), ownerId) | |
90 | + | let resolvedX = $t021482245._1 | |
91 | + | let resolvedY = $t021482245._2 | |
92 | + | let resolvedGen = $t021482245._3 | |
99 | 93 | let resolvedXStr = toString(resolvedX) | |
100 | 94 | let resolvedYStr = toString(resolvedY) | |
101 | 95 | let resolvedGenStr = toString(resolvedGen) | |
102 | - | let assetName = ((resolvedXStr + ",") + resolvedYStr) | |
103 | - | let assetUrl = ((nftDomain + toBase58String(i.transactionId)) + ".png") | |
104 | - | let asset = Issue(((assetName + " Gen ") + resolvedGenStr), assetUrl, 1, 0, false) | |
105 | - | let assetId = calculateAssetId(asset) | |
106 | - | let gen = resolvedGenStr | |
107 | - | let dataKeyPrefix = ((assetName + ",") + gen) | |
96 | + | if ((resolvedGenStr == "1")) | |
97 | + | then throw(((resolvedXStr + ",") + resolvedGenStr)) | |
98 | + | else { | |
99 | + | let assetName = ((resolvedXStr + ",") + resolvedYStr) | |
100 | + | let assetUrl = ((nftDomain + toBase58String(i.transactionId)) + ".png") | |
101 | + | let asset = Issue(((assetName + " Gen ") + resolvedGenStr), assetUrl, 1, 0, false) | |
102 | + | let assetId = calculateAssetId(asset) | |
103 | + | let gen = resolvedGenStr | |
104 | + | let dataKeyPrefix = ((assetName + ",") + gen) | |
108 | 105 | [asset, StringEntry((dataKeyPrefix + "_assetId"), toBase58String(assetId)), StringEntry((dataKeyPrefix + "_asset"), assetUrl), StringEntry((dataKeyPrefix + "_owner"), ownerId), ScriptTransfer(i.caller, 1, assetId)] | |
106 | + | } | |
109 | 107 | } | |
110 | 108 | ||
111 | 109 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let COLS = 1024 | |
5 | 5 | ||
6 | 6 | let ROWS = 1024 | |
7 | 7 | ||
8 | 8 | let nftDomain = "https://nft.gridgang.ca/" | |
9 | 9 | ||
10 | 10 | func getBoundCoords (data) = { | |
11 | 11 | let $t0205227 = data | |
12 | 12 | let x = $t0205227._1 | |
13 | 13 | let y = $t0205227._2 | |
14 | 14 | let gen = $t0205227._3 | |
15 | 15 | let d = pow(2, 0, gen, 0, 0, HALFUP) | |
16 | 16 | let tl = $Tuple2((x - d), (y - d)) | |
17 | 17 | let tc = $Tuple2(x, (y - d)) | |
18 | 18 | let tr = $Tuple2((x + d), (y + d)) | |
19 | 19 | let l = $Tuple2((x - d), y) | |
20 | 20 | let r = $Tuple2((x + d), y) | |
21 | 21 | let bl = $Tuple2((x - d), (y + d)) | |
22 | 22 | let bc = $Tuple2(x, (y + d)) | |
23 | 23 | let br = $Tuple2((x + d), (y + d)) | |
24 | 24 | [$Tuple3(tl, tc, l), $Tuple3(tc, tr, r), $Tuple3(l, bl, bc), $Tuple3(r, bc, br)] | |
25 | 25 | } | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | func checkSquareForEvolve (coords,gen,ownerId) = { | |
29 | 29 | let $t0656684 = coords | |
30 | 30 | let xy1 = $t0656684._1 | |
31 | 31 | let xy2 = $t0656684._2 | |
32 | 32 | let xy3 = $t0656684._3 | |
33 | 33 | let xyVal1 = match getString(this, (((((toString(xy1._1) + ",") + toString(xy1._2)) + ",") + gen) + "_owner")) { | |
34 | 34 | case _: Unit => | |
35 | 35 | "unset" | |
36 | 36 | case x: String => | |
37 | 37 | x | |
38 | 38 | case _ => | |
39 | 39 | throw("Match error") | |
40 | 40 | } | |
41 | 41 | let xyVal2 = match getString(this, (((((toString(xy2._1) + ",") + toString(xy2._2)) + ",") + gen) + "_owner")) { | |
42 | 42 | case _: Unit => | |
43 | 43 | "unset" | |
44 | 44 | case x: String => | |
45 | 45 | x | |
46 | 46 | case _ => | |
47 | 47 | throw("Match error") | |
48 | 48 | } | |
49 | 49 | let xyVal3 = match getString(this, (((((toString(xy3._1) + ",") + toString(xy3._2)) + ",") + gen) + "_owner")) { | |
50 | 50 | case _: Unit => | |
51 | 51 | "unset" | |
52 | 52 | case x: String => | |
53 | 53 | x | |
54 | 54 | case _ => | |
55 | 55 | throw("Match error") | |
56 | 56 | } | |
57 | 57 | if (if ((xyVal1 == ownerId)) | |
58 | 58 | then (xyVal2 == ownerId) | |
59 | 59 | else false) | |
60 | 60 | then (xyVal3 == ownerId) | |
61 | 61 | else false | |
62 | 62 | } | |
63 | 63 | ||
64 | 64 | ||
65 | 65 | func getXyReturn (xy,gen) = { | |
66 | - | let $ | |
67 | - | let x = $ | |
68 | - | let y = $ | |
66 | + | let $t012941309 = xy | |
67 | + | let x = $t012941309._1 | |
68 | + | let y = $t012941309._2 | |
69 | 69 | $Tuple3(x, y, (gen + 1)) | |
70 | 70 | } | |
71 | 71 | ||
72 | 72 | ||
73 | 73 | func getXy (xyg,ownerId) = { | |
74 | 74 | let checkList = getBoundCoords(xyg) | |
75 | - | let $ | |
76 | - | let x = $ | |
77 | - | let y = $ | |
78 | - | let gen = $ | |
75 | + | let $t014251446 = xyg | |
76 | + | let x = $t014251446._1 | |
77 | + | let y = $t014251446._2 | |
78 | + | let gen = $t014251446._3 | |
79 | 79 | let genStr = toString(gen) | |
80 | 80 | if (checkSquareForEvolve(checkList[0], genStr, ownerId)) | |
81 | 81 | then getXyReturn(checkList[0]._1, gen) | |
82 | - | else if (checkSquareForEvolve(checkList[1], genStr, ownerId)) | |
83 | - | then getXyReturn(checkList[1]._1, gen) | |
84 | - | else if (checkSquareForEvolve(checkList[2], genStr, ownerId)) | |
85 | - | then getXyReturn(checkList[2]._1, gen) | |
86 | - | else if (checkSquareForEvolve(checkList[3], genStr, ownerId)) | |
87 | - | then getXyReturn(checkList[3]._1, gen) | |
88 | - | else xyg | |
82 | + | else throw(((((toString(x) + ",") + toString(y)) + ",") + ownerId)) | |
89 | 83 | } | |
90 | 84 | ||
91 | 85 | ||
92 | 86 | @Callable(i) | |
93 | 87 | func purchase (x,y) = { | |
94 | 88 | let ownerId = toBase58String(i.caller.bytes) | |
95 | - | let $ | |
96 | - | let resolvedX = $ | |
97 | - | let resolvedY = $ | |
98 | - | let resolvedGen = $ | |
89 | + | let $t021482245 = getXy($Tuple3(parseIntValue(x), parseIntValue(y), 1), ownerId) | |
90 | + | let resolvedX = $t021482245._1 | |
91 | + | let resolvedY = $t021482245._2 | |
92 | + | let resolvedGen = $t021482245._3 | |
99 | 93 | let resolvedXStr = toString(resolvedX) | |
100 | 94 | let resolvedYStr = toString(resolvedY) | |
101 | 95 | let resolvedGenStr = toString(resolvedGen) | |
102 | - | let assetName = ((resolvedXStr + ",") + resolvedYStr) | |
103 | - | let assetUrl = ((nftDomain + toBase58String(i.transactionId)) + ".png") | |
104 | - | let asset = Issue(((assetName + " Gen ") + resolvedGenStr), assetUrl, 1, 0, false) | |
105 | - | let assetId = calculateAssetId(asset) | |
106 | - | let gen = resolvedGenStr | |
107 | - | let dataKeyPrefix = ((assetName + ",") + gen) | |
96 | + | if ((resolvedGenStr == "1")) | |
97 | + | then throw(((resolvedXStr + ",") + resolvedGenStr)) | |
98 | + | else { | |
99 | + | let assetName = ((resolvedXStr + ",") + resolvedYStr) | |
100 | + | let assetUrl = ((nftDomain + toBase58String(i.transactionId)) + ".png") | |
101 | + | let asset = Issue(((assetName + " Gen ") + resolvedGenStr), assetUrl, 1, 0, false) | |
102 | + | let assetId = calculateAssetId(asset) | |
103 | + | let gen = resolvedGenStr | |
104 | + | let dataKeyPrefix = ((assetName + ",") + gen) | |
108 | 105 | [asset, StringEntry((dataKeyPrefix + "_assetId"), toBase58String(assetId)), StringEntry((dataKeyPrefix + "_asset"), assetUrl), StringEntry((dataKeyPrefix + "_owner"), ownerId), ScriptTransfer(i.caller, 1, assetId)] | |
106 | + | } | |
109 | 107 | } | |
110 | 108 | ||
111 | 109 | ||
112 | 110 | @Verifier(tx) | |
113 | 111 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
114 | 112 |
github/deemru/w8io/169f3d6 59.95 ms ◑![]()