From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Philipp Stephani
> I don't know enough about how signaling and unwind-protect work. I= t's
> just black stack magic for me right now :)
Fsignal works using longjmp.=C2=A0 unwind-protect (and dynamic let-bindings= )
works by adding things onto a stack which Fsignal will run just prior to
calling longjmp.
> I think we just need to implement funcall (from the module API) like t= his:
>=C2=A0 =C2=A0 =C2=A0global error =3D 0
>=C2=A0 =C2=A0 =C2=A0module_funcall(fun, args):
>=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0// wrap (protect?) this with the righ= t code
>=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0// - to keep the control
>=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0// - set ret to nil and error to 1 in= case of error
>=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0ret =3D Ffuncall(fun, args)
>=C2=A0 =C2=A0 =C2=A0 =C2=A0 =C2=A0return ret
> The error is accessible via error_get(), error_clear() and
> error_check() in the module API. error_get() is currently redundant
> with error_check() unless we decide to return detailed errors.
I don't understand what kind of error handling you have in mind.
How/why/when would we use things like error_get, error_clear, etc...?
= blockquote>Because setjmp/longjmp and therefore Fthrow/= Fsignal don't work, you need to design a different error handling API t= hat doesn't rely on non-local jumps. There are three options: return va= lues, output parameters, thread-local state. All three have their pros and = cons; Daniel opted for the third. The error_... functions are needed to acc= ess that thread-local state.=C2=A0
> I didn't think about the case where a module calls Fthrow but my g= uess
> is it will just work. I have to test thoroughly what I have already
> anyway, I'll see if it works.
Fthrow uses the same technique as Fsignal, and I think your intuition is
right: it should just work (for both).
No, it can't. See Daniel's initial= posting where he designed the module API.=C2=A0