Open IamfromSpace opened 11 months ago
@kokobd, it sounded like your suggestion was to add an NFData constraint?
NFData
. At this line: try (fn (either error id eCtx) event)
, currently we don't call toJSON
or Aeson.encode
. If we convert the result to json within this expression, we are effectively forcing evaluation.hal
's library code, I suggest a refactor of error handling:
a. Use explicit throwIO
instead of error
b. Make error type customizable - not limited to the current User
error.Is (1) enough for all possible user code? I was imagining that if hal code for parsing could get tripped up by this, other kinds of user errors could too. A user with error
in their pure runtime likely doesn’t expect that the runtime would exit, and it seems like it would? I’ve been planning to see if I can recreate this.
The user is free to create any bottom value (infinite list or error) in their data structure as long as it's irrelant for ToJSON
. After we get the result Aeson.Value
, no user code will be forced to run anymore, so no new pure error could be thrown. The only other place where the user can throw an error is their IO
monad, but that is catchable by try
. So the runtime won't be crashed.
130 address an issue where exceptions weren’t caught in the runtime code because of laziness, but the next step is to try an eliminate this happening in user code too. There’s little reason for laziness to delay evaluation beyond the current execution—or it should be GC’d, knowing it could never be evaluated at all.
@kokobd, it sounded like your suggestion was to add an
NFData
constraint?