@neo-one/smart-contract-compiler
Version:
NEO•ONE TypeScript smart contract compiler.
130 lines (128 loc) • 4.9 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.BufferSliceHelper = void 0;
const Helper_1 = require("../Helper");
class BufferSliceHelper extends Helper_1.Helper {
constructor({ hasEnd = false }) {
super();
this.hasEnd = hasEnd;
}
emit(sb, node, options) {
if (!options.pushValue) {
sb.emitOp(node, 'DROP');
sb.emitOp(node, 'DROP');
return;
}
if (this.hasEnd) {
sb.emitOp(node, 'ROT');
sb.emitOp(node, 'SWAP');
sb.emitHelper(node, options, sb.helpers.if({
condition: () => {
sb.emitOp(node, 'TUCK');
sb.emitPushInt(node, 0);
sb.emitOp(node, 'LT');
},
whenTrue: () => {
sb.emitOp(node, 'TUCK');
sb.emitOp(node, 'SIZE');
sb.emitOp(node, 'ADD');
sb.emitOp(node, 'SWAP');
},
}));
sb.emitOp(node, 'ROT');
sb.emitHelper(node, options, sb.helpers.if({
condition: () => {
sb.emitOp(node, 'TUCK');
sb.emitPushInt(node, 0);
sb.emitOp(node, 'LT');
},
whenTrue: () => {
sb.emitOp(node, 'TUCK');
sb.emitOp(node, 'SIZE');
sb.emitOp(node, 'ADD');
sb.emitOp(node, 'SWAP');
},
}));
sb.emitOp(node, 'ROT');
sb.emitOp(node, 'ROT');
sb.emitHelper(node, options, sb.helpers.if({
condition: () => {
sb.emitOp(node, 'TUCK');
sb.emitOp(node, 'OVER');
sb.emitOp(node, 'LTE');
},
whenTrue: () => {
sb.emitOp(node, 'DROP');
sb.emitOp(node, 'DROP');
sb.emitOp(node, 'DROP');
sb.emitPushBuffer(node, Buffer.alloc(0, 0));
},
whenFalse: () => {
sb.emitOp(node, 'TUCK');
sb.emitOp(node, 'SUB');
sb.emitOp(node, 'ROT');
sb.emitOp(node, 'ROT');
sb.emitOp(node, 'OVER');
sb.emitOp(node, 'SIZE');
sb.emitOp(node, 'SWAP');
sb.emitOp(node, 'SUB');
sb.emitOp(node, 'RIGHT');
sb.emitOp(node, 'SWAP');
sb.emitOp(node, 'LEFT');
},
}));
}
else {
sb.emitHelper(node, options, sb.helpers.if({
condition: () => {
sb.emitOp(node, 'DUP');
sb.emitPushInt(node, 0);
sb.emitOp(node, 'LT');
},
whenTrue: () => {
sb.emitPushInt(node, -1);
sb.emitOp(node, 'MUL');
sb.emitHelper(node, options, sb.helpers.if({
condition: () => {
sb.emitOp(node, 'TUCK');
sb.emitOp(node, 'OVER');
sb.emitOp(node, 'SIZE');
sb.emitOp(node, 'GT');
},
whenTrue: () => {
sb.emitOp(node, 'NIP');
},
whenFalse: () => {
sb.emitOp(node, 'SWAP');
sb.emitOp(node, 'RIGHT');
},
}));
},
whenFalse: () => {
sb.emitOp(node, 'OVER');
sb.emitOp(node, 'SIZE');
sb.emitOp(node, 'SWAP');
sb.emitOp(node, 'SUB');
sb.emitHelper(node, options, sb.helpers.if({
condition: () => {
sb.emitOp(node, 'TUCK');
sb.emitPushInt(node, 0);
sb.emitOp(node, 'LTE');
},
whenTrue: () => {
sb.emitOp(node, 'DROP');
sb.emitOp(node, 'DROP');
sb.emitPushBuffer(node, Buffer.alloc(0, 0));
},
whenFalse: () => {
sb.emitOp(node, 'SWAP');
sb.emitOp(node, 'RIGHT');
},
}));
},
}));
}
}
}
exports.BufferSliceHelper = BufferSliceHelper;
//# sourceMappingURL=BufferSliceHelper.js.map