ethereumjs-vm
Version:
An Ethereum VM implementation
28 lines • 1.04 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
var BN = require("bn.js");
var evm_1 = require("../evm");
var assert = require('assert');
var bn128 = require('rustbn.js');
function default_1(opts) {
assert(opts.data);
var inputData = opts.data;
// no need to care about non-divisible-by-192, because bn128.pairing will properly fail in that case
var inputDataSize = Math.floor(inputData.length / 192);
var gasUsed = new BN(opts._common.param('gasPrices', 'ecPairing') +
inputDataSize * opts._common.param('gasPrices', 'ecPairingWord'));
if (opts.gasLimit.lt(gasUsed)) {
return evm_1.OOGResult(opts.gasLimit);
}
var returnData = bn128.pairing(inputData);
// check ecpairing success or failure by comparing the output length
if (returnData.length !== 32) {
return evm_1.OOGResult(opts.gasLimit);
}
return {
gasUsed: gasUsed,
returnValue: returnData,
};
}
exports.default = default_1;
//# sourceMappingURL=08-ecpairing.js.map