hyperformula
Version:
HyperFormula is a JavaScript engine for efficient processing of spreadsheet-like data and formulas
63 lines • 1.77 kB
JavaScript
/**
* @license
* Copyright (c) 2025 Handsoncode. All rights reserved.
*/
import { CellError, ErrorType } from "../../Cell.mjs";
import { ErrorMessage } from "../../error-message.mjs";
import { FunctionArgumentType, FunctionPlugin } from "./FunctionPlugin.mjs";
const MAX_48BIT_INTEGER = 281474976710655;
const SHIFT_MIN_POSITIONS = -53;
const SHIFT_MAX_POSITIONS = 53;
export class BitShiftPlugin extends FunctionPlugin {
bitlshift(ast, state) {
return this.runFunction(ast.args, state, this.metadata('BITLSHIFT'), shiftLeft);
}
bitrshift(ast, state) {
return this.runFunction(ast.args, state, this.metadata('BITRSHIFT'), shiftRight);
}
}
BitShiftPlugin.implementedFunctions = {
'BITLSHIFT': {
method: 'bitlshift',
parameters: [{
argumentType: FunctionArgumentType.INTEGER,
minValue: 0
}, {
argumentType: FunctionArgumentType.INTEGER,
minValue: SHIFT_MIN_POSITIONS,
maxValue: SHIFT_MAX_POSITIONS
}]
},
'BITRSHIFT': {
method: 'bitrshift',
parameters: [{
argumentType: FunctionArgumentType.INTEGER,
minValue: 0
}, {
argumentType: FunctionArgumentType.INTEGER,
minValue: SHIFT_MIN_POSITIONS,
maxValue: SHIFT_MAX_POSITIONS
}]
}
};
function shiftLeft(value, positions) {
if (positions < 0) {
return shiftRight(value, -positions);
} else {
return validate(value * Math.pow(2, positions));
}
}
function shiftRight(value, positions) {
if (positions < 0) {
return shiftLeft(value, -positions);
} else {
return validate(Math.floor(value / Math.pow(2, positions)));
}
}
function validate(result) {
if (result > MAX_48BIT_INTEGER) {
return new CellError(ErrorType.NUM, ErrorMessage.BitshiftLong);
} else {
return result;
}
}