jdiutil 1.0.3

Just-Do-It util mixin, some small util mixin to make (debug) life easier: string interpolation etc ...


To use this package, run the following command in your project's root directory:

Manual usage
Put the following dependency into your project's dependences section:

jdiutil: Just-Do-It util mixin

Some small util mixin to make (debug) life easier:

Each of these mixins can be used individually or together in any combination:

  • string interpolation for easy debug print: _S with var name; _s without var name
  • ToString will generate string with class fields content, instead of just plain pointer.
  • ReadOnly, ReadWrite declare fields without boilerplate code
  • Singleton, Low-Lock Singleton Pattern https://wiki.dlang.org/Low-Lock_Singleton_Pattern
  • AtomicCounted, atomic counter

Examples, check app.d:

public import jdiutil;

class Point {
  // declare fields
  mixin ReadOnly! (int,     "x", 3);
  mixin ReadWrite!(double,  "y");
  mixin ReadWrite!(string,  "label", "default value");

  // atomic counter
  mixin AtomicCounted;

  // this is a Singleton class!
  mixin Singleton!Point;

  // debug print string helper
  mixin ToString!Point;
}


void main()
{
        int i = 100;
        double d = 1.23456789;
        Point thePoint = Point.getSingleton();

        // multiple vars separated by ';'
        // _S with var name; _s without var name
        writeln(mixin(_S!"print with    var name: {i; d; thePoint}"));
        writeln(mixin(_s!"print without var name: {i; d; thePoint}"));

      //thePoint.x = 4;  // compile Error: x is ReadOnly
        thePoint.y = 4;  // ok
        thePoint.incCount();
        logger.info(mixin(_S!"works in logger too: {i; d; thePoint}"));

        thePoint.y(3.14).label("pi");  // ok
        string str = mixin(_S!"assign to string with custom format: {i; d%06.2f; thePoint}");
        writeln(str);

        Point samePoint = Point.getSingleton();
        samePoint.incCount();
        writeln(mixin(_S!"it's the same point: {thePoint; samePoint}"));
}

Output:

print with    var name: i=100 d=1.23457 thePoint=app.Point(_x=3 _y=nan _label=default value _counter=0)
print without var name: 100 1.23457 app.Point(_x=3 _y=nan _label=default value _counter=0)
2020-06-21T09:37:21.780 [info] app.d:40:main works in logger too: i=100 d=1.23457 thePoint=app.Point(_x=3 _y=4 _label=default value _counter=1)
assign to string with custom format: i=100 d=001.23 thePoint=app.Point(_x=3 _y=3.14 _label=pi _counter=1)
it's the same point: thePoint=app.Point(_x=3 _y=3.14 _label=pi _counter=2) samePoint=app.Point(_x=3 _y=3.14 _label=pi _counter=2)
Authors:
  • mw
Dependencies:
none
Versions:
1.3.0 2023-Jun-19
1.2.3 2023-Jun-16
1.2.1 2023-May-14
1.2.0 2022-Nov-14
1.1.7 2022-Jul-27
Show all 23 versions
Download Stats:
  • 0 downloads today

  • 0 downloads this week

  • 0 downloads this month

  • 121 downloads total

Score:
0.7
Short URL:
jdiutil.dub.pm