Skip to content

Commit

Permalink
feat: optimize loading internal transfers at startup
Browse files Browse the repository at this point in the history
  • Loading branch information
BobTheBuidler committed Dec 17, 2024
1 parent 099faa9 commit 6def422
Showing 1 changed file with 34 additions and 17 deletions.
51 changes: 34 additions & 17 deletions eth_portfolio/_ledgers/address.py
Original file line number Diff line number Diff line change
Expand Up @@ -673,28 +673,45 @@ async def _load_new_objects(
a_sync.as_completed, tqdm=True, desc=f"Trace Filters {self.address}"
)

if tasks := [
create_task(
coro=InternalTransfer.from_trace(trace, self.load_prices),
name="InternalTransfer.from_trace",
)
for traces in generator_function(trace_filter_coros)
for trace in await traces
if traces := [
trace for traces in generator_function(trace_filter_coros) for trace in await traces
]:
internal_transfers = []
append_transfer = internal_transfers.append
load = InternalTransfer.from_trace
tqdm_desc = f"Internal Transfers {self.address}"
done = 0

async for internal_transfer in a_sync.as_completed(
tasks, aiter=True, tqdm=True, desc=f"Internal Transfers {self.address}"
):
if internal_transfer:
append_transfer(internal_transfer)
yield internal_transfer

done += 1
if done % 100 == 0:
await sleep(0)
if self.load_prices:
tasks = (
create_task(
coro=load(trace, load_prices=True), name="InternalTransfer.from_trace"
)
for trace in traces
)
del traces
async for internal_transfer in a_sync.as_completed(
tasks, aiter=True, tqdm=True, desc=tqdm_desc
):
if internal_transfer is not None:
append_transfer(internal_transfer)
yield internal_transfer

done += 1
if done % 100 == 0:
await sleep(0)

else:
pop_next_trace = traces.pop
for _ in tqdm(tuple(range(len(traces))), desc=tqdm_desc):
internal_transfer = await load(pop_next_trace(), load_prices=False)
if internal_transfer is not None:
append_transfer(internal_transfer)
yield internal_transfer

done += 1
if done % 100 == 0:
await sleep(0)

if internal_transfers:
self.objects.extend(internal_transfers)
Expand Down

0 comments on commit 6def422

Please sign in to comment.