From c3258a49a15779338b28e4ef3ffc90703bc53baa Mon Sep 17 00:00:00 2001 From: Matt A <9440455+matt-allan@users.noreply.github.com> Date: Thu, 28 Mar 2024 15:41:32 -0400 Subject: [PATCH] Remove unnecessary bs58 encoding (#77) The bs58 encoding is CPU intensive. We can skip the repeated encoding since everything within the function needs the encoded value anyway. --- packages/token-sdk/src/fetcher.ts | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/packages/token-sdk/src/fetcher.ts b/packages/token-sdk/src/fetcher.ts index 97b91c6..2a7504e 100644 --- a/packages/token-sdk/src/fetcher.ts +++ b/packages/token-sdk/src/fetcher.ts @@ -68,8 +68,8 @@ export class TokenFetcher { addresses: Address[], refresh: boolean = false ): Promise> { - const mints = AddressUtil.toPubKeys(addresses); - const misses = refresh ? mints : mints.filter((mint) => !this._cache.has(mint.toBase58())); + const mints = AddressUtil.toStrings(addresses); + const misses = refresh ? mints : mints.filter((mint) => !this._cache.has(mint)); if (misses.length > 0) { const mintInfos = ( @@ -78,9 +78,8 @@ export class TokenFetcher { invariant(misses.length === mintInfos.length, "At least one mint info not found"); misses.forEach((mint, index) => { - const mintString = mint.toBase58(); - this._cache.set(mintString, { - mint: mintString, + this._cache.set(mint, { + mint, decimals: mintInfos[index].decimals, }); }); @@ -96,11 +95,10 @@ export class TokenFetcher { } next = []; misses.forEach((mint) => { - const mintString = mint.toBase58(); - const cachedValue = this._cache.get(mintString); + const cachedValue = this._cache.get(mint); invariant(cachedValue, "Expecting token to be in cache"); - const token = mergeMetadata(cachedValue, metadatas.get(mintString)); - this._cache.set(mintString, token); + const token = mergeMetadata(cachedValue, metadatas.get(mint)); + this._cache.set(mint, token); if (MetadataUtil.isPartial(token)) { next.push(mint); } @@ -113,7 +111,7 @@ export class TokenFetcher { } } - return new Map(mints.map((mint) => [mint.toBase58(), this._cache.get(mint.toBase58())!])); + return new Map(mints.map((mint) => [mint, this._cache.get(mint)!])); } private request(promise: PromiseLike) {