Mercurial > projects > ldc
diff gen/functions.cpp @ 275:665b81613475 trunk
[svn r296] Removed: the 'suite' dir, it never took off!
Fixed: foreach statement, key-type checks were buggy.
Fixed: setting LLVMDC versions on the command line is now an error.
Fixed: array compare runtime had incorrect param attrs on call.
Fixed: index expressions on dynamic array slices w/o storage was broken.
Fixed: scope classes had incorrect finalization in some cases.
Fixed: when outputting !ClassInfoS !OffsetTypeInfoS, static class members were trying to be included, crashing the compiler.
Fixed: calling LLVMDC with -inline but not any -O option caused assertion failure.
Changed: the runtime now uses a single interface to "get" to !TypeInfoS, part of eliminating duplicate !TypeInfo codegen.
author | lindquist |
---|---|
date | Thu, 19 Jun 2008 17:30:32 +0200 |
parents | 88252a1af660 |
children | 7086a84ab3d6 |
line wrap: on
line diff
--- a/gen/functions.cpp Thu Jun 19 13:54:31 2008 +0200 +++ b/gen/functions.cpp Thu Jun 19 17:30:32 2008 +0200 @@ -105,8 +105,6 @@ int nbyval = 0; - llvm::PAListPtr palist; - for (int i=0; i < n; ++i) { Argument* arg = Argument::getNth(f->parameters, i); // ensure scalar @@ -122,11 +120,10 @@ arg->llvmByVal = !refOrOut; } else if (isaArray(at)) { + // static array are passed by reference Logger::println("sarray param"); assert(argT->ty == Tsarray); - //paramvec.push_back(getPtrToType(at->getContainedType(0))); paramvec.push_back(getPtrToType(at)); - //arg->llvmByVal = !refOrOut; // static array are passed by reference } else if (llvm::isa<llvm::OpaqueType>(at)) { Logger::println("opaque param");