Mercurial > projects > ldc
annotate lphobos/typeinfo1/ti_char.d @ 1602:a413ae7329bf
Merge DMD r243: some harmonization with D2 dmd
---
dmd/aggregate.h | 24 ++++-
dmd/attrib.c | 63 ++++++----
dmd/attrib.h | 10 +-
dmd/declaration.h | 5 +-
dmd/func.c | 337 ++++++++++++++++++++++-------------------------------
dmd/mars.c | 2 +-
dmd/mars.h | 7 +
dmd/mtype.h | 13 ++-
dmd/parse.c | 32 ++++-
dmd/parse.h | 14 ++-
dmd/scope.h | 2 +-
11 files changed, 263 insertions(+), 246 deletions(-)
author | Leandro Lucarella <llucax@gmail.com> |
---|---|
date | Wed, 06 Jan 2010 15:18:19 -0300 |
parents | 2c3cd3596187 |
children |
rev | line source |
---|---|
1 | 1 |
58
2c3cd3596187
[svn r62] Added support for TypeInfo _Array, _Function, _Pointer, _Delegate, _Enum
lindquist
parents:
52
diff
changeset
|
2 module typeinfo1.ti_char; |
1 | 3 |
4 class TypeInfo_a : TypeInfo | |
5 { | |
6 char[] toString() { return "char"; } | |
7 | |
8 hash_t getHash(void *p) | |
9 { | |
10 return *cast(char *)p; | |
11 } | |
12 | |
13 int equals(void *p1, void *p2) | |
14 { | |
15 return *cast(char *)p1 == *cast(char *)p2; | |
16 } | |
17 | |
18 int compare(void *p1, void *p2) | |
19 { | |
20 return *cast(char *)p1 - *cast(char *)p2; | |
21 } | |
22 | |
23 size_t tsize() | |
24 { | |
25 return char.sizeof; | |
26 } | |
27 | |
28 void swap(void *p1, void *p2) | |
29 { | |
30 char t; | |
31 | |
32 t = *cast(char *)p1; | |
33 *cast(char *)p1 = *cast(char *)p2; | |
34 *cast(char *)p2 = t; | |
35 } | |
36 | |
37 void[] init() | |
38 { static char c; | |
39 | |
40 return (cast(char *)&c)[0 .. 1]; | |
41 } | |
42 } | |
43 |