data:image/s3,"s3://crabby-images/6701a/6701a689455294e4c49944fbc0e886d975a4d65a" alt="Pure c compiler for windows 10"
data:image/s3,"s3://crabby-images/ae2fc/ae2fc081f36fbb2dea782111e358ac268a38de2a" alt="pure c compiler for windows 10 pure c compiler for windows 10"
data:image/s3,"s3://crabby-images/bf349/bf3495da0028050b88de49fdb500c762b4582264" alt="pure c compiler for windows 10 pure c compiler for windows 10"
You can install vectored exception handler over the area that possible can throw exceptions, it will get you callback in case exception happens, and later you can remove this handler. It's a OS API, a bit uglier and slower (only when exception is thrown) - because it will get all exceptions (before SEH handlers) that are thrown, you need to filter only ones you are interested in. Here's the definitions: It's a bit tricky to use because it requires to write custom handler, but its possible.Īnother option is just to use vectored exception handler to catch exceptions. Though the handling syntax is a bit different, so you'll need to wrap this stuff in preprocessor ifdefs.
data:image/s3,"s3://crabby-images/60ceb/60cebc0c329bcdc0b900041f4854702a81b7c0bd" alt="pure c compiler for windows 10 pure c compiler for windows 10"
It installs SEH handler with a bit of inline assembly. But there is a small trick you can do - MinGW provides _try1 and _except1 macros which does almost same stuff as MSVC. This is for x86_64, no idea about SEH support with clang & 32-bit code. Clang supports SEH on Windows exactly same as MSVC.
data:image/s3,"s3://crabby-images/6701a/6701a689455294e4c49944fbc0e886d975a4d65a" alt="Pure c compiler for windows 10"