@gmsol-labs/gmsol-sdk
Version:
GMX-Solana is an extension of GMX on the Solana blockchain.
1,622 lines (1,518 loc) • 75.2 kB
JavaScript
let wasm;
export function __wbg_set_wasm(val) {
wasm = val;
}
let WASM_VECTOR_LEN = 0;
let cachedUint8ArrayMemory0 = null;
function getUint8ArrayMemory0() {
if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {
cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);
}
return cachedUint8ArrayMemory0;
}
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 addToExternrefTable0(obj) {
const idx = wasm.__externref_table_alloc();
wasm.__wbindgen_export_4.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();
function getStringFromWasm0(ptr, len) {
ptr = ptr >>> 0;
return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));
}
function getArrayU8FromWasm0(ptr, len) {
ptr = ptr >>> 0;
return getUint8ArrayMemory0().subarray(ptr / 1, ptr / 1 + len);
}
function isLikeNone(x) {
return x === undefined || x === null;
}
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;
}
/**
* Get default [`StoreProgram`].
* @returns {StoreProgram}
*/
export function default_store_program() {
const ret = wasm.default_store_program();
return ret;
}
function takeFromExternrefTable0(idx) {
const value = wasm.__wbindgen_export_4.get(idx);
wasm.__externref_table_dealloc(idx);
return value;
}
function passArray8ToWasm0(arg, malloc) {
const ptr = malloc(arg.length * 1, 1) >>> 0;
getUint8ArrayMemory0().set(arg, ptr / 1);
WASM_VECTOR_LEN = arg.length;
return ptr;
}
function getArrayJsValueFromWasm0(ptr, len) {
ptr = ptr >>> 0;
const mem = getDataViewMemory0();
const result = [];
for (let i = ptr; i < ptr + 4 * len; i += 4) {
result.push(wasm.__wbindgen_export_4.get(mem.getUint32(i, true)));
}
wasm.__externref_drop_slice(ptr, len);
return result;
}
function _assertClass(instance, klass) {
if (!(instance instanceof klass)) {
throw new Error(`expected instance of ${klass.name}`);
}
}
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;
}
/**
* Create transaction builder for create-order ixs.
* @param {CreateOrderKind} kind
* @param {CreateOrderParams[]} orders
* @param {CreateOrderOptions} options
* @returns {CreateOrdersBuilder}
*/
export function create_orders_builder(kind, orders, options) {
const ptr0 = passArrayJsValueToWasm0(orders, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.create_orders_builder(kind, ptr0, len0, options);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return CreateOrdersBuilder.__wrap(ret[0]);
}
/**
* Build transactions for creating orders.
* @param {CreateOrderKind} kind
* @param {CreateOrderParams[]} orders
* @param {CreateOrderOptions} options
* @returns {TransactionGroup}
*/
export function create_orders(kind, orders, options) {
const ptr0 = passArrayJsValueToWasm0(orders, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.create_orders(kind, ptr0, len0, options);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return TransactionGroup.__wrap(ret[0]);
}
/**
* Build transactions for closing orders.
* @param {CloseOrderArgs} args
* @returns {TransactionGroup}
*/
export function close_orders(args) {
const ret = wasm.close_orders(args);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return TransactionGroup.__wrap(ret[0]);
}
/**
* Build transactions for updating orders.
* @param {UpdateOrderArgs} args
* @returns {TransactionGroup}
*/
export function update_orders(args) {
const ret = wasm.update_orders(args);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return TransactionGroup.__wrap(ret[0]);
}
/**
* Apply `factor` to the `value`.
* @param {bigint} value
* @param {bigint} factor
* @returns {bigint | undefined}
*/
export function apply_factor(value, factor) {
const ret = wasm.apply_factor(value, value >> BigInt(64), factor, factor >> BigInt(64));
return ret[0] === 0 ? undefined : (BigInt.asUintN(64, ret[1]) | (BigInt.asUintN(64, ret[2]) << BigInt(64)));
}
/**
* Initialize Javascript logging and panic handler
*/
export function solana_program_init() {
wasm.solana_program_init();
}
const CreateOrdersBuilderFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_createordersbuilder_free(ptr >>> 0, 1));
/**
* Builder for create-order ixs.
*/
export class CreateOrdersBuilder {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(CreateOrdersBuilder.prototype);
obj.__wbg_ptr = ptr;
CreateOrdersBuilderFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
CreateOrdersBuilderFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_createordersbuilder_free(ptr, 0);
}
/**
* Build transactions.
* @param {TransactionGroupOptions | null} [transaction_group]
* @param {BuildTransactionOptions | null} [build]
* @returns {TransactionGroup}
*/
build_with_options(transaction_group, build) {
const ptr = this.__destroy_into_raw();
const ret = wasm.createordersbuilder_build_with_options(ptr, isLikeNone(transaction_group) ? 0 : addToExternrefTable0(transaction_group), isLikeNone(build) ? 0 : addToExternrefTable0(build));
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return TransactionGroup.__wrap(ret[0]);
}
/**
* Merge with the other [`CreateOrderBuilder`].
* @param {CreateOrdersBuilder} other
*/
merge(other) {
_assertClass(other, CreateOrdersBuilder);
const ret = wasm.createordersbuilder_merge(this.__wbg_ptr, other.__wbg_ptr);
if (ret[1]) {
throw takeFromExternrefTable0(ret[0]);
}
}
}
const ElGamalKeypairFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_elgamalkeypair_free(ptr >>> 0, 1));
/**
* A (twisted) ElGamal encryption keypair.
*
* The instances of the secret key are zeroized on drop.
*/
export class ElGamalKeypair {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(ElGamalKeypair.prototype);
obj.__wbg_ptr = ptr;
ElGamalKeypairFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
ElGamalKeypairFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_elgamalkeypair_free(ptr, 0);
}
/**
* Generates the public and secret keys for ElGamal encryption.
*
* This function is randomized. It internally samples a scalar element using `OsRng`.
* @returns {ElGamalKeypair}
*/
static new_rand() {
const ret = wasm.elgamalkeypair_new_rand();
return ElGamalKeypair.__wrap(ret);
}
/**
* @returns {ElGamalPubkey}
*/
pubkey_owned() {
const ret = wasm.elgamalkeypair_pubkey_owned(this.__wbg_ptr);
return ElGamalPubkey.__wrap(ret);
}
}
const ElGamalPubkeyFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_elgamalpubkey_free(ptr >>> 0, 1));
/**
* Public key for the ElGamal encryption scheme.
*/
export class ElGamalPubkey {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(ElGamalPubkey.prototype);
obj.__wbg_ptr = ptr;
ElGamalPubkeyFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
ElGamalPubkeyFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_elgamalpubkey_free(ptr, 0);
}
}
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 KeypairFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_keypair_free(ptr >>> 0, 1));
/**
* A vanilla Ed25519 key pair
*/
export class Keypair {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Keypair.prototype);
obj.__wbg_ptr = ptr;
KeypairFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
KeypairFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_keypair_free(ptr, 0);
}
/**
* Create a new `Keypair `
*/
constructor() {
const ret = wasm.keypair_constructor();
this.__wbg_ptr = ret >>> 0;
KeypairFinalization.register(this, this.__wbg_ptr, this);
return this;
}
/**
* Convert a `Keypair` to a `Uint8Array`
* @returns {Uint8Array}
*/
toBytes() {
const ret = wasm.keypair_toBytes(this.__wbg_ptr);
var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice();
wasm.__wbindgen_free(ret[0], ret[1] * 1, 1);
return v1;
}
/**
* Recover a `Keypair` from a `Uint8Array`
* @param {Uint8Array} bytes
* @returns {Keypair}
*/
static fromBytes(bytes) {
const ptr0 = passArray8ToWasm0(bytes, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.keypair_fromBytes(ptr0, len0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Keypair.__wrap(ret[0]);
}
/**
* Return the `Pubkey` for this `Keypair`
* @returns {Pubkey}
*/
pubkey() {
const ret = wasm.keypair_pubkey(this.__wbg_ptr);
return Pubkey.__wrap(ret);
}
}
const MarketFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_market_free(ptr >>> 0, 1));
/**
* Wrapper of [`Market`].
*/
export class Market {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Market.prototype);
obj.__wbg_ptr = ptr;
MarketFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
MarketFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_market_free(ptr, 0);
}
/**
* Create from base64 encoded account data with options.
* @param {string} data
* @param {boolean | null} [no_discriminator]
* @returns {Market}
*/
static decode_from_base64_with_options(data, no_discriminator) {
const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.market_decode_from_base64_with_options(ptr0, len0, isLikeNone(no_discriminator) ? 0xFFFFFF : no_discriminator ? 1 : 0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Market.__wrap(ret[0]);
}
/**
* Create from base64 encoded account data.
* @param {string} data
* @returns {Market}
*/
static decode_from_base64(data) {
const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.market_decode_from_base64(ptr0, len0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Market.__wrap(ret[0]);
}
/**
* Create from account data.
* @param {Uint8Array} data
* @returns {Market}
*/
static decode(data) {
const ptr0 = passArray8ToWasm0(data, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.market_decode(ptr0, len0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Market.__wrap(ret[0]);
}
/**
* Convert into [`JsMarketModel`]
* @param {bigint} supply
* @returns {MarketModel}
*/
to_model(supply) {
const ret = wasm.market_to_model(this.__wbg_ptr, supply);
return MarketModel.__wrap(ret);
}
/**
* Get market token address.
* @returns {string}
*/
market_token_address() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.market_market_token_address(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);
}
}
/**
* Get index token address.
* @returns {string}
*/
index_token_address() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.market_index_token_address(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);
}
}
/**
* Get long token address.
* @returns {string}
*/
long_token_address() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.market_long_token_address(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);
}
}
/**
* Get short token address.
* @returns {string}
*/
short_token_address() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.market_short_token_address(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);
}
}
}
const MarketGraphFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_marketgraph_free(ptr >>> 0, 1));
/**
* A JS binding for [`MarketGraph`].
*/
export class MarketGraph {
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
MarketGraphFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_marketgraph_free(ptr, 0);
}
/**
* Create an empty market graph.
* @param {MarketGraphConfig} config
*/
constructor(config) {
const ret = wasm.marketgraph_new(config);
this.__wbg_ptr = ret >>> 0;
MarketGraphFinalization.register(this, this.__wbg_ptr, this);
return this;
}
/**
* Insert market from base64 encoded data.
* @param {string} data
* @param {bigint} supply
* @returns {boolean}
*/
insert_market_from_base64(data, supply) {
const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.marketgraph_insert_market_from_base64(this.__wbg_ptr, ptr0, len0, supply);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return ret[0] !== 0;
}
/**
* Update token price.
* @param {string} token
* @param {Value} price
*/
update_token_price(token, price) {
const ptr0 = passStringToWasm0(token, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.marketgraph_update_token_price(this.__wbg_ptr, ptr0, len0, price);
if (ret[1]) {
throw takeFromExternrefTable0(ret[0]);
}
}
/**
* Update value.
* @param {bigint} value
*/
update_value(value) {
wasm.marketgraph_update_value(this.__wbg_ptr, value, value >> BigInt(64));
}
/**
* Update base cost.
* @param {bigint} base_cost
*/
update_base_cost(base_cost) {
wasm.marketgraph_update_base_cost(this.__wbg_ptr, base_cost, base_cost >> BigInt(64));
}
/**
* Update max steps.
* @param {number} max_steps
*/
update_max_steps(max_steps) {
wasm.marketgraph_update_max_steps(this.__wbg_ptr, max_steps);
}
/**
* Get market by its market token.
* @param {string} market_token
* @returns {MarketModel | undefined}
*/
get_market(market_token) {
const ptr0 = passStringToWasm0(market_token, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.marketgraph_get_market(this.__wbg_ptr, ptr0, len0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return ret[0] === 0 ? undefined : MarketModel.__wrap(ret[0]);
}
/**
* Get all market tokens.
* @returns {string[]}
*/
market_tokens() {
const ret = wasm.marketgraph_market_tokens(this.__wbg_ptr);
var v1 = getArrayJsValueFromWasm0(ret[0], ret[1]).slice();
wasm.__wbindgen_free(ret[0], ret[1] * 4, 4);
return v1;
}
/**
* Get all index tokens.
* @returns {string[]}
*/
index_tokens() {
const ret = wasm.marketgraph_index_tokens(this.__wbg_ptr);
var v1 = getArrayJsValueFromWasm0(ret[0], ret[1]).slice();
wasm.__wbindgen_free(ret[0], ret[1] * 4, 4);
return v1;
}
/**
* Compute best swap path.
* @param {string} source
* @param {string} target
* @param {boolean} skip_bellman_ford
* @returns {BestSwapPath}
*/
best_swap_path(source, target, skip_bellman_ford) {
const ptr0 = passStringToWasm0(source, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ptr1 = passStringToWasm0(target, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len1 = WASM_VECTOR_LEN;
const ret = wasm.marketgraph_best_swap_path(this.__wbg_ptr, ptr0, len0, ptr1, len1, skip_bellman_ford);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
/**
* Simulates order execution.
* @param {SimulateOrderArgs} args
* @param {Position | null} [position]
* @returns {OrderSimulationOutput}
*/
simulate_order(args, position) {
let ptr0 = 0;
if (!isLikeNone(position)) {
_assertClass(position, Position);
ptr0 = position.__destroy_into_raw();
}
const ret = wasm.marketgraph_simulate_order(this.__wbg_ptr, args, ptr0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return OrderSimulationOutput.__wrap(ret[0]);
}
}
const MarketModelFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_marketmodel_free(ptr >>> 0, 1));
/**
* Wrapper of [`MarketModel`].
*/
export class MarketModel {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(MarketModel.prototype);
obj.__wbg_ptr = ptr;
MarketModelFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
MarketModelFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_marketmodel_free(ptr, 0);
}
/**
* Get market token price.
* @param {MarketTokenPriceParams} params
* @returns {bigint}
*/
market_token_price(params) {
const ret = wasm.marketmodel_market_token_price(this.__wbg_ptr, params);
if (ret[3]) {
throw takeFromExternrefTable0(ret[2]);
}
return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64)));
}
/**
* Get market status.
* @param {MarketStatusParams} params
* @returns {MarketStatus}
*/
status(params) {
const ret = wasm.marketmodel_status(this.__wbg_ptr, params);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
}
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 {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Message.prototype);
obj.__wbg_ptr = ptr;
MessageFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__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 OrderSimulationOutputFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_ordersimulationoutput_free(ptr >>> 0, 1));
/**
* A JS binding for [`OrderSimulationOutput`].
*/
export class OrderSimulationOutput {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(OrderSimulationOutput.prototype);
obj.__wbg_ptr = ptr;
OrderSimulationOutputFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
OrderSimulationOutputFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_ordersimulationoutput_free(ptr, 0);
}
/**
* Returns increase order simulation output.
* @returns {IncreaseOrderSimulationOutput | undefined}
*/
increase() {
const ret = wasm.ordersimulationoutput_increase(this.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
/**
* Returns decrease order simulation output.
* @returns {DecreaseOrderSimulationOutput | undefined}
*/
decrease() {
const ret = wasm.ordersimulationoutput_decrease(this.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
/**
* Returns swap order simulation output.
* @returns {SwapOrderSimulationOutput | undefined}
*/
swap() {
const ret = wasm.ordersimulationoutput_swap(this.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
}
const PodElGamalPubkeyFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_podelgamalpubkey_free(ptr >>> 0, 1));
/**
* The `ElGamalPubkey` type as a `Pod`.
*/
export class PodElGamalPubkey {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(PodElGamalPubkey.prototype);
obj.__wbg_ptr = ptr;
PodElGamalPubkeyFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
PodElGamalPubkeyFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_podelgamalpubkey_free(ptr, 0);
}
/**
* Create a new `PodElGamalPubkey` object
*
* * `value` - optional public key as a base64 encoded string, `Uint8Array`, `[number]`
* @param {any} value
*/
constructor(value) {
const ret = wasm.podelgamalpubkey_constructor(value);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
this.__wbg_ptr = ret[0] >>> 0;
PodElGamalPubkeyFinalization.register(this, this.__wbg_ptr, this);
return this;
}
/**
* Return the base64 string representation of the public key
* @returns {string}
*/
toString() {
let deferred1_0;
let deferred1_1;
try {
const ret = wasm.podelgamalpubkey_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 `ElGamalPubkey`s are equal
* @param {PodElGamalPubkey} other
* @returns {boolean}
*/
equals(other) {
_assertClass(other, PodElGamalPubkey);
const ret = wasm.podelgamalpubkey_equals(this.__wbg_ptr, other.__wbg_ptr);
return ret !== 0;
}
/**
* Return the `Uint8Array` representation of the public key
* @returns {Uint8Array}
*/
toBytes() {
const ret = wasm.podelgamalpubkey_toBytes(this.__wbg_ptr);
var v1 = getArrayU8FromWasm0(ret[0], ret[1]).slice();
wasm.__wbindgen_free(ret[0], ret[1] * 1, 1);
return v1;
}
/**
* @param {ElGamalPubkey} decoded
* @returns {PodElGamalPubkey}
*/
static compressed(decoded) {
_assertClass(decoded, ElGamalPubkey);
const ret = wasm.podelgamalpubkey_compressed(decoded.__wbg_ptr);
return PodElGamalPubkey.__wrap(ret);
}
/**
* @returns {ElGamalPubkey}
*/
decompressed() {
const ret = wasm.podelgamalpubkey_decompressed(this.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return ElGamalPubkey.__wrap(ret[0]);
}
}
const PositionFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_position_free(ptr >>> 0, 1));
/**
* JS version of [`Position`].
*/
export class Position {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(Position.prototype);
obj.__wbg_ptr = ptr;
PositionFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
PositionFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_position_free(ptr, 0);
}
/**
* Create from base64 encoded account data with options.
* @param {string} data
* @param {boolean | null} [no_discriminator]
* @returns {Position}
*/
static decode_from_base64_with_options(data, no_discriminator) {
const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.position_decode_from_base64_with_options(ptr0, len0, isLikeNone(no_discriminator) ? 0xFFFFFF : no_discriminator ? 1 : 0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Position.__wrap(ret[0]);
}
/**
* Create from base64 encoded account data.
* @param {string} data
* @returns {Position}
*/
static decode_from_base64(data) {
const ptr0 = passStringToWasm0(data, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.position_decode_from_base64(ptr0, len0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Position.__wrap(ret[0]);
}
/**
* Create from account data.
* @param {Uint8Array} data
* @returns {Position}
*/
static decode(data) {
const ptr0 = passArray8ToWasm0(data, wasm.__wbindgen_malloc);
const len0 = WASM_VECTOR_LEN;
const ret = wasm.position_decode(ptr0, len0);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return Position.__wrap(ret[0]);
}
/**
* Convert to a [`JsPositionModel`].
* @param {MarketModel} market
* @returns {PositionModel}
*/
to_model(market) {
_assertClass(market, MarketModel);
const ret = wasm.position_to_model(this.__wbg_ptr, market.__wbg_ptr);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return PositionModel.__wrap(ret[0]);
}
}
const PositionModelFinalization = (typeof FinalizationRegistry === 'undefined')
? { register: () => {}, unregister: () => {} }
: new FinalizationRegistry(ptr => wasm.__wbg_positionmodel_free(ptr >>> 0, 1));
/**
* JS version of [`PositionModel`].
*/
export class PositionModel {
static __wrap(ptr) {
ptr = ptr >>> 0;
const obj = Object.create(PositionModel.prototype);
obj.__wbg_ptr = ptr;
PositionModelFinalization.register(obj, obj.__wbg_ptr, obj);
return obj;
}
__destroy_into_raw() {
const ptr = this.__wbg_ptr;
this.__wbg_ptr = 0;
PositionModelFinalization.unregister(this);
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_positionmodel_free(ptr, 0);
}
/**
* Get position status.
* @param {Prices} prices
* @returns {PositionStatus}
*/
status(prices) {
const ret = wasm.positionmodel_status(this.__wbg_ptr, prices);
if (ret[2]) {
throw takeFromExternrefTable0(ret[1]);
}
return takeFromExternrefTable0(ret[0]);
}
/**
* Get position size.
* @returns {bigint}
*/
size() {
const ret = wasm.positionmodel_size(this.__wbg_ptr);
return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64)));
}
/**
* Get position size in tokens.
* @returns {bigint}
*/
size_in_tokens() {
const ret = wasm.positionmodel_size_in_tokens(this.__wbg_ptr);
return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64)));
}
/**
* Get collateral amount.
* @returns {bigint}
*/
collateral_amount() {
const ret = wasm.positionmodel_collateral_amount(this.__wbg_ptr);
return (BigInt.asUintN(64, ret[0]) | (BigInt.asUintN(64, ret[1]) << BigInt(64)));
}
/**
* Returns the inner [`JsPosition`].
* @returns {Position}
*/
position() {
const ret = wasm.positionmodel_position(this.__wbg_ptr);
return Position.__wrap(ret);
}
}
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