range-bet-math-core
Version:
Mathematical core library for Signals Breakout Programs protocol
1,253 lines (1,145 loc) • 38.9 kB
JavaScript
let wasm;
export function __wbg_set_wasm(val) {
wasm = val;
}
function addToExternrefTable0(obj) {
const idx = wasm.__externref_table_alloc();
wasm.__wbindgen_export_2.set(idx, obj);
return idx;
}
function handleError(f, args) {
try {
return f.apply(this, args);
} catch (e) {
const idx = addToExternrefTable0(e);
wasm.__wbindgen_exn_store(idx);
}
}
const lTextDecoder = typeof TextDecoder === 'undefined' ? (0, module.require)('util').TextDecoder : TextDecoder;
let cachedTextDecoder = new lTextDecoder('utf-8', { ignoreBOM: true, fatal: true });
cachedTextDecoder.decode();
let cachedUint8ArrayMemory0 = null;
function getUint8ArrayMemory0() {
if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {
cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);
}
return cachedUint8ArrayMemory0;
}
function getStringFromWasm0(ptr, len) {
ptr = ptr >>> 0;
return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));
}
let WASM_VECTOR_LEN = 0;
const lTextEncoder = typeof TextEncoder === 'undefined' ? (0, module.require)('util').TextEncoder : TextEncoder;
let cachedTextEncoder = new lTextEncoder('utf-8');
const encodeString = (typeof cachedTextEncoder.encodeInto === 'function'
? function (arg, view) {
return cachedTextEncoder.encodeInto(arg, view);
}
: function (arg, view) {
const buf = cachedTextEncoder.encode(arg);
view.set(buf);
return {
read: arg.length,
written: buf.length
};
});
function passStringToWasm0(arg, malloc, realloc) {
if (realloc === undefined) {
const buf = cachedTextEncoder.encode(arg);
const ptr = malloc(buf.length, 1) >>> 0;
getUint8ArrayMemory0().subarray(ptr, ptr + buf.length).set(buf);
WASM_VECTOR_LEN = buf.length;
return ptr;
}
let len = arg.length;
let ptr = malloc(len, 1) >>> 0;
const mem = getUint8ArrayMemory0();
let offset = 0;
for (; offset < len; offset++) {
const code = arg.charCodeAt(offset);
if (code > 0x7F) break;
mem[ptr + offset] = code;
}
if (offset !== len) {
if (offset !== 0) {
arg = arg.slice(offset);
}
ptr = realloc(ptr, len, len = offset + arg.length * 3, 1) >>> 0;
const view = getUint8ArrayMemory0().subarray(ptr + offset, ptr + len);
const ret = encodeString(arg, view);
offset += ret.written;
ptr = realloc(ptr, len, offset, 1) >>> 0;
}
WASM_VECTOR_LEN = offset;
return ptr;
}
let cachedDataViewMemory0 = null;
function getDataViewMemory0() {
if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) {
cachedDataViewMemory0 = new DataView(wasm.memory.buffer);
}
return cachedDataViewMemory0;
}
function debugString(val) {
// primitive types
const type = typeof val;
if (type == 'number' || type == 'boolean' || val == null) {
return `${val}`;
}
if (type == 'string') {
return `"${val}"`;
}
if (type == 'symbol') {
const description = val.description;
if (description == null) {
return 'Symbol';
} else {
return `Symbol(${description})`;
}
}
if (type == 'function') {
const name = val.name;
if (typeof name == 'string' && name.length > 0) {
return `Function(${name})`;
} else {
return 'Function';
}
}
// objects
if (Array.isArray(val)) {
const length = val.length;
let debug = '[';
if (length > 0) {
debug += debugString(val[0]);
}
for(let i = 1; i < length; i++) {
debug += ', ' + debugString(val[i]);
}
debug += ']';
return debug;
}
// Test for built-in
const builtInMatches = /\[object ([^\]]+)\]/.exec(toString.call(val));
let className;
if (builtInMatches && builtInMatches.length > 1) {
className = builtInMatches[1];
} else {
// Failed to match the standard '[object ClassName]'
return toString.call(val);
}
if (className == 'Object') {
// we're a user defined class or Object
// JSON.stringify avoids problems with cycles, and is generally much
// easier than looping through ownProperties of `val`.
try {
return 'Object(' + JSON.stringify(val) + ')';
} catch (_) {
return 'Object';
}
}
// errors
if (val instanceof Error) {
return `${val.name}: ${val.message}\n${val.stack}`;
}
// TODO we could test for more things here, like `Set`s and `Map`s.
return className;
}
function isLikeNone(x) {
return x === undefined || x === null;
}
/**
* @param {bigint} x
* @param {bigint} q
* @param {bigint} t
* @returns {bigint}
*/
export function calculateBinBuyCost(x, q, t) {
const ret = wasm.calculateBinBuyCost(x, q, t);
return BigInt.asUintN(64, ret);
}
/**
* @param {bigint} x
* @param {bigint} q
* @param {bigint} t
* @returns {bigint}
*/
export function calculateBinSellCost(x, q, t) {
const ret = wasm.calculateBinSellCost(x, q, t);
return BigInt.asUintN(64, ret);
}
let cachedBigUint64ArrayMemory0 = null;
function getBigUint64ArrayMemory0() {
if (cachedBigUint64ArrayMemory0 === null || cachedBigUint64ArrayMemory0.byteLength === 0) {
cachedBigUint64ArrayMemory0 = new BigUint64Array(wasm.memory.buffer);
}
return cachedBigUint64ArrayMemory0;
}
function passArray64ToWasm0(arg, malloc) {
const ptr = malloc(arg.length * 8, 8) >>> 0;
getBigUint64ArrayMemory0().set(arg, ptr / 8);
WASM_VECTOR_LEN = arg.length;
return ptr;
}
/**
* @param {bigint} x
* @param {BigUint64Array} qs
* @param {bigint} t
* @returns {bigint}
*/
export function calculateMultiBinsBuyCost(x, qs, t) {
const ptr0 = passArray64ToWasm0(qs, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.calculateMultiBinsBuyCost(x, ptr0, len0, t);
return BigInt.asUintN(64, ret);
}
/**
* @param {bigint} x
* @param {BigUint64Array} qs
* @param {bigint} t
* @returns {bigint}
*/
export function calculateMultiBinsSellCost(x, qs, t) {
const ptr0 = passArray64ToWasm0(qs, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.calculateMultiBinsSellCost(x, ptr0, len0, t);
return BigInt.asUintN(64, ret);
}
/**
* @param {bigint} budget
* @param {BigUint64Array} qs
* @param {bigint} t
* @returns {bigint}
*/
export function calculateXForMultiBins(budget, qs, t) {
const ptr0 = passArray64ToWasm0(qs, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.calculateXForMultiBins(budget, ptr0, len0, t);
return BigInt.asUintN(64, ret);
}
function takeFromExternrefTable0(idx) {
const value = wasm.__wbindgen_export_2.get(idx);
wasm.__externref_table_dealloc(idx);
return value;
}
/**
* @param {string} x_str
* @param {string} q_str
* @param {string} t_str
* @returns {string}
*/
export function calculateBinBuyCostEvm(x_str, q_str, t_str) {
let deferred5_0;
let deferred5_1;
try {
const ptr0 = passStringToWasm0(x_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(q_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ptr2 = passStringToWasm0(t_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len2 = WASM_VECTOR_LEN;
const ret = wasm.calculateBinBuyCostEvm(ptr0, len0, ptr1, len1, ptr2, len2);
var ptr4 = ret[0];
var len4 = ret[1];
if (ret[3]) {
ptr4 = 0; len4 = 0;
throw takeFromExternrefTable0(ret[2]);
}
deferred5_0 = ptr4;
deferred5_1 = len4;
return getStringFromWasm0(ptr4, len4);
} finally {
wasm.__wbindgen_free(deferred5_0, deferred5_1, 1);
}
}
/**
* @param {string} x_str
* @param {string} q_str
* @param {string} t_str
* @returns {string}
*/
export function calculateBinSellCostEvm(x_str, q_str, t_str) {
let deferred5_0;
let deferred5_1;
try {
const ptr0 = passStringToWasm0(x_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(q_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ptr2 = passStringToWasm0(t_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len2 = WASM_VECTOR_LEN;
const ret = wasm.calculateBinSellCostEvm(ptr0, len0, ptr1, len1, ptr2, len2);
var ptr4 = ret[0];
var len4 = ret[1];
if (ret[3]) {
ptr4 = 0; len4 = 0;
throw takeFromExternrefTable0(ret[2]);
}
deferred5_0 = ptr4;
deferred5_1 = len4;
return getStringFromWasm0(ptr4, len4);
} finally {
wasm.__wbindgen_free(deferred5_0, deferred5_1, 1);
}
}
/**
* @param {string} x_str
* @param {string} qs_str
* @param {string} t_str
* @returns {string}
*/
export function calculateMultiBinsBuyCostEvm(x_str, qs_str, t_str) {
let deferred5_0;
let deferred5_1;
try {
const ptr0 = passStringToWasm0(x_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(qs_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ptr2 = passStringToWasm0(t_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len2 = WASM_VECTOR_LEN;
const ret = wasm.calculateMultiBinsBuyCostEvm(ptr0, len0, ptr1, len1, ptr2, len2);
var ptr4 = ret[0];
var len4 = ret[1];
if (ret[3]) {
ptr4 = 0; len4 = 0;
throw takeFromExternrefTable0(ret[2]);
}
deferred5_0 = ptr4;
deferred5_1 = len4;
return getStringFromWasm0(ptr4, len4);
} finally {
wasm.__wbindgen_free(deferred5_0, deferred5_1, 1);
}
}
/**
* @param {string} x_str
* @param {string} qs_str
* @param {string} t_str
* @returns {string}
*/
export function calculateMultiBinsSellCostEvm(x_str, qs_str, t_str) {
let deferred5_0;
let deferred5_1;
try {
const ptr0 = passStringToWasm0(x_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(qs_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ptr2 = passStringToWasm0(t_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len2 = WASM_VECTOR_LEN;
const ret = wasm.calculateMultiBinsSellCostEvm(ptr0, len0, ptr1, len1, ptr2, len2);
var ptr4 = ret[0];
var len4 = ret[1];
if (ret[3]) {
ptr4 = 0; len4 = 0;
throw takeFromExternrefTable0(ret[2]);
}
deferred5_0 = ptr4;
deferred5_1 = len4;
return getStringFromWasm0(ptr4, len4);
} finally {
wasm.__wbindgen_free(deferred5_0, deferred5_1, 1);
}
}
/**
* @param {string} budget_str
* @param {string} qs_str
* @param {string} t_str
* @returns {string}
*/
export function calculateXForMultiBinsEvm(budget_str, qs_str, t_str) {
let deferred5_0;
let deferred5_1;
try {
const ptr0 = passStringToWasm0(budget_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(qs_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ptr2 = passStringToWasm0(t_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len2 = WASM_VECTOR_LEN;
const ret = wasm.calculateXForMultiBinsEvm(ptr0, len0, ptr1, len1, ptr2, len2);
var ptr4 = ret[0];
var len4 = ret[1];
if (ret[3]) {
ptr4 = 0; len4 = 0;
throw takeFromExternrefTable0(ret[2]);
}
deferred5_0 = ptr4;
deferred5_1 = len4;
return getStringFromWasm0(ptr4, len4);
} finally {
wasm.__wbindgen_free(deferred5_0, deferred5_1, 1);
}
}
/**
* @param {string} value_str
* @returns {boolean}
*/
export function isWithinU64Range(value_str) {
const ptr0 = passStringToWasm0(value_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.isWithinU64Range(ptr0, len0);
return ret !== 0;
}
/**
* @returns {string}
*/
export function getMaxU64() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.getMaxU64();
deferred1_0 = ret[0];
deferred1_1 = ret[1];
return getStringFromWasm0(ret[0], ret[1]);
} finally {
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
}
}
/**
* @param {string} budget_str
* @param {string} qs_str
* @param {string} t_str
* @returns {string}
*/
export function validateEvmValues(budget_str, qs_str, t_str) {
let deferred5_0;
let deferred5_1;
try {
const ptr0 = passStringToWasm0(budget_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(qs_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ptr2 = passStringToWasm0(t_str, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len2 = WASM_VECTOR_LEN;
const ret = wasm.validateEvmValues(ptr0, len0, ptr1, len1, ptr2, len2);
var ptr4 = ret[0];
var len4 = ret[1];
if (ret[3]) {
ptr4 = 0; len4 = 0;
throw takeFromExternrefTable0(ret[2]);
}
deferred5_0 = ptr4;
deferred5_1 = len4;
return getStringFromWasm0(ptr4, len4);
} finally {
wasm.__wbindgen_free(deferred5_0, deferred5_1, 1);
}
}
/**
* Initialize Javascript logging and panic handler
*/
export function solana_program_init() {
wasm.solana_program_init();
}
function _assertClass(instance, klass) {
if (!(instance instanceof klass)) {
throw new Error(`expected instance of ${klass.name}`);
}
}
function getArrayU8FromWasm0(ptr, len) {
ptr = ptr >>> 0;
return getUint8ArrayMemory0().subarray(ptr / 1, ptr / 1 + len);
}
function passArrayJsValueToWasm0(array, malloc) {
const ptr = malloc(array.length * 4, 4) >>> 0;
for (let i = 0; i < array.length; i++) {
const add = addToExternrefTable0(array[i]);
getDataViewMemory0().setUint32(ptr + 4 * i, add, true);
}
WASM_VECTOR_LEN = array.length;
return ptr;
}
const HashFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_hash_free(ptr >>> 0, 1));
/**
* A hash; the 32-byte output of a hashing algorithm.
*
* This struct is used most often in `solana-sdk` and related crates to contain
* a [SHA-256] hash, but may instead contain a [blake3] hash.
*
* [SHA-256]: https://en.wikipedia.org/wiki/SHA-2
* [blake3]: https://github.com/BLAKE3-team/BLAKE3
*/
export class Hash {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Hash.prototype);
obj.__wbg_ptr = ptr;
HashFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
HashFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_hash_free(ptr, 0);
}
/**
* Create a new Hash object
*
* * `value` - optional hash as a base58 encoded string, `Uint8Array`, `[number]`
* @param {any} value
*/
constructor(value) {
const ret = wasm.hash_constructor(value);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
this.__wbg_ptr = ret[0] >>> 0;
HashFinalization.register(this, this.__wbg_ptr, this);
return this;
}
/**
* Return the base58 string representation of the hash
* @returns {string}
*/
toString() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.hash_toString(this.__wbg_ptr);
deferred1_0 = ret[0];
deferred1_1 = ret[1];
return getStringFromWasm0(ret[0], ret[1]);
} finally {
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
}
}
/**
* Checks if two `Hash`s are equal
* @param {Hash} other
* @returns {boolean}
*/
equals(other) {
_assertClass(other, Hash);
const ret = wasm.hash_equals(this.__wbg_ptr, other.__wbg_ptr);
return ret !== 0;
}
/**
* Return the `Uint8Array` representation of the hash
* @returns {Uint8Array}
*/
toBytes() {
const ret = wasm.hash_toBytes(this.__wbg_ptr);
var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice();
wasm.__wbindgen_free(ret[0], ret[1] * 1, 1);
return v1;
}
}
const InstructionFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_instruction_free(ptr >>> 0, 1));
/**
* wasm-bindgen version of the Instruction struct.
* This duplication is required until https://github.com/rustwasm/wasm-bindgen/issues/3671
* is fixed. This must not diverge from the regular non-wasm Instruction struct.
*/
export class Instruction {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Instruction.prototype);
obj.__wbg_ptr = ptr;
InstructionFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
InstructionFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_instruction_free(ptr, 0);
}
}
const InstructionsFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_instructions_free(ptr >>> 0, 1));
export class Instructions {
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
InstructionsFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_instructions_free(ptr, 0);
}
constructor() {
const ret = wasm.instructions_constructor();
this.__wbg_ptr = ret >>> 0;
InstructionsFinalization.register(this, this.__wbg_ptr, this);
return this;
}
/**
* @param {Instruction} instruction
*/
push(instruction) {
_assertClass(instruction, Instruction);
var ptr0 = instruction.__destroy_into_raw();
wasm.instructions_push(this.__wbg_ptr, ptr0);
}
}
const MessageFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_message_free(ptr >>> 0, 1));
/**
* wasm-bindgen version of the Message struct.
* This duplication is required until https://github.com/rustwasm/wasm-bindgen/issues/3671
* is fixed. This must not diverge from the regular non-wasm Message struct.
*/
export class Message {
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
MessageFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_message_free(ptr, 0);
}
/**
* The id of a recent ledger entry.
* @returns {Hash}
*/
get recent_blockhash() {
const ret = wasm.__wbg_get_message_recent_blockhash(this.__wbg_ptr);
return Hash.__wrap(ret);
}
/**
* The id of a recent ledger entry.
* @param {Hash} arg0
*/
set recent_blockhash(arg0) {
_assertClass(arg0, Hash);
var ptr0 = arg0.__destroy_into_raw();
wasm.__wbg_set_message_recent_blockhash(this.__wbg_ptr, ptr0);
}
}
const PubkeyFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_pubkey_free(ptr >>> 0, 1));
/**
* The address of a [Solana account][acc].
*
* Some account addresses are [ed25519] public keys, with corresponding secret
* keys that are managed off-chain. Often, though, account addresses do not
* have corresponding secret keys — as with [_program derived
* addresses_][pdas] — or the secret key is not relevant to the operation
* of a program, and may have even been disposed of. As running Solana programs
* can not safely create or manage secret keys, the full [`Keypair`] is not
* defined in `solana-program` but in `solana-sdk`.
*
* [acc]: https://solana.com/docs/core/accounts
* [ed25519]: https://ed25519.cr.yp.to/
* [pdas]: https://solana.com/docs/core/cpi#program-derived-addresses
* [`Keypair`]: https://docs.rs/solana-sdk/latest/solana_sdk/signer/keypair/struct.Keypair.html
*/
export class Pubkey {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Pubkey.prototype);
obj.__wbg_ptr = ptr;
PubkeyFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
PubkeyFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_pubkey_free(ptr, 0);
}
/**
* Create a new Pubkey object
*
* * `value` - optional public key as a base58 encoded string, `Uint8Array`, `[number]`
* @param {any} value
*/
constructor(value) {
const ret = wasm.pubkey_constructor(value);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
this.__wbg_ptr = ret[0] >>> 0;
PubkeyFinalization.register(this, this.__wbg_ptr, this);
return this;
}
/**
* Return the base58 string representation of the public key
* @returns {string}
*/
toString() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.pubkey_toString(this.__wbg_ptr);
deferred1_0 = ret[0];
deferred1_1 = ret[1];
return getStringFromWasm0(ret[0], ret[1]);
} finally {
wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
}
}
/**
* Check if a `Pubkey` is on the ed25519 curve.
* @returns {boolean}
*/
isOnCurve() {
const ret = wasm.pubkey_isOnCurve(this.__wbg_ptr);
return ret !== 0;
}
/**
* Checks if two `Pubkey`s are equal
* @param {Pubkey} other
* @returns {boolean}
*/
equals(other) {
_assertClass(other, Pubkey);
const ret = wasm.pubkey_equals(this.__wbg_ptr, other.__wbg_ptr);
return ret !== 0;
}
/**
* Return the `Uint8Array` representation of the public key
* @returns {Uint8Array}
*/
toBytes() {
const ret = wasm.pubkey_toBytes(this.__wbg_ptr);
var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice();
wasm.__wbindgen_free(ret[0], ret[1] * 1, 1);
return v1;
}
/**
* Derive a Pubkey from another Pubkey, string seed, and a program id
* @param {Pubkey} base
* @param {string} seed
* @param {Pubkey} owner
* @returns {Pubkey}
*/
static createWithSeed(base, seed, owner) {
_assertClass(base, Pubkey);
const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(owner, Pubkey);
const ret = wasm.pubkey_createWithSeed(base.__wbg_ptr, ptr0, len0, owner.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Pubkey.__wrap(ret[0]);
}
/**
* Derive a program address from seeds and a program id
* @param {any[]} seeds
* @param {Pubkey} program_id
* @returns {Pubkey}
*/
static createProgramAddress(seeds, program_id) {
const ptr0 = passArrayJsValueToWasm0(seeds, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(program_id, Pubkey);
const ret = wasm.pubkey_createProgramAddress(ptr0, len0, program_id.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Pubkey.__wrap(ret[0]);
}
/**
* Find a valid program address
*
* Returns:
* * `[PubKey, number]` - the program address and bump seed
* @param {any[]} seeds
* @param {Pubkey} program_id
* @returns {any}
*/
static findProgramAddress(seeds, program_id) {
const ptr0 = passArrayJsValueToWasm0(seeds, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(program_id, Pubkey);
const ret = wasm.pubkey_findProgramAddress(ptr0, len0, program_id.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
}
const SystemInstructionFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_systeminstruction_free(ptr >>> 0, 1));
export class SystemInstruction {
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
SystemInstructionFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_systeminstruction_free(ptr, 0);
}
/**
* @param {Pubkey} from_pubkey
* @param {Pubkey} to_pubkey
* @param {bigint} lamports
* @param {bigint} space
* @param {Pubkey} owner
* @returns {Instruction}
*/
static createAccount(from_pubkey, to_pubkey, lamports, space, owner) {
_assertClass(from_pubkey, Pubkey);
_assertClass(to_pubkey, Pubkey);
_assertClass(owner, Pubkey);
const ret = wasm.systeminstruction_createAccount(from_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, lamports, space, owner.__wbg_ptr);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} from_pubkey
* @param {Pubkey} to_pubkey
* @param {Pubkey} base
* @param {string} seed
* @param {bigint} lamports
* @param {bigint} space
* @param {Pubkey} owner
* @returns {Instruction}
*/
static createAccountWithSeed(from_pubkey, to_pubkey, base, seed, lamports, space, owner) {
_assertClass(from_pubkey, Pubkey);
_assertClass(to_pubkey, Pubkey);
_assertClass(base, Pubkey);
const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(owner, Pubkey);
const ret = wasm.systeminstruction_createAccountWithSeed(from_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, base.__wbg_ptr, ptr0, len0, lamports, space, owner.__wbg_ptr);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} pubkey
* @param {Pubkey} owner
* @returns {Instruction}
*/
static assign(pubkey, owner) {
_assertClass(pubkey, Pubkey);
_assertClass(owner, Pubkey);
const ret = wasm.systeminstruction_assign(pubkey.__wbg_ptr, owner.__wbg_ptr);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} pubkey
* @param {Pubkey} base
* @param {string} seed
* @param {Pubkey} owner
* @returns {Instruction}
*/
static assignWithSeed(pubkey, base, seed, owner) {
_assertClass(pubkey, Pubkey);
_assertClass(base, Pubkey);
const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(owner, Pubkey);
const ret = wasm.systeminstruction_assignWithSeed(pubkey.__wbg_ptr, base.__wbg_ptr, ptr0, len0, owner.__wbg_ptr);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} from_pubkey
* @param {Pubkey} to_pubkey
* @param {bigint} lamports
* @returns {Instruction}
*/
static transfer(from_pubkey, to_pubkey, lamports) {
_assertClass(from_pubkey, Pubkey);
_assertClass(to_pubkey, Pubkey);
const ret = wasm.systeminstruction_transfer(from_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, lamports);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} from_pubkey
* @param {Pubkey} from_base
* @param {string} from_seed
* @param {Pubkey} from_owner
* @param {Pubkey} to_pubkey
* @param {bigint} lamports
* @returns {Instruction}
*/
static transferWithSeed(from_pubkey, from_base, from_seed, from_owner, to_pubkey, lamports) {
_assertClass(from_pubkey, Pubkey);
_assertClass(from_base, Pubkey);
const ptr0 = passStringToWasm0(from_seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(from_owner, Pubkey);
_assertClass(to_pubkey, Pubkey);
const ret = wasm.systeminstruction_transferWithSeed(from_pubkey.__wbg_ptr, from_base.__wbg_ptr, ptr0, len0, from_owner.__wbg_ptr, to_pubkey.__wbg_ptr, lamports);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} pubkey
* @param {bigint} space
* @returns {Instruction}
*/
static allocate(pubkey, space) {
_assertClass(pubkey, Pubkey);
const ret = wasm.systeminstruction_allocate(pubkey.__wbg_ptr, space);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} address
* @param {Pubkey} base
* @param {string} seed
* @param {bigint} space
* @param {Pubkey} owner
* @returns {Instruction}
*/
static allocateWithSeed(address, base, seed, space, owner) {
_assertClass(address, Pubkey);
_assertClass(base, Pubkey);
const ptr0 = passStringToWasm0(seed, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
_assertClass(owner, Pubkey);
const ret = wasm.systeminstruction_allocateWithSeed(address.__wbg_ptr, base.__wbg_ptr, ptr0, len0, space, owner.__wbg_ptr);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} from_pubkey
* @param {Pubkey} nonce_pubkey
* @param {Pubkey} authority
* @param {bigint} lamports
* @returns {Array<any>}
*/
static createNonceAccount(from_pubkey, nonce_pubkey, authority, lamports) {
_assertClass(from_pubkey, Pubkey);
_assertClass(nonce_pubkey, Pubkey);
_assertClass(authority, Pubkey);
const ret = wasm.systeminstruction_createNonceAccount(from_pubkey.__wbg_ptr, nonce_pubkey.__wbg_ptr, authority.__wbg_ptr, lamports);
return ret;
}
/**
* @param {Pubkey} nonce_pubkey
* @param {Pubkey} authorized_pubkey
* @returns {Instruction}
*/
static advanceNonceAccount(nonce_pubkey, authorized_pubkey) {
_assertClass(nonce_pubkey, Pubkey);
_assertClass(authorized_pubkey, Pubkey);
const ret = wasm.systeminstruction_advanceNonceAccount(nonce_pubkey.__wbg_ptr, authorized_pubkey.__wbg_ptr);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} nonce_pubkey
* @param {Pubkey} authorized_pubkey
* @param {Pubkey} to_pubkey
* @param {bigint} lamports
* @returns {Instruction}
*/
static withdrawNonceAccount(nonce_pubkey, authorized_pubkey, to_pubkey, lamports) {
_assertClass(nonce_pubkey, Pubkey);
_assertClass(authorized_pubkey, Pubkey);
_assertClass(to_pubkey, Pubkey);
const ret = wasm.systeminstruction_withdrawNonceAccount(nonce_pubkey.__wbg_ptr, authorized_pubkey.__wbg_ptr, to_pubkey.__wbg_ptr, lamports);
return Instruction.__wrap(ret);
}
/**
* @param {Pubkey} nonce_pubkey
* @param {Pubkey} authorized_pubkey
* @param {Pubkey} new_authority
* @returns {Instruction}
*/
static authorizeNonceAccount(nonce_pubkey, authorized_pubkey, new_authority) {
_assertClass(nonce_pubkey, Pubkey);
_assertClass(authorized_pubkey, Pubkey);
_assertClass(new_authority, Pubkey);
const ret = wasm.systeminstruction_authorizeNonceAccount(nonce_pubkey.__wbg_ptr, authorized_pubkey.__wbg_ptr, new_authority.__wbg_ptr);
return Instruction.__wrap(ret);
}
}
export function __wbg_buffer_609cc3eee51ed158(arg0) {
const ret = arg0.buffer;
return ret;
};
export function __wbg_call_672a4d21634d4a24() { return handleError(function (arg0, arg1) {
const ret = arg0.call(arg1);
return ret;
}, arguments) };
export function __wbg_debug_3cb59063b29f58c1(arg0) {
console.debug(arg0);
};
export function __wbg_done_769e5ede4b31c67b(arg0) {
const ret = arg0.done;
return ret;
};
export function __wbg_error_524f506f44df1645(arg0) {
console.error(arg0);
};
export function __wbg_error_7534b8e9a36f1ab4(arg0, arg1) {
let deferred0_0;
let deferred0_1;
try {
deferred0_0 = arg0;
deferred0_1 = arg1;
console.error(getStringFromWasm0(arg0, arg1));
} finally {
wasm.__wbindgen_free(deferred0_0, deferred0_1, 1);
}
};
export function __wbg_get_67b2ba62fc30de12() { return handleError(function (arg0, arg1) {
const ret = Reflect.get(arg0, arg1);
return ret;
}, arguments) };
export function __wbg_info_3daf2e093e091b66(arg0) {
console.info(arg0);
};
export function __wbg_instanceof_Uint8Array_17156bcf118086a9(arg0) {
let result;
try {
result = arg0 instanceof Uint8Array;
} catch (_) {
result = false;
}
const ret = result;
return ret;
};
export function __wbg_instruction_new(arg0) {
const ret = Instruction.__wrap(arg0);
return ret;
};
export function __wbg_isArray_a1eab7e0d067391b(arg0) {
const ret = Array.isArray(arg0);
return ret;
};
export function __wbg_iterator_9a24c88df860dc65() {
const ret = Symbol.iterator;
return ret;
};
export function __wbg_length_a446193dc22c12f8(arg0) {
const ret = arg0.length;
return ret;
};
export function __wbg_log_c222819a41e063d3(arg0) {
console.log(arg0);
};
export function __wbg_new_78feb108b6472713() {
const ret = new Array();
return ret;
};
export function __wbg_new_8a6f238a6ece86ea() {
const ret = new Error();
return ret;
};
export function __wbg_new_a12002a7f91c75be(arg0) {
const ret = new Uint8Array(arg0);
return ret;
};
export function __wbg_newwithlength_c4c419ef0bc8a1f8(arg0) {
const ret = new Array(arg0 >>> 0);
return ret;
};
export function __wbg_next_25feadfc0913fea9(arg0) {
const ret = arg0.next;
return ret;
};
export function __wbg_next_6574e1a8a62d1055() { return handleError(function (arg0) {
const ret = arg0.next();
return ret;
}, arguments) };
export function __wbg_pubkey_new(arg0) {
const ret = Pubkey.__wrap(arg0);
return ret;
};
export function __wbg_push_737cfc8c1432c2c6(arg0, arg1) {
const ret = arg0.push(arg1);
return ret;
};
export function __wbg_set_37837023f3d740e8(arg0, arg1, arg2) {
arg0[arg1 >>> 0] = arg2;
};
export function __wbg_set_65595bdd868b3009(arg0, arg1, arg2) {
arg0.set(arg1, arg2 >>> 0);
};
export function __wbg_stack_0ed75d68575b0f3c(arg0, arg1) {
const ret = arg1.stack;
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true);
getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true);
};
export function __wbg_value_cd1ffa7b1ab794f1(arg0) {
const ret = arg0.value;
return ret;
};
export function __wbg_values_99f7a68c7f313d66(arg0) {
const ret = arg0.values();
return ret;
};
export function __wbg_warn_4ca3906c248c47c4(arg0) {
console.warn(arg0);
};
export function __wbindgen_debug_string(arg0, arg1) {
const ret = debugString(arg1);
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true);
getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true);
};
export function __wbindgen_init_externref_table() {
const table = wasm.__wbindgen_export_2;
const offset = table.grow(4);
table.set(0, undefined);
table.set(offset + 0, undefined);
table.set(offset + 1, null);
table.set(offset + 2, true);
table.set(offset + 3, false);
;
};
export function __wbindgen_is_function(arg0) {
const ret = typeof(arg0) === 'function';
return ret;
};
export function __wbindgen_is_object(arg0) {
const val = arg0;
const ret = typeof(val) === 'object' && val !== null;
return ret;
};
export function __wbindgen_is_undefined(arg0) {
const ret = arg0 === undefined;
return ret;
};
export function __wbindgen_memory() {
const ret = wasm.memory;
return ret;
};
export function __wbindgen_number_get(arg0, arg1) {
const obj = arg1;
const ret = typeof(obj) === 'number' ? obj : undefined;
getDataViewMemory0().setFloat64(arg0 + 8 * 1, isLikeNone(ret) ? 0 : ret, true);
getDataViewMemory0().setInt32(arg0 + 4 * 0, !isLikeNone(ret), true);
};
export function __wbindgen_number_new(arg0) {
const ret = arg0;
return ret;
};
export function __wbindgen_string_get(arg0, arg1) {
const obj = arg1;
const ret = typeof(obj) === 'string' ? obj : undefined;
var ptr1 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len1 = WASM_VECTOR_LEN;
getDataViewMemory0().setInt32(arg0 + 4 * 1, len1, true);
getDataViewMemory0().setInt32(arg0 + 4 * 0, ptr1, true);
};
export function __wbindgen_string_new(arg0, arg1) {
const ret = getStringFromWasm0(arg0, arg1);
return ret;
};
export function __wbindgen_throw(arg0, arg1) {
throw new Error(getStringFromWasm0(arg0, arg1));
};