parent
4b2219c71f
commit
45e84ff168
@ -1549,7 +1549,7 @@ Script.prototype.execute = function execute(stack, flags, tx, index, version) {
|
|||||||
|
|
||||||
subscript = this.getSubscript(lastSep);
|
subscript = this.getSubscript(lastSep);
|
||||||
if (version === 0)
|
if (version === 0)
|
||||||
subscript.removeData(Script.encodePush(sig));
|
subscript.removeData(sig);
|
||||||
|
|
||||||
Script.validateSignature(sig, flags);
|
Script.validateSignature(sig, flags);
|
||||||
Script.validateKey(key, flags);
|
Script.validateKey(key, flags);
|
||||||
@ -1611,7 +1611,7 @@ Script.prototype.execute = function execute(stack, flags, tx, index, version) {
|
|||||||
for (j = 0; j < m; j++) {
|
for (j = 0; j < m; j++) {
|
||||||
sig = stack.top(-isig - j);
|
sig = stack.top(-isig - j);
|
||||||
if (version === 0)
|
if (version === 0)
|
||||||
subscript.removeData(Script.encodePush(sig));
|
subscript.removeData(sig);
|
||||||
}
|
}
|
||||||
|
|
||||||
res = true;
|
res = true;
|
||||||
@ -1971,7 +1971,7 @@ Script.array = function(value) {
|
|||||||
* @returns {Number} Total.
|
* @returns {Number} Total.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
Script.prototype.removeDataFast = function removeData(data) {
|
Script.prototype.removeData = function removeData(data) {
|
||||||
var index = [];
|
var index = [];
|
||||||
var i, op;
|
var i, op;
|
||||||
|
|
||||||
@ -2009,91 +2009,6 @@ Script.prototype.removeDataFast = function removeData(data) {
|
|||||||
return index.length;
|
return index.length;
|
||||||
};
|
};
|
||||||
|
|
||||||
Script.encodePush = function encodePush(data) {
|
|
||||||
var p = new BufferWriter();
|
|
||||||
if (data.length <= 0x4b) {
|
|
||||||
p.writeU8(data.length);
|
|
||||||
p.writeBytes(data);
|
|
||||||
} else if (data.length <= 0xff) {
|
|
||||||
p.writeU8(opcodes.OP_PUSHDATA1);
|
|
||||||
p.writeU8(data.length);
|
|
||||||
p.writeBytes(data);
|
|
||||||
} else if (data.length <= 0xffff) {
|
|
||||||
p.writeU8(opcodes.OP_PUSHDATA2);
|
|
||||||
p.writeU16(data.length);
|
|
||||||
p.writeBytes(data);
|
|
||||||
} else if (data.length <= 0xffffffff) {
|
|
||||||
p.writeU8(opcodes.OP_PUSHDATA4);
|
|
||||||
p.writeU32(data.length);
|
|
||||||
p.writeBytes(data);
|
|
||||||
} else {
|
|
||||||
assert(false, 'Bad pushdata op.');
|
|
||||||
}
|
|
||||||
return p.render();
|
|
||||||
};
|
|
||||||
|
|
||||||
Script.prototype.removeData = function removeData(data) {
|
|
||||||
var total = 0;
|
|
||||||
var p, raw, a, b, op, size;
|
|
||||||
|
|
||||||
if (data.length === 0)
|
|
||||||
return total;
|
|
||||||
|
|
||||||
// Compare on the byte level.
|
|
||||||
raw = this.encode();
|
|
||||||
|
|
||||||
p = new BufferReader(raw, true);
|
|
||||||
|
|
||||||
for (;;) {
|
|
||||||
while (p.left() >= data.length && utils.icmp(raw, data, p.offset) === 0) {
|
|
||||||
a = raw.slice(0, p.offset);
|
|
||||||
b = raw.slice(p.offset + data.length);
|
|
||||||
raw = Buffer.concat([a, b]);
|
|
||||||
p.data = raw;
|
|
||||||
total++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (p.left() === 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
op = p.readU8();
|
|
||||||
if (op >= 0x01 && op <= 0x4b) {
|
|
||||||
if (p.left() < op)
|
|
||||||
break;
|
|
||||||
p.seek(op);
|
|
||||||
} else if (op === opcodes.OP_PUSHDATA1) {
|
|
||||||
if (p.left() < 1)
|
|
||||||
break;
|
|
||||||
size = p.readU8();
|
|
||||||
if (p.left() < size)
|
|
||||||
break;
|
|
||||||
p.seek(size);
|
|
||||||
} else if (op === opcodes.OP_PUSHDATA2) {
|
|
||||||
if (p.left() < 2)
|
|
||||||
break;
|
|
||||||
size = p.readU16();
|
|
||||||
if (p.left() < size)
|
|
||||||
break;
|
|
||||||
p.seek(size);
|
|
||||||
} else if (op === opcodes.OP_PUSHDATA4) {
|
|
||||||
if (p.left() < 4)
|
|
||||||
break;
|
|
||||||
size = p.readU32();
|
|
||||||
if (p.left() < size)
|
|
||||||
break;
|
|
||||||
p.seek(size);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (total > 0) {
|
|
||||||
this.code = Script.decode(raw);
|
|
||||||
if (this.raw)
|
|
||||||
this.raw = raw;
|
|
||||||
}
|
|
||||||
|
|
||||||
return total;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find a data element in a script.
|
* Find a data element in a script.
|
||||||
* @param {Buffer} data - Data element to match against.
|
* @param {Buffer} data - Data element to match against.
|
||||||
|
|||||||
@ -258,159 +258,6 @@ describe('Script', function() {
|
|||||||
assert(success(s2.execute(stack), stack));
|
assert(success(s2.execute(stack), stack));
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should execute FindAndDelete correctly', function() {
|
|
||||||
var s, d, expect;
|
|
||||||
|
|
||||||
function del(s) {
|
|
||||||
s.mutable = true;
|
|
||||||
delete s.raw;
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
||||||
s = bcoin.script.fromString('OP_1 OP_2');
|
|
||||||
del(s);
|
|
||||||
d = new bcoin.script();
|
|
||||||
expect = s.clone();
|
|
||||||
assert.equal(s.removeData(d.encode()), 0);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromString('OP_1 OP_2 OP_3');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromString('OP_2');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromString('OP_1 OP_3');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromString('OP_3 OP_1 OP_3 OP_3 OP_4 OP_3');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromString('OP_3');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromString('OP_1 OP_4');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 4);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0302ff03', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('0302ff03', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = new bcoin.script();
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0302ff030302ff03', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('0302ff03', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = new bcoin.script();
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 2);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0302ff030302ff03', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('02', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = s.clone();
|
|
||||||
del(expect);
|
|
||||||
//assert.equal(s.removeData(d.encode()), 0);
|
|
||||||
s.removeData(d.encode());
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0302ff030302ff03', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('ff', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = s.clone();
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 0);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0302ff030302ff03', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('03', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = new bcoin.script([new Buffer([0xff, 0x03]), new Buffer([0xff, 0x03])]);
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 2);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('02feed5169', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('feed51', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = s.clone();
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 0);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('02feed5169', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('02feed51', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromRaw('69', 'hex');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('516902feed5169', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('feed51', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = s.clone();
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 0);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('516902feed5169', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('02feed51', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromRaw('516969', 'hex');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromString('OP_0 OP_0 OP_1 OP_1');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromString('OP_0 OP_1');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromString('OP_0 OP_1');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromString('OP_0 OP_0 OP_1 OP_0 OP_1 OP_1');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromString('OP_0 OP_1');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromString('OP_0 OP_1');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 2);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0003feed', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('03feed', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromRaw('00', 'hex');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
|
|
||||||
s = bcoin.script.fromRaw('0003feed', 'hex');
|
|
||||||
del(s);
|
|
||||||
d = bcoin.script.fromRaw('00', 'hex');
|
|
||||||
del(d);
|
|
||||||
expect = bcoin.script.fromRaw('03feed', 'hex');
|
|
||||||
del(expect);
|
|
||||||
assert.equal(s.removeData(d.encode()), 1);
|
|
||||||
assert.deepEqual(s.encode(), expect.encode());
|
|
||||||
});
|
|
||||||
|
|
||||||
scripts.forEach(function(data) {
|
scripts.forEach(function(data) {
|
||||||
// ["Format is: [[wit...]?, scriptSig, scriptPubKey, flags, expected_scripterror, ... comments]"],
|
// ["Format is: [[wit...]?, scriptSig, scriptPubKey, flags, expected_scripterror, ... comments]"],
|
||||||
var witness = Array.isArray(data[0]) ? data.shift() : null;
|
var witness = Array.isArray(data[0]) ? data.shift() : null;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user