Mercurial > projects > dil
diff trunk/src/dil/SyntaxTree.d @ 495:b60450804b6e
Attributes are evaluated during the parsing phase now.
Renamed parseDeclarationDefinitionsBlock to parseDeclarationDefinitionsBody.
Renamed parseDeclaration to parseVariableOrFunction.
Removed class Linkage, renamed parseLinkage to parseLinkageType and modified
it so that it returns a value from enum LinkageType.
Fix in parseStorageAttribute(): class invariants are recognized now.
Modified parseAlignAttribute() so that returns an uint - the alignment size.
Removed classes AttributeStatement and ExternStatement. Using Declarations
instead in parseAttributeStatement().
Added LinkageType to module Enums. Added StorageClassDeclaration and renamed
ExternDeclaration to LinkageDeclaration.
author | Aziz K?ksal <aziz.koeksal@gmail.com> |
---|---|
date | Sat, 08 Dec 2007 22:20:34 +0100 |
parents | 9c208925a3d4 |
children | 433d51c18524 |
line wrap: on
line diff
--- a/trunk/src/dil/SyntaxTree.d Fri Dec 07 18:22:35 2007 +0100 +++ b/trunk/src/dil/SyntaxTree.d Sat Dec 08 22:20:34 2007 +0100 @@ -47,7 +47,8 @@ DeleteDeclaration, AttributeDeclaration, ProtectionDeclaration, - ExternDeclaration, + StorageClassDeclaration, + LinkageDeclaration, AlignDeclaration, PragmaDeclaration, MixinDeclaration, @@ -92,8 +93,6 @@ StaticAssertStatement, DebugStatement, VersionStatement, - AttributeStatement, - ExternStatement, // Expressions: EmptyExpression, @@ -215,7 +214,6 @@ TemplateTupleParameter, TemplateParameters, TemplateArguments, - Linkage, EnumMember, } @@ -230,6 +228,12 @@ return null; } +Class CastTo(Class)(Node n) +{ + assert(n !is null && n.kind == mixin("NodeKind." ~ typeof(Class).stringof)); + return cast(Class)cast(void*)n; +} + class Node { NodeCategory category;