Hex Artifact Content
Not logged in

Artifact d70e48b147acc2422a34d61271fc72b9d65b1aa4:


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;.}.