GitXplorerGitXplorer
J

exitclean

public
0 stars
0 forks
0 issues

Commits

List of commits on branch master.
Unverified
c42d6e91c8069b60ad6687b7bc451af654dcf9cd

add missing ) in README.md

JJohn-Colvin committed 9 years ago
Unverified
e45f6dfdb3821eae466722c692cba72495a00ea0

add missing newline in README.md

JJohn-Colvin committed 9 years ago
Unverified
ce48beb09f46b2617db633831238746bec3e8107

Update README.md

JJohn-Colvin committed 9 years ago
Unverified
010aabb9df2a6847d202ad51a280d3d733e713f2

initial

JJohn-Colvin committed 9 years ago
Unverified
0908c5477fe93852adc8c83ca29278abfb1a781f

Initial commit

JJohn-Colvin committed 9 years ago

README

The README file for this repository.

exitclean

For simple programs (and even some less simple), C's exit function from stdlib.h is very convenient. You can use it in D (import core.stdc.stdlib;), but it's not going to run any destructors or terminate the runtime cleanly.

exitclean deals with this by throwing a custom exception, so all stacks are appropriately unwound. Use it like this:

import exitclean;

void foo()
{
    if (somethingsWrong)
        exit(1);
}

You can then catch the ExitException yourself in your main, extract the exit code (available as a member code of the exception) and return it.

In order to save effort, exitclean also defines a mixin template to generate a main for you that deals with the try/catch and return automagically. Use like this:

void myMain()
{
    // Your program here
}

mixin Main!myMain;

or like this:

mixin Main!((string[] args)
{
    // Your program here
});

All that's required is that the function you provide to Main takes either nothing or string[] and returns either void or int.

Options

There are 2 versions that affect the behaviour of Main. ShowExitLoc causes the function name, file and line where exit was called from to be printed to stderr before exiting. ShowExitTrace causes a full stack trace to be printed to stderr. ShowExitLoc is enabled by default in debug builds.

Caveats

Because we are using an exception, exit will trigger any scope(failure) clauses on the way up the stack.

exit will be blocked by any catch(Exception) statement on the way up the stack.If this is a problem for you, I suggest forking this project and changing ExitException to inherit from Throwable instead of Exception.