mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-04-17 17:29:02 +02:00
[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.
This commit is contained in:
@@ -127,7 +127,9 @@ void VersionCondition::checkPredefined(Loc loc, char *ident)
|
||||
{
|
||||
static char* reserved[] =
|
||||
{
|
||||
"DigitalMars", "X86", "X86_64",
|
||||
"DigitalMars", "LLVM", "LLVMDC",
|
||||
"LLVM64", "LLVM_X86_FP80",
|
||||
"X86", "X86_64", "PPC", "PPC64",
|
||||
"Windows", "Win32", "Win64",
|
||||
"linux",
|
||||
"LittleEndian", "BigEndian",
|
||||
|
||||
@@ -123,7 +123,7 @@ struct Param
|
||||
char *resfile;
|
||||
char *exefile;
|
||||
|
||||
// LLVM stuff
|
||||
// LLVMDC stuff
|
||||
char *llvmArch;
|
||||
char forceBE;
|
||||
char *tt_arch;
|
||||
@@ -291,6 +291,7 @@ enum MATCH
|
||||
MATCHexact // exact match
|
||||
};
|
||||
|
||||
// LLVMDC
|
||||
enum ARCH
|
||||
{
|
||||
ARCHx86,
|
||||
|
||||
@@ -1180,12 +1180,17 @@ Statement *ForeachStatement::semantic(Scope *sc)
|
||||
if (arg->storageClass & (STCout | STCref | STClazy))
|
||||
error("no storage class for key %s", arg->ident->toChars());
|
||||
TY keyty = arg->type->ty;
|
||||
if ((keyty != Tint32 && keyty != Tuns32) &&
|
||||
(global.params.is64bit && keyty != Tint64 && keyty != Tuns64)
|
||||
)
|
||||
{
|
||||
error("foreach: key type must be %s, not %s", global.params.is64bit ? "int, uint, long or ulong" : "int or uint",arg->type->toChars());
|
||||
}
|
||||
if (global.params.is64bit)
|
||||
{
|
||||
if (keyty != Tint32 && keyty != Tuns32 && keyty != Tint64 && keyty != Tuns64)
|
||||
{
|
||||
error("foreach: key type must be int, uint, long or ulong, not %s", key->type->toChars());
|
||||
}
|
||||
}
|
||||
else if (keyty != Tint32 && keyty != Tuns32)
|
||||
{
|
||||
error("foreach: key type must be int or uint, not %s", key->type->toChars());
|
||||
}
|
||||
Initializer *ie = new ExpInitializer(0, new IntegerExp(k));
|
||||
VarDeclaration *var = new VarDeclaration(loc, arg->type, arg->ident, ie);
|
||||
var->storage_class |= STCconst;
|
||||
@@ -1320,14 +1325,20 @@ Statement *ForeachStatement::semantic(Scope *sc)
|
||||
error("foreach: %s is not an array of %s", tab->toChars(), value->type->toChars());
|
||||
}
|
||||
|
||||
if (key &&
|
||||
((key->type->ty != Tint32 && key->type->ty != Tuns32) &&
|
||||
(global.params.is64bit && key->type->ty != Tint64 && key->type->ty != Tuns64)
|
||||
)
|
||||
)
|
||||
{
|
||||
error("foreach: key type must be %s, not %s", global.params.is64bit ? "int, uint, long or ulong" : "int or uint", key->type->toChars());
|
||||
}
|
||||
if (key)
|
||||
{
|
||||
if (global.params.is64bit)
|
||||
{
|
||||
if (key->type->ty != Tint32 && key->type->ty != Tuns32 && key->type->ty != Tint64 && key->type->ty != Tuns64)
|
||||
{
|
||||
error("foreach: key type must be int, uint, long or ulong, not %s", key->type->toChars());
|
||||
}
|
||||
}
|
||||
else if (key->type->ty != Tint32 && key->type->ty != Tuns32)
|
||||
{
|
||||
error("foreach: key type must be int or uint, not %s", key->type->toChars());
|
||||
}
|
||||
}
|
||||
|
||||
if (key && key->storage_class & (STCout | STCref))
|
||||
error("foreach: key cannot be out or ref");
|
||||
|
||||
Reference in New Issue
Block a user