# HG changeset patch # User lindquist # Date 1191476102 -7200 # Node ID a6360e68134a034c70ab203d4ccccfa8a1ffe54e # Parent 8d45266bbabeff9de830f2c3ee23e250d0269cc3 [svn r26] * Fixed templates defining a constant value * Fixed problem with slice-slice copy assignment if a side was a temporary slice diff -r 8d45266bbabe -r a6360e68134a gen/arrays.c --- a/gen/arrays.c Thu Oct 04 07:01:15 2007 +0200 +++ b/gen/arrays.c Thu Oct 04 07:35:02 2007 +0200 @@ -308,7 +308,21 @@ assert(e->mem); const llvm::Type* t = e->mem->getType()->getContainedType(0); llvm::Value* ret = 0; - if (llvm::isa(t)) { + if (e->arg != 0) { + // this means it's a real slice + ret = e->mem; + + size_t elembsz = gTargetData->getTypeSize(ret->getType()); + llvm::ConstantInt* elemsz = llvm::ConstantInt::get(LLVM_DtoSize_t(), elembsz, false); + + if (llvm::isa(e->arg)) { + sz = llvm::ConstantExpr::getMul(elemsz, llvm::cast(e->arg)); + } + else { + sz = llvm::BinaryOperator::createMul(elemsz,e->arg,"tmp",gIR->scopebb()); + } + } + else if (llvm::isa(t)) { ret = LLVM_DtoGEPi(e->mem, 0, 0, "tmp", gIR->scopebb()); size_t elembsz = gTargetData->getTypeSize(ret->getType()->getContainedType(0)); diff -r 8d45266bbabe -r a6360e68134a gen/toobj.c --- a/gen/toobj.c Thu Oct 04 07:01:15 2007 +0200 +++ b/gen/toobj.c Thu Oct 04 07:35:02 2007 +0200 @@ -497,7 +497,7 @@ } // global variable or magic - if (!parent || parent->isModule()) + if (isDataseg()) { bool _isconst = isConst(); if (!_isconst) diff -r 8d45266bbabe -r a6360e68134a lphobos/std/stdio.d --- a/lphobos/std/stdio.d Thu Oct 04 07:01:15 2007 +0200 +++ b/lphobos/std/stdio.d Thu Oct 04 07:35:02 2007 +0200 @@ -1,13 +1,15 @@ module std.stdio; +import std.traits; + void _writef(T)(T t) { static if(is(T: Object)) _writef(t.toString()); else - static if(is(T==char)) _writef("%c", t); else + static if(is(T==char)) printf("%c", t); else static if(is(T: char[])) printf("%.*s", t.length, t.ptr); else static if(isArray!(T)) { _writef('['); if (t.length) _writef(t[0]); - for (int i=1; i