How to write async code in Nim to be called by timer periodically?
Asked Answered
R

1

6

I need to save a cache to disk periodically, every 500ms, how can I do that?

The code I tried is not compiled properly. Also, it seems that the asyncCheck should be used for error checking.

import tables, os, asyncdispatch

var cache = init_table[string, int]()

proc save(cache: Table[string, int]): Future[void] {.async.} =
  echo cache

addTimer(
  timeout = 500, oneshot = false, cb = proc() = discard cache.save()
)

for i in (0..3):
  cache["a"] = i
  echo cache
  sleep 1000
Rathskeller answered 7/9, 2020 at 4:23 Comment(0)
H
7

I think this is the sort of thing you're after

import tables,asyncdispatch,strformat    

#global, GC'd variable, careful!         
var cache = initTable[string, int]()    
     
proc save(){.async.} =                                  
  while true:    
    echo &"writing cache:{cache}"    
    await sleepAsync(500)    

#just some fake data sources         
proc write1(){.async.} =  
  await sleepAsync(900)
  for i in 0..99:                                            
    cache["a"]=i     
    await sleepAsync(20)
#that happen at various rates
proc write2(){.async.} = 
  for i in 0..99:
     cache["b"]=i
     await sleepAsync(33)

#asyncCheck when we're not interested in the Future from a proc
#it will raise an Exception if the proc has an error
asyncCheck save() #save starts running asynchronously

echo "but we can still run other code"

waitFor:          #blocks here until both write1 and write2 finish            
  write1() and write2()

echo "writing is done but save is still running"
cache["c"]=17

#os.sleep would block the whole thread, including save so instead
waitFor(sleepAsync(500)) #wait for save to echo one more time

echo "quit"

outputs something like:

writing cache:{:}
but we can still run other code
writing cache:{"b": 15}
writing cache:{"b": 30, "a": 4}
writing cache:{"b": 45, "a": 29}
writing cache:{"b": 59, "a": 54}
writing cache:{"b": 74, "a": 78}
writing cache:{"b": 89, "a": 99}
writing is done but save is still running
writing cache:{"b": 99, "c": 17, "a": 99}
quit
Helical answered 8/9, 2020 at 22:54 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.