nogc 0.1.1

Utilities to write @nogc code

To use this package, put the following dependency into your project's dependencies section:



Build Status Coverage

Utilities to write @nogc code, including converting values to strings (text) and a variant of std.exception.enforce that is @nogc but limits the type of the exception thrown to be NoGcException. Examples:

// text is @system because it returns a slice to a static array
// if you need to store the string you'll need to make a copy
// since consecutive calls will return the same slice and it will
// be mutated
@nogc @system unittest {
    import nogc.conv: text;
    // works with basic types and user defined structs/classes
    assert(text(1, " ", "foo", " ", 2.0) == "1 foo 2.000000");

// enforce is @safe, since it internally makes a call to `text` but
// immediately throws an exception, and casting it to `string` makes
// it immutable. Ugly but it works.
@nogc @safe unittest {
    import nogc.exception: enforce;
    import nogc.conv: text;
    const expected = 1;
    const actual = 1;
    enforce(actual == expected, "Expected: ", expected, " but got: ", actual);
  • Atila Neves
0.1.1 2018-Nov-02
0.1.0 2018-Oct-26
0.0.3 2018-Oct-12
0.0.2 2018-Sep-26
0.0.1 2017-Apr-28
Show all 6 versions
Download Stats:
  • 20 downloads today

  • 251 downloads this week

  • 1203 downloads this month

  • 8721 downloads total

Short URL: