Mercurial > projects > ldc
annotate lphobos/typeinfo1/ti_ptr.d @ 1605:1d5721f9ae18
[WIP] Merge DMD r251: bugzilla 111 (appending a dchar to a char[])
This patch needs some work in the code generation, because of the runtime
changes (functions "_d_arrayappendcd" and "_d_arrayappendwd" are added).
This doesn't affect existing code though, it just makes with patch
a little useless, because something like this:
char [] s;
s ~= '\u6211';
That failed to compile with a nice error message previously to this
change, now fails with and ugly error message (a failed assertion).
Apparently there is a regression introduced by this patch too, when
compiling Dil I get this assertion message:
ldc: /home/luca/tesis/ldc/gen/statements.cpp:132: virtual void ReturnStatement::toIR(IRState*): Assertion `p->topfunc()->getReturnType() == llvm::Type::getVoidTy(gIR->context())' failed.
0 ldc 0x08a91628
Thank god we have bisecting capabilities in VCSs now ;)
---
dmd/expression.c | 47 +++++++++++++++++++++++++++++++++++++++++------
1 files changed, 41 insertions(+), 6 deletions(-)
author | Leandro Lucarella <llucax@gmail.com> |
---|---|
date | Wed, 06 Jan 2010 15:18:19 -0300 |
parents | 2c3cd3596187 |
children |
rev | line source |
---|---|
1 | 1 |
2 // pointer | |
3 | |
58
2c3cd3596187
[svn r62] Added support for TypeInfo _Array, _Function, _Pointer, _Delegate, _Enum
lindquist
parents:
52
diff
changeset
|
4 module typeinfo1.ti_ptr; |
1 | 5 |
6 class TypeInfo_P : TypeInfo | |
7 { | |
8 hash_t getHash(void *p) | |
9 { | |
10 return cast(uint)*cast(void* *)p; | |
11 } | |
12 | |
13 int equals(void *p1, void *p2) | |
14 { | |
15 return *cast(void* *)p1 == *cast(void* *)p2; | |
16 } | |
17 | |
18 int compare(void *p1, void *p2) | |
19 { | |
20 return *cast(void* *)p1 - *cast(void* *)p2; | |
21 } | |
22 | |
23 size_t tsize() | |
24 { | |
25 return (void*).sizeof; | |
26 } | |
27 | |
28 void swap(void *p1, void *p2) | |
29 { | |
30 void* t; | |
31 | |
32 t = *cast(void* *)p1; | |
33 *cast(void* *)p1 = *cast(void* *)p2; | |
34 *cast(void* *)p2 = t; | |
35 } | |
36 | |
37 uint flags() | |
38 { | |
39 return 1; | |
40 } | |
41 } | |
42 |