[trade] implement max swap from health computer (#335)

This commit is contained in:
Bob van der Helm 2023-08-02 11:38:41 +02:00 committed by GitHub
parent 203152d39c
commit b6be254804
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 241 additions and 387 deletions

View File

@ -117,7 +117,7 @@ export default function AccountBalancesTable(props: Props) {
denom: row.original.denom, denom: row.original.denom,
amount: row.original.amount.toString(), amount: row.original.amount.toString(),
}) })
return <DisplayCurrency coin={coin} className='text-xs text-right' /> return <DisplayCurrency coin={coin} className='text-right text-xs' />
}, },
}, },
{ {
@ -131,7 +131,7 @@ export default function AccountBalancesTable(props: Props) {
) )
return ( return (
<FormattedNumber <FormattedNumber
className='text-xs text-right' className='text-right text-xs'
amount={Number(BN(amount).abs().toPrecision(2))} amount={Number(BN(amount).abs().toPrecision(2))}
options={{ maxDecimals: 2, abbreviated: true }} options={{ maxDecimals: 2, abbreviated: true }}
animate animate
@ -192,7 +192,7 @@ export default function AccountBalancesTable(props: Props) {
'align-center', 'align-center',
)} )}
> >
<span className='w-6 h-6 text-white'> <span className='h-6 w-6 text-white'>
{header.column.getCanSort() {header.column.getCanSort()
? { ? {
asc: <SortAsc />, asc: <SortAsc />,

View File

@ -1,4 +1,5 @@
import { useEffect, useState } from 'react' import { useEffect, useState } from 'react'
import BigNumber from 'bignumber.js'
import AccountSummary from 'components/Account/AccountSummary' import AccountSummary from 'components/Account/AccountSummary'
import AssetImage from 'components/AssetImage' import AssetImage from 'components/AssetImage'
@ -20,7 +21,6 @@ import { hardcodedFee } from 'utils/constants'
import { formatPercent, formatValue } from 'utils/formatters' import { formatPercent, formatValue } from 'utils/formatters'
import { BN } from 'utils/helpers' import { BN } from 'utils/helpers'
import useHealthComputer from 'hooks/useHealthComputer' import useHealthComputer from 'hooks/useHealthComputer'
import { BorrowTarget } from 'types/enums/borrowTarget'
import { BN_ZERO } from 'constants/math' import { BN_ZERO } from 'constants/math'
function getDebtAmount(modal: BorrowModal | null) { function getDebtAmount(modal: BorrowModal | null) {
@ -112,12 +112,12 @@ function BorrowModal(props: Props) {
return return
} }
computeMaxBorrowAmount( const maxBorrowAmount = computeMaxBorrowAmount(
asset.denom, asset.denom,
borrowToWallet ? BorrowTarget.Wallet : BorrowTarget.Deposit, borrowToWallet ? 'wallet' : 'deposit',
).then((maxBorrowAmount) => { )
setMax(BN(Math.min(maxBorrowAmount, modal?.marketData?.liquidity?.amount.toNumber() || 0)))
}) setMax(BigNumber.min(maxBorrowAmount, modal?.marketData?.liquidity?.amount || 0))
}, [isRepay, modal, asset.denom, computeMaxBorrowAmount, borrowToWallet]) }, [isRepay, modal, asset.denom, computeMaxBorrowAmount, borrowToWallet])
useEffect(() => { useEffect(() => {

View File

@ -19,6 +19,7 @@ import { AvailableOrderType } from 'components/Trade/TradeModule/SwapForm/OrderT
import TradeSummary from 'components/Trade/TradeModule/SwapForm/TradeSummary' import TradeSummary from 'components/Trade/TradeModule/SwapForm/TradeSummary'
import { BNCoin } from 'types/classes/BNCoin' import { BNCoin } from 'types/classes/BNCoin'
import estimateExactIn from 'api/swap/estimateExactIn' import estimateExactIn from 'api/swap/estimateExactIn'
import useHealthComputer from 'hooks/useHealthComputer'
interface Props { interface Props {
buyAsset: Asset buyAsset: Asset
@ -31,6 +32,7 @@ export default function SwapForm(props: Props) {
const { data: prices } = usePrices() const { data: prices } = usePrices()
const swap = useStore((s) => s.swap) const swap = useStore((s) => s.swap)
const [slippage] = useLocalStorage(SLIPPAGE_KEY, DEFAULT_SETTINGS.slippage) const [slippage] = useLocalStorage(SLIPPAGE_KEY, DEFAULT_SETTINGS.slippage)
const { computeMaxSwapAmount } = useHealthComputer(account)
const [isMarginChecked, setMarginChecked] = useState(false) const [isMarginChecked, setMarginChecked] = useState(false)
const [buyAssetAmount, setBuyAssetAmount] = useState(BN_ZERO) const [buyAssetAmount, setBuyAssetAmount] = useState(BN_ZERO)
@ -40,9 +42,9 @@ export default function SwapForm(props: Props) {
const [selectedOrderType, setSelectedOrderType] = useState<AvailableOrderType>('Market') const [selectedOrderType, setSelectedOrderType] = useState<AvailableOrderType>('Market')
const [isTransactionExecuting, setTransactionExecuting] = useState(false) const [isTransactionExecuting, setTransactionExecuting] = useState(false)
const accountSellAssetDeposit = useMemo( const maxSellAssetAmount = useMemo(
() => account?.deposits.find(byDenom(sellAsset.denom))?.amount || BN_ZERO, () => computeMaxSwapAmount(sellAsset.denom, buyAsset.denom, 'default'),
[account, sellAsset.denom], [computeMaxSwapAmount, sellAsset.denom, buyAsset.denom],
) )
const [buyAssetValue, sellAssetValue] = useMemo(() => { const [buyAssetValue, sellAssetValue] = useMemo(() => {
@ -71,10 +73,10 @@ export default function SwapForm(props: Props) {
useEffect(() => { useEffect(() => {
estimateExactIn( estimateExactIn(
{ denom: sellAsset.denom, amount: accountSellAssetDeposit }, { denom: sellAsset.denom, amount: maxSellAssetAmount.toString() },
buyAsset.denom, buyAsset.denom,
).then(setMaxBuyableAmountEstimation) ).then(setMaxBuyableAmountEstimation)
}, [accountSellAssetDeposit, buyAsset.denom, sellAsset.denom]) }, [maxSellAssetAmount, buyAsset.denom, sellAsset.denom])
useEffect(() => { useEffect(() => {
if (focusedInput === 'sell') { if (focusedInput === 'sell') {
@ -149,15 +151,15 @@ export default function SwapForm(props: Props) {
<RangeInput <RangeInput
wrapperClassName='p-4' wrapperClassName='p-4'
onBlur={dismissInputFocus} onBlur={dismissInputFocus}
disabled={isTransactionExecuting || accountSellAssetDeposit.isZero()} disabled={isTransactionExecuting || maxSellAssetAmount.isZero()}
onChange={handleRangeInputChange} onChange={handleRangeInputChange}
value={sellAssetAmount.shiftedBy(-sellAsset.decimals).toNumber()} value={sellAssetAmount.shiftedBy(-sellAsset.decimals).toNumber()}
max={accountSellAssetDeposit.shiftedBy(-sellAsset.decimals).toNumber()} max={maxSellAssetAmount.shiftedBy(-sellAsset.decimals).toNumber()}
/> />
<AssetAmountInput <AssetAmountInput
label='Sell' label='Sell'
max={accountSellAssetDeposit} max={maxSellAssetAmount}
amount={sellAssetAmount} amount={sellAssetAmount}
setAmount={setSellAssetAmount} setAmount={setSellAssetAmount}
assetUSDValue={sellAssetValue} assetUSDValue={sellAssetValue}

View File

@ -9,52 +9,61 @@ import {
import { VaultConfigBaseForString } from 'types/generated/mars-params/MarsParams.types' import { VaultConfigBaseForString } from 'types/generated/mars-params/MarsParams.types'
import useVaultConfigs from 'hooks/useVaultConfigs' import useVaultConfigs from 'hooks/useVaultConfigs'
import { import {
BorrowTarget,
compute_health_js, compute_health_js,
max_borrow_estimate_js, max_borrow_estimate_js,
max_swap_estimate_js,
max_withdraw_estimate_js, max_withdraw_estimate_js,
SwapKind,
} from 'utils/health_computer' } from 'utils/health_computer'
import { convertAccountToPositions } from 'utils/accounts' import { convertAccountToPositions } from 'utils/accounts'
import { VaultPositionValue } from 'types/generated/mars-credit-manager/MarsCreditManager.types' import {
Positions,
VaultPositionValue,
} from 'types/generated/mars-credit-manager/MarsCreditManager.types'
import useStore from 'store' import useStore from 'store'
import { BorrowTarget } from 'types/enums/borrowTarget' import { BN_ZERO } from 'constants/math'
import { BN } from 'utils/helpers'
export default function useHealthComputer(account: Account) { export default function useHealthComputer(account?: Account) {
const { data: prices } = usePrices() const { data: prices } = usePrices()
const { data: assetParams } = useAssetParams() const { data: assetParams } = useAssetParams()
const { data: vaultConfigs } = useVaultConfigs() const { data: vaultConfigs } = useVaultConfigs()
const baseCurrency = useStore((s) => s.baseCurrency) const baseCurrency = useStore((s) => s.baseCurrency)
const [health, setHealth] = useState(0) const [health, setHealth] = useState(0)
const positions = useMemo(() => convertAccountToPositions(account), [account]) const positions: Positions | null = useMemo(() => {
if (!account) return null
return convertAccountToPositions(account)
}, [account])
const baseCurrencyPrice = useMemo( const baseCurrencyPrice = useMemo(
() => prices.find((price) => price.denom === baseCurrency.denom)?.amount || 0, () => prices.find((price) => price.denom === baseCurrency.denom)?.amount || 0,
[prices, baseCurrency.denom], [prices, baseCurrency.denom],
) )
const vaultPositionValues = useMemo( const vaultPositionValues = useMemo(() => {
() => if (!account?.vaults) return null
account.vaults.reduce((prev, curr) => { return account.vaults.reduce((prev, curr) => {
const baseCoinPrice = prices.find((price) => price.denom === curr.denoms.lp)?.amount || 0 const baseCoinPrice = prices.find((price) => price.denom === curr.denoms.lp)?.amount || 0
prev[curr.address] = { prev[curr.address] = {
base_coin: { base_coin: {
amount: '0', // Not used by healthcomputer amount: '0', // Not used by healthcomputer
denom: curr.denoms.lp, denom: curr.denoms.lp,
value: curr.amounts.unlocking.times(baseCoinPrice).integerValue().toString(), value: curr.amounts.unlocking.times(baseCoinPrice).integerValue().toString(),
}, },
vault_coin: { vault_coin: {
amount: '0', // Not used by healthcomputer amount: '0', // Not used by healthcomputer
denom: curr.denoms.vault, denom: curr.denoms.vault,
value: curr.values.primary value: curr.values.primary
.div(baseCurrencyPrice) .div(baseCurrencyPrice)
.plus(curr.values.secondary.div(baseCurrencyPrice)) .plus(curr.values.secondary.div(baseCurrencyPrice))
.integerValue() .integerValue()
.toString(), .toString(),
}, },
} }
return prev return prev
}, {} as { [key: string]: VaultPositionValue }), }, {} as { [key: string]: VaultPositionValue })
[account.vaults, prices, baseCurrencyPrice], }, [account?.vaults, prices, baseCurrencyPrice])
)
const priceData = useMemo(() => { const priceData = useMemo(() => {
const baseCurrencyPrice = const baseCurrencyPrice =
@ -132,27 +141,31 @@ export default function useHealthComputer(account: Account) {
const computeMaxBorrowAmount = useCallback( const computeMaxBorrowAmount = useCallback(
(denom: string, target: BorrowTarget) => { (denom: string, target: BorrowTarget) => {
async function callMaxBorrowWasmFn(denom: string): Promise<number> { if (!healthComputer) return BN_ZERO
if (!healthComputer) return 0 return BN(max_borrow_estimate_js(healthComputer, denom, target))
return await max_borrow_estimate_js(healthComputer, denom, target)
}
return callMaxBorrowWasmFn(denom)
}, },
[healthComputer], [healthComputer],
) )
const computeMaxWithdrawAmount = useCallback( const computeMaxWithdrawAmount = useCallback(
(denom: string) => { (denom: string) => {
async function callMaxWithdrawWasmFn(denom: string): Promise<number> { if (!healthComputer) return BN_ZERO
if (!healthComputer) return 0 return BN(max_withdraw_estimate_js(healthComputer, denom))
return await max_withdraw_estimate_js(healthComputer, denom)
}
return callMaxWithdrawWasmFn(denom)
}, },
[healthComputer], [healthComputer],
) )
return { health, computeMaxBorrowAmount, computeMaxWithdrawAmount } const computeMaxSwapAmount = useCallback(
(from: string, to: string, kind: SwapKind) => {
if (!healthComputer) return BN_ZERO
try {
return BN(max_swap_estimate_js(healthComputer, from, to, kind))
} catch {
return BN_ZERO
}
},
[healthComputer],
)
return { health, computeMaxBorrowAmount, computeMaxWithdrawAmount, computeMaxSwapAmount }
} }

View File

@ -1,4 +0,0 @@
export enum BorrowTarget {
Deposit = 'deposit',
Wallet = 'wallet',
}

View File

@ -1,31 +1,78 @@
/* tslint:disable */ /* tslint:disable */
/* eslint-disable */ /* eslint-disable */
/** /**
* @param {any} health_computer * @param {HealthComputer} c
* @returns {any} * @returns {HealthValuesResponse}
*/ */
export function compute_health_js(health_computer: any): any export function compute_health_js(c: HealthComputer): HealthValuesResponse
/** /**
* @param {any} health_computer * @param {HealthComputer} c
* @param {any} withdraw_denom * @param {string} withdraw_denom
* @returns {any} * @returns {string}
*/ */
export function max_withdraw_estimate_js(health_computer: any, withdraw_denom: any): any export function max_withdraw_estimate_js(c: HealthComputer, withdraw_denom: string): string
/** /**
* @param {any} health_computer * @param {HealthComputer} c
* @param {any} borrow_denom * @param {string} borrow_denom
* @param {any} target * @param {BorrowTarget} target
* @returns {any} * @returns {string}
*/ */
export function max_borrow_estimate_js(health_computer: any, borrow_denom: any, target: any): any export function max_borrow_estimate_js(
c: HealthComputer,
borrow_denom: string,
target: BorrowTarget,
): string
/**
* @param {HealthComputer} c
* @param {string} from_denom
* @param {string} to_denom
* @param {SwapKind} kind
* @returns {string}
*/
export function max_swap_estimate_js(
c: HealthComputer,
from_denom: string,
to_denom: string,
kind: SwapKind,
): string
export interface HealthComputer {
kind: AccountKind
positions: Positions
denoms_data: DenomsData
vaults_data: VaultsData
}
export interface HealthValuesResponse {
total_debt_value: Uint128
total_collateral_value: Uint128
max_ltv_adjusted_collateral: Uint128
liquidation_threshold_adjusted_collateral: Uint128
max_ltv_health_factor: Decimal | null
liquidation_health_factor: Decimal | null
liquidatable: boolean
above_max_ltv: boolean
}
export type SwapKind = 'default' | 'margin'
export type BorrowTarget = 'deposit' | 'wallet' | { vault: { address: Addr } }
export type InitInput = RequestInfo | URL | Response | BufferSource | WebAssembly.Module export type InitInput = RequestInfo | URL | Response | BufferSource | WebAssembly.Module
export interface InitOutput { export interface InitOutput {
readonly memory: WebAssembly.Memory readonly memory: WebAssembly.Memory
readonly compute_health_js: (a: number) => number readonly compute_health_js: (a: number) => number
readonly max_withdraw_estimate_js: (a: number, b: number) => number readonly max_withdraw_estimate_js: (a: number, b: number, c: number, d: number) => void
readonly max_borrow_estimate_js: (a: number, b: number, c: number) => number readonly max_borrow_estimate_js: (a: number, b: number, c: number, d: number, e: number) => void
readonly max_swap_estimate_js: (
a: number,
b: number,
c: number,
d: number,
e: number,
f: number,
g: number,
) => void
readonly allocate: (a: number) => number readonly allocate: (a: number) => number
readonly deallocate: (a: number) => void readonly deallocate: (a: number) => void
readonly requires_stargate: () => void readonly requires_stargate: () => void
@ -33,6 +80,7 @@ export interface InitOutput {
readonly interface_version_8: () => void readonly interface_version_8: () => void
readonly __wbindgen_malloc: (a: number, b: number) => number readonly __wbindgen_malloc: (a: number, b: number) => number
readonly __wbindgen_realloc: (a: number, b: number, c: number, d: number) => number readonly __wbindgen_realloc: (a: number, b: number, c: number, d: number) => number
readonly __wbindgen_add_to_stack_pointer: (a: number) => number
readonly __wbindgen_free: (a: number, b: number, c: number) => void readonly __wbindgen_free: (a: number, b: number, c: number) => void
readonly __wbindgen_exn_store: (a: number) => void readonly __wbindgen_exn_store: (a: number) => void
} }

View File

@ -10,6 +10,15 @@ function getObject(idx) {
let heap_next = heap.length let heap_next = heap.length
function addHeapObject(obj) {
if (heap_next === heap.length) heap.push(heap.length + 1)
const idx = heap_next
heap_next = heap[idx]
heap[idx] = obj
return idx
}
function dropObject(idx) { function dropObject(idx) {
if (idx < 132) return if (idx < 132) return
heap[idx] = heap_next heap[idx] = heap_next
@ -125,133 +134,90 @@ function getStringFromWasm0(ptr, len) {
ptr = ptr >>> 0 ptr = ptr >>> 0
return cachedTextDecoder.decode(getUint8Memory0().subarray(ptr, ptr + len)) return cachedTextDecoder.decode(getUint8Memory0().subarray(ptr, ptr + len))
} }
function addHeapObject(obj) {
if (heap_next === heap.length) heap.push(heap.length + 1)
const idx = heap_next
heap_next = heap[idx]
heap[idx] = obj
return idx
}
let cachedFloat64Memory0 = null
function getFloat64Memory0() {
if (cachedFloat64Memory0 === null || cachedFloat64Memory0.byteLength === 0) {
cachedFloat64Memory0 = new Float64Array(wasm.memory.buffer)
}
return cachedFloat64Memory0
}
let cachedBigInt64Memory0 = null
function getBigInt64Memory0() {
if (cachedBigInt64Memory0 === null || cachedBigInt64Memory0.byteLength === 0) {
cachedBigInt64Memory0 = new BigInt64Array(wasm.memory.buffer)
}
return cachedBigInt64Memory0
}
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.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
}
/** /**
* @param {any} health_computer * @param {HealthComputer} c
* @returns {any} * @returns {HealthValuesResponse}
*/ */
export function compute_health_js(health_computer) { export function compute_health_js(c) {
const ret = wasm.compute_health_js(addHeapObject(health_computer)) const ret = wasm.compute_health_js(addHeapObject(c))
return takeObject(ret) return takeObject(ret)
} }
/** /**
* @param {any} health_computer * @param {HealthComputer} c
* @param {any} withdraw_denom * @param {string} withdraw_denom
* @returns {any} * @returns {string}
*/ */
export function max_withdraw_estimate_js(health_computer, withdraw_denom) { export function max_withdraw_estimate_js(c, withdraw_denom) {
const ret = wasm.max_withdraw_estimate_js( let deferred2_0
addHeapObject(health_computer), let deferred2_1
addHeapObject(withdraw_denom), try {
) const retptr = wasm.__wbindgen_add_to_stack_pointer(-16)
return takeObject(ret) const ptr0 = passStringToWasm0(withdraw_denom, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc)
const len0 = WASM_VECTOR_LEN
wasm.max_withdraw_estimate_js(retptr, addHeapObject(c), ptr0, len0)
var r0 = getInt32Memory0()[retptr / 4 + 0]
var r1 = getInt32Memory0()[retptr / 4 + 1]
deferred2_0 = r0
deferred2_1 = r1
return getStringFromWasm0(r0, r1)
} finally {
wasm.__wbindgen_add_to_stack_pointer(16)
wasm.__wbindgen_free(deferred2_0, deferred2_1, 1)
}
} }
/** /**
* @param {any} health_computer * @param {HealthComputer} c
* @param {any} borrow_denom * @param {string} borrow_denom
* @param {any} target * @param {BorrowTarget} target
* @returns {any} * @returns {string}
*/ */
export function max_borrow_estimate_js(health_computer, borrow_denom, target) { export function max_borrow_estimate_js(c, borrow_denom, target) {
const ret = wasm.max_borrow_estimate_js( let deferred2_0
addHeapObject(health_computer), let deferred2_1
addHeapObject(borrow_denom), try {
addHeapObject(target), const retptr = wasm.__wbindgen_add_to_stack_pointer(-16)
) const ptr0 = passStringToWasm0(borrow_denom, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc)
return takeObject(ret) const len0 = WASM_VECTOR_LEN
wasm.max_borrow_estimate_js(retptr, addHeapObject(c), ptr0, len0, addHeapObject(target))
var r0 = getInt32Memory0()[retptr / 4 + 0]
var r1 = getInt32Memory0()[retptr / 4 + 1]
deferred2_0 = r0
deferred2_1 = r1
return getStringFromWasm0(r0, r1)
} finally {
wasm.__wbindgen_add_to_stack_pointer(16)
wasm.__wbindgen_free(deferred2_0, deferred2_1, 1)
}
}
/**
* @param {HealthComputer} c
* @param {string} from_denom
* @param {string} to_denom
* @param {SwapKind} kind
* @returns {string}
*/
export function max_swap_estimate_js(c, from_denom, to_denom, kind) {
let deferred3_0
let deferred3_1
try {
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16)
const ptr0 = passStringToWasm0(from_denom, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc)
const len0 = WASM_VECTOR_LEN
const ptr1 = passStringToWasm0(to_denom, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc)
const len1 = WASM_VECTOR_LEN
wasm.max_swap_estimate_js(retptr, addHeapObject(c), ptr0, len0, ptr1, len1, addHeapObject(kind))
var r0 = getInt32Memory0()[retptr / 4 + 0]
var r1 = getInt32Memory0()[retptr / 4 + 1]
deferred3_0 = r0
deferred3_1 = r1
return getStringFromWasm0(r0, r1)
} finally {
wasm.__wbindgen_add_to_stack_pointer(16)
wasm.__wbindgen_free(deferred3_0, deferred3_1, 1)
}
} }
function handleError(f, args) { function handleError(f, args) {
@ -295,21 +261,16 @@ async function __wbg_load(module, imports) {
function __wbg_get_imports() { function __wbg_get_imports() {
const imports = {} const imports = {}
imports.wbg = {} imports.wbg = {}
imports.wbg.__wbindgen_object_drop_ref = function (arg0) { imports.wbg.__wbindgen_object_clone_ref = function (arg0) {
takeObject(arg0) const ret = getObject(arg0)
} return addHeapObject(ret)
imports.wbg.__wbindgen_is_object = function (arg0) {
const val = getObject(arg0)
const ret = typeof val === 'object' && val !== null
return ret
} }
imports.wbg.__wbindgen_is_undefined = function (arg0) { imports.wbg.__wbindgen_is_undefined = function (arg0) {
const ret = getObject(arg0) === undefined const ret = getObject(arg0) === undefined
return ret return ret
} }
imports.wbg.__wbindgen_in = function (arg0, arg1) { imports.wbg.__wbindgen_object_drop_ref = function (arg0) {
const ret = getObject(arg0) in getObject(arg1) takeObject(arg0)
return ret
} }
imports.wbg.__wbindgen_string_get = function (arg0, arg1) { imports.wbg.__wbindgen_string_get = function (arg0, arg1) {
const obj = getObject(arg1) const obj = getObject(arg1)
@ -321,195 +282,21 @@ function __wbg_get_imports() {
getInt32Memory0()[arg0 / 4 + 1] = len1 getInt32Memory0()[arg0 / 4 + 1] = len1
getInt32Memory0()[arg0 / 4 + 0] = ptr1 getInt32Memory0()[arg0 / 4 + 0] = ptr1
} }
imports.wbg.__wbindgen_error_new = function (arg0, arg1) { imports.wbg.__wbg_parse_670c19d4e984792e = function () {
const ret = new Error(getStringFromWasm0(arg0, arg1)) return handleError(function (arg0, arg1) {
return addHeapObject(ret) const ret = JSON.parse(getStringFromWasm0(arg0, arg1))
return addHeapObject(ret)
}, arguments)
} }
imports.wbg.__wbindgen_is_string = function (arg0) { imports.wbg.__wbg_stringify_e25465938f3f611f = function () {
const ret = typeof getObject(arg0) === 'string'
return ret
}
imports.wbg.__wbindgen_boolean_get = function (arg0) {
const v = getObject(arg0)
const ret = typeof v === 'boolean' ? (v ? 1 : 0) : 2
return ret
}
imports.wbg.__wbindgen_is_bigint = function (arg0) {
const ret = typeof getObject(arg0) === 'bigint'
return ret
}
imports.wbg.__wbindgen_bigint_from_u64 = function (arg0) {
const ret = BigInt.asUintN(64, arg0)
return addHeapObject(ret)
}
imports.wbg.__wbindgen_jsval_eq = function (arg0, arg1) {
const ret = getObject(arg0) === getObject(arg1)
return ret
}
imports.wbg.__wbg_new_abda76e883ba8a5f = function () {
const ret = new Error()
return addHeapObject(ret)
}
imports.wbg.__wbg_stack_658279fe44541cf6 = function (arg0, arg1) {
const ret = getObject(arg1).stack
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc)
const len1 = WASM_VECTOR_LEN
getInt32Memory0()[arg0 / 4 + 1] = len1
getInt32Memory0()[arg0 / 4 + 0] = ptr1
}
imports.wbg.__wbg_error_f851667af71bcfc6 = function (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)
}
}
imports.wbg.__wbindgen_jsval_loose_eq = function (arg0, arg1) {
const ret = getObject(arg0) == getObject(arg1)
return ret
}
imports.wbg.__wbindgen_number_get = function (arg0, arg1) {
const obj = getObject(arg1)
const ret = typeof obj === 'number' ? obj : undefined
getFloat64Memory0()[arg0 / 8 + 1] = isLikeNone(ret) ? 0 : ret
getInt32Memory0()[arg0 / 4 + 0] = !isLikeNone(ret)
}
imports.wbg.__wbindgen_object_clone_ref = function (arg0) {
const ret = getObject(arg0)
return addHeapObject(ret)
}
imports.wbg.__wbindgen_string_new = function (arg0, arg1) {
const ret = getStringFromWasm0(arg0, arg1)
return addHeapObject(ret)
}
imports.wbg.__wbg_getwithrefkey_5e6d9547403deab8 = function (arg0, arg1) {
const ret = getObject(arg0)[getObject(arg1)]
return addHeapObject(ret)
}
imports.wbg.__wbg_set_841ac57cff3d672b = function (arg0, arg1, arg2) {
getObject(arg0)[takeObject(arg1)] = takeObject(arg2)
}
imports.wbg.__wbg_get_44be0491f933a435 = function (arg0, arg1) {
const ret = getObject(arg0)[arg1 >>> 0]
return addHeapObject(ret)
}
imports.wbg.__wbg_length_fff51ee6522a1a18 = function (arg0) {
const ret = getObject(arg0).length
return ret
}
imports.wbg.__wbindgen_is_function = function (arg0) {
const ret = typeof getObject(arg0) === 'function'
return ret
}
imports.wbg.__wbg_next_526fc47e980da008 = function (arg0) {
const ret = getObject(arg0).next
return addHeapObject(ret)
}
imports.wbg.__wbg_next_ddb3312ca1c4e32a = function () {
return handleError(function (arg0) { return handleError(function (arg0) {
const ret = getObject(arg0).next() const ret = JSON.stringify(getObject(arg0))
return addHeapObject(ret) return addHeapObject(ret)
}, arguments) }, arguments)
} }
imports.wbg.__wbg_done_5c1f01fb660d73b5 = function (arg0) {
const ret = getObject(arg0).done
return ret
}
imports.wbg.__wbg_value_1695675138684bd5 = function (arg0) {
const ret = getObject(arg0).value
return addHeapObject(ret)
}
imports.wbg.__wbg_iterator_97f0c81209c6c35a = function () {
const ret = Symbol.iterator
return addHeapObject(ret)
}
imports.wbg.__wbg_get_97b561fb56f034b5 = function () {
return handleError(function (arg0, arg1) {
const ret = Reflect.get(getObject(arg0), getObject(arg1))
return addHeapObject(ret)
}, arguments)
}
imports.wbg.__wbg_call_cb65541d95d71282 = function () {
return handleError(function (arg0, arg1) {
const ret = getObject(arg0).call(getObject(arg1))
return addHeapObject(ret)
}, arguments)
}
imports.wbg.__wbg_new_b51585de1b234aff = function () {
const ret = new Object()
return addHeapObject(ret)
}
imports.wbg.__wbg_isArray_4c24b343cb13cfb1 = function (arg0) {
const ret = Array.isArray(getObject(arg0))
return ret
}
imports.wbg.__wbg_instanceof_ArrayBuffer_39ac22089b74fddb = function (arg0) {
let result
try {
result = getObject(arg0) instanceof ArrayBuffer
} catch {
result = false
}
const ret = result
return ret
}
imports.wbg.__wbg_isSafeInteger_bb8e18dd21c97288 = function (arg0) {
const ret = Number.isSafeInteger(getObject(arg0))
return ret
}
imports.wbg.__wbg_entries_e51f29c7bba0c054 = function (arg0) {
const ret = Object.entries(getObject(arg0))
return addHeapObject(ret)
}
imports.wbg.__wbg_buffer_085ec1f694018c4f = function (arg0) {
const ret = getObject(arg0).buffer
return addHeapObject(ret)
}
imports.wbg.__wbg_new_8125e318e6245eed = function (arg0) {
const ret = new Uint8Array(getObject(arg0))
return addHeapObject(ret)
}
imports.wbg.__wbg_set_5cf90238115182c3 = function (arg0, arg1, arg2) {
getObject(arg0).set(getObject(arg1), arg2 >>> 0)
}
imports.wbg.__wbg_length_72e2208bbc0efc61 = function (arg0) {
const ret = getObject(arg0).length
return ret
}
imports.wbg.__wbg_instanceof_Uint8Array_d8d9cb2b8e8ac1d4 = function (arg0) {
let result
try {
result = getObject(arg0) instanceof Uint8Array
} catch {
result = false
}
const ret = result
return ret
}
imports.wbg.__wbindgen_bigint_get_as_i64 = function (arg0, arg1) {
const v = getObject(arg1)
const ret = typeof v === 'bigint' ? v : undefined
getBigInt64Memory0()[arg0 / 8 + 1] = isLikeNone(ret) ? BigInt(0) : ret
getInt32Memory0()[arg0 / 4 + 0] = !isLikeNone(ret)
}
imports.wbg.__wbindgen_debug_string = function (arg0, arg1) {
const ret = debugString(getObject(arg1))
const ptr1 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc)
const len1 = WASM_VECTOR_LEN
getInt32Memory0()[arg0 / 4 + 1] = len1
getInt32Memory0()[arg0 / 4 + 0] = ptr1
}
imports.wbg.__wbindgen_throw = function (arg0, arg1) { imports.wbg.__wbindgen_throw = function (arg0, arg1) {
throw new Error(getStringFromWasm0(arg0, arg1)) throw new Error(getStringFromWasm0(arg0, arg1))
} }
imports.wbg.__wbindgen_memory = function () {
const ret = wasm.memory
return addHeapObject(ret)
}
return imports return imports
} }
@ -519,8 +306,6 @@ function __wbg_init_memory(imports, maybe_memory) {}
function __wbg_finalize_init(instance, module) { function __wbg_finalize_init(instance, module) {
wasm = instance.exports wasm = instance.exports
__wbg_init.__wbindgen_wasm_module = module __wbg_init.__wbindgen_wasm_module = module
cachedBigInt64Memory0 = null
cachedFloat64Memory0 = null
cachedInt32Memory0 = null cachedInt32Memory0 = null
cachedUint8Memory0 = null cachedUint8Memory0 = null

View File

@ -2,8 +2,17 @@
/* eslint-disable */ /* eslint-disable */
export const memory: WebAssembly.Memory export const memory: WebAssembly.Memory
export function compute_health_js(a: number): number export function compute_health_js(a: number): number
export function max_withdraw_estimate_js(a: number, b: number): number export function max_withdraw_estimate_js(a: number, b: number, c: number, d: number): void
export function max_borrow_estimate_js(a: number, b: number, c: number): number export function max_borrow_estimate_js(a: number, b: number, c: number, d: number, e: number): void
export function max_swap_estimate_js(
a: number,
b: number,
c: number,
d: number,
e: number,
f: number,
g: number,
): void
export function allocate(a: number): number export function allocate(a: number): number
export function deallocate(a: number): void export function deallocate(a: number): void
export function requires_stargate(): void export function requires_stargate(): void
@ -11,5 +20,6 @@ export function requires_iterator(): void
export function interface_version_8(): void export function interface_version_8(): void
export function __wbindgen_malloc(a: number, b: number): number export function __wbindgen_malloc(a: number, b: number): number
export function __wbindgen_realloc(a: number, b: number, c: number, d: number): number export function __wbindgen_realloc(a: number, b: number, c: number, d: number): number
export function __wbindgen_add_to_stack_pointer(a: number): number
export function __wbindgen_free(a: number, b: number, c: number): void export function __wbindgen_free(a: number, b: number, c: number): void
export function __wbindgen_exn_store(a: number): void export function __wbindgen_exn_store(a: number): void