0000: 2f 2a 2a 0a 20 2a 20 41 75 74 68 6f 72 73 3a 20 /**. * Authors:
0010: 6b 2e 69 6e 61 62 61 0a 20 2a 20 4c 69 63 65 6e k.inaba. * Licen
0020: 73 65 3a 20 4e 59 53 4c 20 30 2e 39 39 38 32 20 se: NYSL 0.9982
0030: 68 74 74 70 3a 2f 2f 77 77 77 2e 6b 6d 6f 6e 6f http://www.kmono
0040: 73 2e 6e 65 74 2f 6e 79 73 6c 2f 0a 20 2a 0a 20 s.net/nysl/. *.
0050: 2a 20 43 6f 6d 6d 6f 6e 20 74 72 69 63 6b 73 20 * Common tricks
0060: 61 6e 64 20 75 74 69 6c 69 74 69 65 73 20 66 6f and utilities fo
0070: 72 20 70 72 6f 67 72 61 6d 6d 69 6e 67 20 69 6e r programming in
0080: 20 44 2e 0a 20 2a 2f 0a 6d 6f 64 75 6c 65 20 74 D.. */.module t
0090: 72 69 63 6b 73 2e 74 72 69 63 6b 73 3b 0a 69 6d ricks.tricks;.im
00a0: 70 6f 72 74 20 74 72 69 63 6b 73 2e 74 65 73 74 port tricks.test
00b0: 3b 0a 69 6d 70 6f 72 74 20 73 74 64 2e 61 72 72 ;.import std.arr
00c0: 61 79 20 20 20 20 20 20 3a 20 61 70 70 65 6e 64 ay : append
00d0: 65 72 3b 0a 69 6d 70 6f 72 74 20 73 74 64 2e 66 er;.import std.f
00e0: 6f 72 6d 61 74 20 20 20 20 20 3a 20 66 6f 72 6d ormat : form
00f0: 61 74 74 65 64 57 72 69 74 65 3b 0d 0a 69 6d 70 attedWrite;..imp
0100: 6f 72 74 20 63 6f 72 65 2e 65 78 63 65 70 74 69 ort core.excepti
0110: 6f 6e 20 3a 20 41 73 73 65 72 74 45 72 72 6f 72 on : AssertError
0120: 3b 0a 0a 2f 2f 2f 20 53 69 6d 70 6c 65 20 57 72 ;../// Simple Wr
0130: 61 70 70 65 72 20 66 6f 72 20 73 74 64 2e 66 6f apper for std.fo
0140: 72 6d 61 74 2e 64 6f 46 6f 72 6d 61 74 0a 0a 73 rmat.doFormat..s
0150: 74 72 69 6e 67 20 73 70 72 69 6e 74 66 28 73 74 tring sprintf(st
0160: 72 69 6e 67 20 66 6d 74 2c 20 54 2e 2e 2e 29 28 ring fmt, T...)(
0170: 54 20 70 61 72 61 6d 73 29 0a 7b 0a 09 61 75 74 T params).{..aut
0180: 6f 20 77 72 69 74 65 72 20 3d 20 61 70 70 65 6e o writer = appen
0190: 64 65 72 21 73 74 72 69 6e 67 28 29 3b 0a 09 66 der!string();..f
01a0: 6f 72 6d 61 74 74 65 64 57 72 69 74 65 28 77 72 ormattedWrite(wr
01b0: 69 74 65 72 2c 20 66 6d 74 2c 20 70 61 72 61 6d iter, fmt, param
01c0: 73 29 3b 0a 09 72 65 74 75 72 6e 20 77 72 69 74 s);..return writ
01d0: 65 72 2e 64 61 74 61 3b 0a 7d 0a 0a 75 6e 69 74 er.data;.}..unit
01e0: 74 65 73 74 0a 7b 0a 09 61 73 73 65 72 74 5f 65 test.{..assert_e
01f0: 71 28 20 73 70 72 69 6e 74 66 21 22 25 73 20 3d q( sprintf!"%s =
0200: 3d 20 25 30 34 64 22 28 22 31 2b 32 22 2c 20 33 = %04d"("1+2", 3
0210: 29 2c 20 22 31 2b 32 20 3d 3d 20 30 30 30 33 22 ), "1+2 == 0003"
0220: 20 29 3b 0d 0a 09 61 73 73 65 72 74 5f 65 71 28 );...assert_eq(
0230: 20 73 70 72 69 6e 74 66 21 22 25 32 24 73 20 3d sprintf!"%2$s =
0240: 3d 20 25 31 24 73 22 28 22 31 2b 32 22 2c 20 35 = %1$s"("1+2", 5
0250: 2c 20 38 29 2c 20 22 35 20 3d 3d 20 31 2b 32 22 , 8), "5 == 1+2"
0260: 20 29 3b 0d 0a 09 61 73 73 65 72 74 5f 74 68 72 );...assert_thr
0270: 6f 77 21 45 72 72 6f 72 28 20 73 70 72 69 6e 74 ow!Error( sprint
0280: 66 21 22 25 73 25 73 22 28 31 29 20 29 3b 0d 0a f!"%s%s"(1) );..
0290: 7d 0a 0a 2f 2f 2f 20 43 72 65 61 74 65 20 61 6e }../// Create an
02a0: 20 65 78 63 65 70 74 69 6f 6e 20 77 69 74 68 20 exception with
02b0: 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79 20 63 6f automatically co
02c0: 6d 70 6c 65 74 65 64 20 66 69 6c 65 6e 61 6d 65 mpleted filename
02d0: 20 61 6e 64 20 6c 69 6e 65 6e 6f 20 69 6e 66 6f and lineno info
02e0: 72 6d 61 74 69 6f 6e 0a 0a 45 78 63 65 70 74 69 rmation..Excepti
02f0: 6f 6e 54 79 70 65 20 67 65 6e 65 78 28 45 78 63 onType genex(Exc
0300: 65 70 74 69 6f 6e 54 79 70 65 2c 20 73 74 72 69 eptionType, stri
0310: 6e 67 20 66 6e 3d 5f 5f 46 49 4c 45 5f 5f 2c 20 ng fn=__FILE__,
0320: 69 6e 74 20 6c 6e 3d 5f 5f 4c 49 4e 45 5f 5f 2c int ln=__LINE__,
0330: 20 54 2e 2e 2e 29 28 54 20 70 61 72 61 6d 73 29 T...)(T params)
0340: 0a 7b 0a 09 73 74 61 74 69 63 20 69 66 28 20 54 .{..static if( T
0350: 2e 6c 65 6e 67 74 68 20 3e 20 30 20 26 26 20 69 .length > 0 && i
0360: 73 28 54 5b 24 2d 31 5d 20 3a 20 54 68 72 6f 77 s(T[$-1] : Throw
0370: 61 62 6c 65 29 20 29 0a 09 09 72 65 74 75 72 6e able) )...return
0380: 20 6e 65 77 20 45 78 63 65 70 74 69 6f 6e 54 79 new ExceptionTy
0390: 70 65 28 70 61 72 61 6d 73 5b 30 2e 2e 24 2d 31 pe(params[0..$-1
03a0: 5d 2c 20 66 6e 2c 20 6c 6e 2c 20 70 61 72 61 6d ], fn, ln, param
03b0: 73 5b 24 2d 31 5d 29 3b 0a 09 65 6c 73 65 0a 09 s[$-1]);..else..
03c0: 09 72 65 74 75 72 6e 20 6e 65 77 20 45 78 63 65 .return new Exce
03d0: 70 74 69 6f 6e 54 79 70 65 28 70 61 72 61 6d 73 ptionType(params
03e0: 2c 20 66 6e 2c 20 6c 6e 29 3b 0a 7d 0a 0a 75 6e , fn, ln);.}..un
03f0: 69 74 74 65 73 74 0a 7b 0a 09 61 73 73 65 72 74 ittest.{..assert
0400: 5f 6e 65 28 20 67 65 6e 65 78 21 45 78 63 65 70 _ne( genex!Excep
0410: 74 69 6f 6e 28 22 6d 73 67 22 29 2e 66 69 6c 65 tion("msg").file
0420: 2c 20 22 22 20 29 3b 0a 09 61 73 73 65 72 74 5f , "" );..assert_
0430: 6e 65 28 20 67 65 6e 65 78 21 45 78 63 65 70 74 ne( genex!Except
0440: 69 6f 6e 28 22 6d 73 67 22 29 2e 6c 69 6e 65 2c ion("msg").line,
0450: 20 30 20 29 3b 0a 09 61 73 73 65 72 74 5f 6e 65 0 );..assert_ne
0460: 28 20 67 65 6e 65 78 21 45 78 63 65 70 74 69 6f ( genex!Exceptio
0470: 6e 28 22 6d 73 67 22 2c 6e 65 77 20 45 78 63 65 n("msg",new Exce
0480: 70 74 69 6f 6e 28 22 62 61 72 22 29 29 2e 6e 65 ption("bar")).ne
0490: 78 74 2c 20 45 78 63 65 70 74 69 6f 6e 2e 69 6e xt, Exception.in
04a0: 69 74 20 29 3b 0a 7d 0a 0a 2f 2f 2f 20 4d 69 78 it );.}../// Mix
04b0: 69 6e 67 2d 69 6e 20 74 68 65 20 62 65 61 6e 20 ing-in the bean
04c0: 63 6f 6e 73 74 72 75 63 74 6f 72 20 66 6f 72 20 constructor for
04d0: 61 20 63 6c 61 73 73 0a 0a 2f 2a 6d 69 78 69 6e a class../*mixin
04e0: 2a 2f 0a 74 65 6d 70 6c 61 74 65 20 53 69 6d 70 */.template Simp
04f0: 6c 65 43 6f 6e 73 74 72 75 63 74 6f 72 28 29 0a leConstructor().
0500: 7b 0a 09 2f 2f 2f 20 6d 65 6d 62 65 72 2d 62 79 {../// member-by
0510: 2d 6d 65 6d 62 65 72 20 63 6f 6e 73 74 72 75 63 -member construc
0520: 74 6f 72 0d 0a 09 73 74 61 74 69 63 20 69 66 28 tor...static if(
0530: 20 69 73 28 74 79 70 65 6f 66 28 73 75 70 65 72 is(typeof(super
0540: 29 20 3d 3d 20 4f 62 6a 65 63 74 29 20 7c 7c 20 ) == Object) ||
0550: 73 75 70 65 72 2e 74 75 70 6c 65 6f 66 2e 6c 65 super.tupleof.le
0560: 6e 67 74 68 3d 3d 30 20 29 0a 09 09 74 68 69 73 ngth==0 )...this
0570: 28 20 74 79 70 65 6f 66 28 74 68 69 73 2e 74 75 ( typeof(this.tu
0580: 70 6c 65 6f 66 29 20 70 61 72 61 6d 73 20 29 0a pleof) params ).
0590: 09 09 7b 0a 09 09 09 73 74 61 74 69 63 20 69 66 ..{....static if
05a0: 28 74 68 69 73 2e 74 75 70 6c 65 6f 66 2e 6c 65 (this.tupleof.le
05b0: 6e 67 74 68 3e 30 29 0a 09 09 09 09 74 68 69 73 ngth>0).....this
05c0: 2e 74 75 70 6c 65 6f 66 20 3d 20 70 61 72 61 6d .tupleof = param
05d0: 73 3b 0a 09 09 7d 0a 09 65 6c 73 65 0a 09 09 74 s;...}..else...t
05e0: 68 69 73 28 20 74 79 70 65 6f 66 28 73 75 70 65 his( typeof(supe
05f0: 72 2e 74 75 70 6c 65 6f 66 29 20 70 73 2c 20 74 r.tupleof) ps, t
0600: 79 70 65 6f 66 28 74 68 69 73 2e 74 75 70 6c 65 ypeof(this.tuple
0610: 6f 66 29 20 70 61 72 61 6d 73 20 29 0a 09 09 7b of) params )...{
0620: 0a 09 09 09 2f 2f 20 69 6e 63 6c 75 64 69 6e 67 ....// including
0630: 20 28 6f 6e 6c 79 29 20 74 68 65 20 64 69 72 65 (only) the dire
0640: 63 74 20 73 75 70 65 72 20 63 6c 61 73 73 20 6d ct super class m
0650: 65 6d 62 65 72 73 0a 09 09 09 2f 2f 20 6d 61 79 embers....// may
0660: 20 6e 6f 74 20 61 6c 77 61 79 73 20 62 65 20 61 not always be a
0670: 20 64 65 73 69 72 61 62 6c 65 20 63 68 6f 69 63 desirable choic
0680: 65 2c 20 62 75 74 20 73 68 6f 75 6c 64 20 77 6f e, but should wo
0690: 72 6b 20 66 6f 72 20 6d 61 6e 79 20 63 61 73 65 rk for many case
06a0: 73 0a 09 09 09 73 75 70 65 72 28 70 73 29 3b 0a s....super(ps);.
06b0: 09 09 09 73 74 61 74 69 63 20 69 66 28 74 68 69 ...static if(thi
06c0: 73 2e 74 75 70 6c 65 6f 66 2e 6c 65 6e 67 74 68 s.tupleof.length
06d0: 3e 30 29 0a 09 09 09 09 74 68 69 73 2e 74 75 70 >0).....this.tup
06e0: 6c 65 6f 66 20 3d 20 70 61 72 61 6d 73 3b 0a 09 leof = params;..
06f0: 09 7d 0a 7d 0a 0a 75 6e 69 74 74 65 73 74 0a 7b .}.}..unittest.{
0700: 0a 09 63 6c 61 73 73 20 54 65 6d 70 0a 09 7b 0a ..class Temp..{.
0710: 09 09 69 6e 74 20 78 3b 0a 09 09 73 74 72 69 6e ..int x;...strin
0720: 67 20 79 3b 0a 09 09 6d 69 78 69 6e 20 53 69 6d g y;...mixin Sim
0730: 70 6c 65 43 6f 6e 73 74 72 75 63 74 6f 72 3b 0a pleConstructor;.
0740: 09 7d 0a 09 61 73 73 65 72 74 5f 65 71 28 20 28 .}..assert_eq( (
0750: 6e 65 77 20 54 65 6d 70 28 31 2c 22 66 6f 6f 22 new Temp(1,"foo"
0760: 29 29 2e 78 2c 20 31 20 29 3b 0a 09 61 73 73 65 )).x, 1 );..asse
0770: 72 74 5f 65 71 28 20 28 6e 65 77 20 54 65 6d 70 rt_eq( (new Temp
0780: 28 31 2c 22 66 6f 6f 22 29 29 2e 79 2c 20 22 66 (1,"foo")).y, "f
0790: 6f 6f 22 20 29 3b 0a 09 61 73 73 65 72 74 28 20 oo" );..assert(
07a0: 21 5f 5f 74 72 61 69 74 73 28 63 6f 6d 70 69 6c !__traits(compil
07b0: 65 73 2c 20 6e 65 77 20 54 65 6d 70 29 20 29 3b es, new Temp) );
07c0: 0a 09 61 73 73 65 72 74 28 20 21 5f 5f 74 72 61 ..assert( !__tra
07d0: 69 74 73 28 63 6f 6d 70 69 6c 65 73 2c 20 6e 65 its(compiles, ne
07e0: 77 20 54 65 6d 70 28 31 29 29 20 29 3b 0a 09 61 w Temp(1)) );..a
07f0: 73 73 65 72 74 28 20 21 5f 5f 74 72 61 69 74 73 ssert( !__traits
0800: 28 63 6f 6d 70 69 6c 65 73 2c 20 6e 65 77 20 54 (compiles, new T
0810: 65 6d 70 28 22 66 6f 6f 22 2c 31 29 29 20 29 3b emp("foo",1)) );
0820: 0a 0a 09 63 6c 61 73 73 20 54 6f 6d 70 20 3a 20 ...class Tomp :
0830: 54 65 6d 70 0a 09 7b 0a 09 09 72 65 61 6c 20 7a Temp..{...real z
0840: 3b 0a 09 09 6d 69 78 69 6e 20 53 69 6d 70 6c 65 ;...mixin Simple
0850: 43 6f 6e 73 74 72 75 63 74 6f 72 3b 0a 09 7d 0a Constructor;..}.
0860: 09 61 73 73 65 72 74 5f 65 71 28 20 28 6e 65 77 .assert_eq( (new
0870: 20 54 6f 6d 70 28 31 2c 22 66 6f 6f 22 2c 32 2e Tomp(1,"foo",2.
0880: 35 29 29 2e 78 2c 20 31 20 29 3b 0a 09 61 73 73 5)).x, 1 );..ass
0890: 65 72 74 5f 65 71 28 20 28 6e 65 77 20 54 6f 6d ert_eq( (new Tom
08a0: 70 28 31 2c 22 66 6f 6f 22 2c 32 2e 35 29 29 2e p(1,"foo",2.5)).
08b0: 79 2c 20 22 66 6f 6f 22 20 29 3b 0a 09 61 73 73 y, "foo" );..ass
08c0: 65 72 74 5f 65 71 28 20 28 6e 65 77 20 54 6f 6d ert_eq( (new Tom
08d0: 70 28 31 2c 22 66 6f 6f 22 2c 32 2e 35 29 29 2e p(1,"foo",2.5)).
08e0: 7a 2c 20 32 2e 35 20 29 3b 0a 09 61 73 73 65 72 z, 2.5 );..asser
08f0: 74 28 20 21 5f 5f 74 72 61 69 74 73 28 63 6f 6d t( !__traits(com
0900: 70 69 6c 65 73 2c 20 6e 65 77 20 54 6f 6d 70 28 piles, new Tomp(
0910: 33 2e 31 34 29 29 20 29 3b 0a 0a 09 2f 2f 20 73 3.14)) );...// s
0920: 68 69 79 6f 2d 20 64 65 73 75 2e 20 44 6f 6e 27 hiyo- desu. Don'
0930: 74 20 75 73 65 20 69 6e 20 74 68 69 73 20 77 61 t use in this wa
0940: 79 2e 0a 09 2f 2f 20 20 20 54 61 6d 70 20 74 72 y...// Tamp tr
0950: 69 65 73 20 74 6f 20 63 61 6c 6c 20 6e 65 77 20 ies to call new
0960: 54 6f 6d 70 28 72 65 61 6c 29 20 28 62 65 63 61 Tomp(real) (beca
0970: 75 73 65 20 69 74 20 6f 6e 6c 79 20 73 65 65 73 use it only sees
0980: 20 54 6f 6d 70 27 73 20 6d 65 6d 62 65 72 73 29 Tomp's members)
0990: 2c 0a 09 2f 2f 20 20 20 62 75 74 20 69 74 20 66 ,..// but it f
09a0: 61 69 6c 73 20 62 65 63 61 75 73 65 20 54 6f 6d ails because Tom
09b0: 70 20 74 61 6b 65 73 20 28 69 6e 74 2c 73 74 72 p takes (int,str
09c0: 69 6e 67 2c 72 65 61 6c 29 2e 0a 09 61 73 73 65 ing,real)...asse
09d0: 72 74 28 20 21 5f 5f 74 72 61 69 74 73 28 63 6f rt( !__traits(co
09e0: 6d 70 69 6c 65 73 2c 20 7b 0a 09 09 63 6c 61 73 mpiles, {...clas
09f0: 73 20 54 61 6d 70 20 3a 20 54 6f 6d 70 20 7b 20 s Tamp : Tomp {
0a00: 6d 69 78 69 6e 20 53 69 6d 70 6c 65 43 6f 6e 73 mixin SimpleCons
0a10: 74 72 75 63 74 6f 72 3b 20 7d 0a 09 7d 29 20 29 tructor; }..}) )
0a20: 3b 0a 7d 0a 0a 2f 2f 2f 20 4d 69 78 69 6e 67 2d ;.}../// Mixing-
0a30: 69 6e 20 74 68 65 20 4d 4f 53 54 2d 44 45 52 49 in the MOST-DERI
0a40: 56 45 44 2d 6d 65 6d 62 65 72 2d 77 69 73 65 20 VED-member-wise
0a50: 63 6f 6d 70 61 72 61 74 6f 72 20 66 6f 72 20 61 comparator for a
0a60: 20 63 6c 61 73 73 0a 0a 2f 2a 6d 69 78 69 6e 2a class../*mixin*
0a70: 2f 0a 74 65 6d 70 6c 61 74 65 20 53 69 6d 70 6c /.template Simpl
0a80: 65 43 6f 6d 70 61 72 65 28 29 0a 7b 0a 09 6f 76 eCompare().{..ov
0a90: 65 72 72 69 64 65 20 62 6f 6f 6c 20 6f 70 45 71 erride bool opEq
0aa0: 75 61 6c 73 28 4f 62 6a 65 63 74 20 72 68 73 5f uals(Object rhs_
0ab0: 29 20 63 6f 6e 73 74 20 2f 2f 2f 20 6d 65 6d 62 ) const /// memb
0ac0: 65 72 2d 62 79 2d 6d 65 6d 62 65 72 20 65 71 75 er-by-member equ
0ad0: 61 6c 69 74 79 0a 09 7b 0a 09 09 69 66 28 20 61 ality..{...if( a
0ae0: 75 74 6f 20 72 68 73 20 3d 20 63 61 73 74 28 74 uto rhs = cast(t
0af0: 79 70 65 6f 66 28 74 68 69 73 29 29 72 68 73 5f ypeof(this))rhs_
0b00: 20 29 0a 09 09 7b 0a 09 09 09 66 6f 72 65 61 63 )...{....foreac
0b10: 68 28 69 2c 5f 3b 20 74 68 69 73 2e 74 75 70 6c h(i,_; this.tupl
0b20: 65 6f 66 29 0a 09 09 09 09 69 66 28 20 74 68 69 eof).....if( thi
0b30: 73 2e 74 75 70 6c 65 6f 66 5b 69 5d 20 21 3d 20 s.tupleof[i] !=
0b40: 72 68 73 2e 74 75 70 6c 65 6f 66 5b 69 5d 20 29 rhs.tupleof[i] )
0b50: 0a 09 09 09 09 09 72 65 74 75 72 6e 20 66 61 6c ......return fal
0b60: 73 65 3b 0a 09 09 09 72 65 74 75 72 6e 20 74 72 se;....return tr
0b70: 75 65 3b 0a 09 09 7d 0a 09 09 61 73 73 65 72 74 ue;...}...assert
0b80: 28 66 61 6c 73 65 2c 20 73 70 72 69 6e 74 66 21 (false, sprintf!
0b90: 22 43 61 6e 6e 6f 74 20 63 6f 6d 70 61 72 65 20 "Cannot compare
0ba0: 25 73 20 77 69 74 68 20 25 73 22 28 74 79 70 65 %s with %s"(type
0bb0: 69 64 28 74 68 69 73 29 2c 20 74 79 70 65 69 64 id(this), typeid
0bc0: 28 72 68 73 5f 29 29 29 3b 0a 09 7d 0a 0a 09 6f (rhs_)));..}...o
0bd0: 76 65 72 72 69 64 65 20 68 61 73 68 5f 74 20 74 verride hash_t t
0be0: 6f 48 61 73 68 28 29 20 63 6f 6e 73 74 20 2f 2f oHash() const //
0bf0: 2f 20 6d 65 6d 62 65 72 2d 62 79 2d 6d 65 6d 62 / member-by-memb
0c00: 65 72 20 68 61 73 68 0a 09 7b 0a 09 09 68 61 73 er hash..{...has
0c10: 68 5f 74 20 68 20 3d 20 30 3b 0a 09 09 66 6f 72 h_t h = 0;...for
0c20: 65 61 63 68 28 6d 65 6d 3b 20 74 68 69 73 2e 74 each(mem; this.t
0c30: 75 70 6c 65 6f 66 29 0a 09 09 09 68 20 2b 3d 20 upleof)....h +=
0c40: 74 79 70 65 69 64 28 6d 65 6d 29 2e 67 65 74 48 typeid(mem).getH
0c50: 61 73 68 28 26 6d 65 6d 29 3b 0a 09 09 72 65 74 ash(&mem);...ret
0c60: 75 72 6e 20 68 3b 0a 09 7d 0a 0a 09 6f 76 65 72 urn h;..}...over
0c70: 72 69 64 65 20 69 6e 74 20 6f 70 43 6d 70 28 4f ride int opCmp(O
0c80: 62 6a 65 63 74 20 72 68 73 5f 29 20 63 6f 6e 73 bject rhs_) cons
0c90: 74 20 2f 2f 2f 20 6d 65 6d 62 65 72 2d 62 79 2d t /// member-by-
0ca0: 6d 65 6d 62 65 72 20 63 6f 6d 70 61 72 65 0a 09 member compare..
0cb0: 7b 0a 09 09 69 66 28 20 61 75 74 6f 20 72 68 73 {...if( auto rhs
0cc0: 20 3d 20 63 61 73 74 28 74 79 70 65 6f 66 28 74 = cast(typeof(t
0cd0: 68 69 73 29 29 72 68 73 5f 20 29 0a 09 09 7b 0a his))rhs_ )...{.
0ce0: 09 09 09 66 6f 72 65 61 63 68 28 69 2c 5f 3b 20 ...foreach(i,_;
0cf0: 74 68 69 73 2e 74 75 70 6c 65 6f 66 29 0a 09 09 this.tupleof)...
0d00: 09 09 69 66 28 61 75 74 6f 20 63 20 3d 20 74 79 ..if(auto c = ty
0d10: 70 65 69 64 28 5f 29 2e 63 6f 6d 70 61 72 65 28 peid(_).compare(
0d20: 26 74 68 69 73 2e 74 75 70 6c 65 6f 66 5b 69 5d &this.tupleof[i]
0d30: 2c 26 72 68 73 2e 74 75 70 6c 65 6f 66 5b 69 5d ,&rhs.tupleof[i]
0d40: 29 29 0a 09 09 09 09 09 72 65 74 75 72 6e 20 63 ))......return c
0d50: 3b 0a 09 09 09 72 65 74 75 72 6e 20 30 3b 0a 09 ;....return 0;..
0d60: 09 7d 0a 09 09 61 73 73 65 72 74 28 66 61 6c 73 .}...assert(fals
0d70: 65 2c 20 73 70 72 69 6e 74 66 21 22 43 61 6e 6e e, sprintf!"Cann
0d80: 6f 74 20 63 6f 6d 70 61 72 65 20 25 73 20 77 69 ot compare %s wi
0d90: 74 68 20 25 73 22 28 74 79 70 65 69 64 28 74 68 th %s"(typeid(th
0da0: 69 73 29 2c 20 74 79 70 65 69 64 28 72 68 73 5f is), typeid(rhs_
0db0: 29 29 29 3b 0a 09 7d 0a 7d 0a 0a 75 6e 69 74 74 )));..}.}..unitt
0dc0: 65 73 74 0a 7b 0a 09 63 6c 61 73 73 20 54 65 6d est.{..class Tem
0dd0: 70 0a 09 7b 0a 09 09 69 6e 74 20 78 3b 0a 09 09 p..{...int x;...
0de0: 73 74 72 69 6e 67 20 79 3b 0a 09 09 6d 69 78 69 string y;...mixi
0df0: 6e 20 53 69 6d 70 6c 65 43 6f 6e 73 74 72 75 63 n SimpleConstruc
0e00: 74 6f 72 3b 0a 09 09 6d 69 78 69 6e 20 53 69 6d tor;...mixin Sim
0e10: 70 6c 65 43 6f 6d 70 61 72 65 3b 0a 09 7d 0a 09 pleCompare;..}..
0e20: 61 73 73 65 72 74 5f 65 71 28 20 6e 65 77 20 54 assert_eq( new T
0e30: 65 6d 70 28 31 2c 22 66 6f 6f 22 29 2c 20 6e 65 emp(1,"foo"), ne
0e40: 77 20 54 65 6d 70 28 31 2c 22 66 6f 6f 22 29 20 w Temp(1,"foo")
0e50: 29 3b 0a 09 61 73 73 65 72 74 5f 65 71 28 20 28 );..assert_eq( (
0e60: 6e 65 77 20 54 65 6d 70 28 31 2c 22 66 6f 6f 22 new Temp(1,"foo"
0e70: 29 29 2e 74 6f 48 61 73 68 2c 20 28 6e 65 77 20 )).toHash, (new
0e80: 54 65 6d 70 28 31 2c 22 66 6f 6f 22 29 29 2e 74 Temp(1,"foo")).t
0e90: 6f 48 61 73 68 20 29 3b 0a 09 61 73 73 65 72 74 oHash );..assert
0ea0: 5f 6e 65 28 20 6e 65 77 20 54 65 6d 70 28 31 2c _ne( new Temp(1,
0eb0: 22 66 6f 6f 22 29 2c 20 6e 65 77 20 54 65 6d 70 "foo"), new Temp
0ec0: 28 32 2c 22 66 6f 6f 22 29 20 29 3b 0a 09 61 73 (2,"foo") );..as
0ed0: 73 65 72 74 5f 6e 65 28 20 6e 65 77 20 54 65 6d sert_ne( new Tem
0ee0: 70 28 31 2c 22 66 6f 6f 22 29 2c 20 6e 65 77 20 p(1,"foo"), new
0ef0: 54 65 6d 70 28 31 2c 22 62 61 72 22 29 20 29 3b Temp(1,"bar") );
0f00: 0a 09 61 73 73 65 72 74 5f 67 74 28 20 6e 65 77 ..assert_gt( new
0f10: 20 54 65 6d 70 28 31 2c 22 66 6f 6f 22 29 2c 20 Temp(1,"foo"),
0f20: 6e 65 77 20 54 65 6d 70 28 31 2c 22 62 61 72 22 new Temp(1,"bar"
0f30: 29 20 29 3b 0a 09 61 73 73 65 72 74 5f 6c 74 28 ) );..assert_lt(
0f40: 20 6e 65 77 20 54 65 6d 70 28 31 2c 22 66 6f 6f new Temp(1,"foo
0f50: 22 29 2c 20 6e 65 77 20 54 65 6d 70 28 32 2c 22 "), new Temp(2,"
0f60: 62 61 72 22 29 20 29 3b 0a 09 61 73 73 65 72 74 bar") );..assert
0f70: 5f 67 65 28 20 6e 65 77 20 54 65 6d 70 28 31 2c _ge( new Temp(1,
0f80: 22 66 6f 6f 22 29 2c 20 6e 65 77 20 54 65 6d 70 "foo"), new Temp
0f90: 28 31 2c 22 66 6f 6f 22 29 20 29 3b 0a 0a 09 63 (1,"foo") );...c
0fa0: 6c 61 73 73 20 54 65 6d 70 44 75 6d 6d 79 0a 09 lass TempDummy..
0fb0: 7b 0a 09 09 69 6e 74 20 78 3b 0a 09 09 73 74 72 {...int x;...str
0fc0: 69 6e 67 20 79 3b 0a 09 09 6d 69 78 69 6e 20 53 ing y;...mixin S
0fd0: 69 6d 70 6c 65 43 6f 6e 73 74 72 75 63 74 6f 72 impleConstructor
0fe0: 3b 0a 09 09 6d 69 78 69 6e 20 53 69 6d 70 6c 65 ;...mixin Simple
0ff0: 43 6f 6d 70 61 72 65 3b 0a 09 7d 0a 09 61 73 73 Compare;..}..ass
1000: 65 72 74 5f 74 68 72 6f 77 21 41 73 73 65 72 74 ert_throw!Assert
1010: 45 72 72 6f 72 28 20 6e 65 77 20 54 65 6d 70 28 Error( new Temp(
1020: 31 2c 22 66 6f 6f 22 29 20 3d 3d 20 6e 65 77 20 1,"foo") == new
1030: 54 65 6d 70 44 75 6d 6d 79 28 31 2c 22 66 6f 6f TempDummy(1,"foo
1040: 22 29 20 29 3b 0a 09 61 73 73 65 72 74 5f 74 68 ") );..assert_th
1050: 72 6f 77 21 41 73 73 65 72 74 45 72 72 6f 72 28 row!AssertError(
1060: 20 6e 65 77 20 54 65 6d 70 28 31 2c 22 66 6f 6f new Temp(1,"foo
1070: 22 29 20 3c 3d 20 6e 65 77 20 54 65 6d 70 44 75 ") <= new TempDu
1080: 6d 6d 79 28 31 2c 22 66 6f 6f 22 29 20 29 3b 0a mmy(1,"foo") );.
1090: 7d 0a 0a 2f 2f 2f 20 4d 69 78 69 6e 67 2d 69 6e }../// Mixing-in
10a0: 20 61 20 73 69 6d 70 6c 65 20 74 6f 53 74 72 69 a simple toStri
10b0: 6e 67 20 6d 65 74 68 6f 64 0a 0a 2f 2a 6d 69 78 ng method../*mix
10c0: 69 6e 2a 2f 0a 74 65 6d 70 6c 61 74 65 20 53 69 in*/.template Si
10d0: 6d 70 6c 65 54 6f 53 74 72 69 6e 67 28 29 0a 7b mpleToString().{
10e0: 0d 0a 09 2f 2f 2f 20 6d 65 6d 62 65 72 2d 62 79 .../// member-by
10f0: 2d 6d 65 6d 62 65 72 20 74 6f 53 74 72 69 6e 67 -member toString
1100: 0a 09 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e ..override strin
1110: 67 20 74 6f 53 74 72 69 6e 67 28 29 0a 09 7b 0a g toString()..{.
1120: 09 09 73 74 72 69 6e 67 20 73 74 72 20 3d 20 73 ..string str = s
1130: 70 72 69 6e 74 66 21 22 25 73 28 22 28 74 79 70 printf!"%s("(typ
1140: 65 6f 66 28 74 68 69 73 29 2e 73 74 72 69 6e 67 eof(this).string
1150: 6f 66 29 3b 0a 09 09 66 6f 72 65 61 63 68 28 69 of);...foreach(i
1160: 2c 6d 65 6d 3b 20 74 68 69 73 2e 74 75 70 6c 65 ,mem; this.tuple
1170: 6f 66 29 0a 09 09 7b 0a 09 09 09 69 66 28 69 29 of)...{....if(i)
1180: 20 73 74 72 20 7e 3d 20 22 2c 22 3b 0a 09 09 09 str ~= ",";....
1190: 73 74 61 74 69 63 20 69 66 28 20 69 73 28 74 79 static if( is(ty
11a0: 70 65 6f 66 28 6d 65 6d 29 20 3d 3d 20 73 74 64 peof(mem) == std
11b0: 2e 62 69 67 69 6e 74 2e 42 69 67 49 6e 74 29 20 .bigint.BigInt)
11c0: 29 0a 09 09 09 09 73 74 72 20 7e 3d 20 73 74 64 ).....str ~= std
11d0: 2e 62 69 67 69 6e 74 2e 74 6f 44 65 63 69 6d 61 .bigint.toDecima
11e0: 6c 53 74 72 69 6e 67 28 6d 65 6d 29 3b 0a 09 09 lString(mem);...
11f0: 09 65 6c 73 65 0a 09 09 09 09 73 74 72 20 7e 3d .else.....str ~=
1200: 20 73 70 72 69 6e 74 66 21 22 25 73 22 28 6d 65 sprintf!"%s"(me
1210: 6d 29 3b 0a 09 09 7d 0a 09 09 72 65 74 75 72 6e m);...}...return
1220: 20 73 74 72 20 7e 20 22 29 22 3b 0a 09 7d 0a 7d str ~ ")";..}.}
1230: 0a 0a 76 65 72 73 69 6f 6e 28 75 6e 69 74 74 65 ..version(unitte
1240: 73 74 29 20 69 6d 70 6f 72 74 20 73 74 64 2e 62 st) import std.b
1250: 69 67 69 6e 74 3b 0a 75 6e 69 74 74 65 73 74 0a igint;.unittest.
1260: 7b 0a 09 63 6c 61 73 73 20 54 65 6d 70 0a 09 7b {..class Temp..{
1270: 0a 09 09 69 6e 74 20 78 3b 0a 09 09 73 74 72 69 ...int x;...stri
1280: 6e 67 20 79 3b 0a 09 09 42 69 67 49 6e 74 20 7a ng y;...BigInt z
1290: 3b 0a 09 09 6d 69 78 69 6e 20 53 69 6d 70 6c 65 ;...mixin Simple
12a0: 43 6f 6e 73 74 72 75 63 74 6f 72 3b 0a 09 09 6d Constructor;...m
12b0: 69 78 69 6e 20 53 69 6d 70 6c 65 54 6f 53 74 72 ixin SimpleToStr
12c0: 69 6e 67 3b 0a 09 7d 0a 09 61 73 73 65 72 74 5f ing;..}..assert_
12d0: 65 71 28 20 28 6e 65 77 20 54 65 6d 70 28 31 2c eq( (new Temp(1,
12e0: 22 66 6f 6f 22 2c 42 69 67 49 6e 74 28 34 32 29 "foo",BigInt(42)
12f0: 29 29 2e 74 6f 53 74 72 69 6e 67 28 29 2c 20 22 )).toString(), "
1300: 54 65 6d 70 28 31 2c 66 6f 6f 2c 34 32 29 22 20 Temp(1,foo,42)"
1310: 29 3b 0a 7d 0a 0a 2f 2f 2f 20 45 76 65 72 79 74 );.}../// Everyt
1320: 68 69 6e 67 20 69 73 20 69 6e 0a 0a 2f 2a 6d 69 hing is in../*mi
1330: 78 69 6e 2a 2f 0a 74 65 6d 70 6c 61 74 65 20 53 xin*/.template S
1340: 69 6d 70 6c 65 43 6c 61 73 73 28 29 0a 7b 0a 09 impleClass().{..
1350: 6d 69 78 69 6e 20 53 69 6d 70 6c 65 43 6f 6e 73 mixin SimpleCons
1360: 74 72 75 63 74 6f 72 3b 0a 09 6d 69 78 69 6e 20 tructor;..mixin
1370: 53 69 6d 70 6c 65 43 6f 6d 70 61 72 65 3b 0a 09 SimpleCompare;..
1380: 6d 69 78 69 6e 20 53 69 6d 70 6c 65 54 6f 53 74 mixin SimpleToSt
1390: 72 69 6e 67 3b 0a 7d 0a ring;.}.