Mercurial > projects > dil
view trunk/src/dil/ast/Expressions.d @ 682:7541c64fc423
Renamed FunctionBody, CatchBody and FinallyBody.
FunctionBody -> FuncBodyStatement,
CatchBody -> CatchStatement,
FinallyBody -> FinallyStatement.
author | Aziz K?ksal <aziz.koeksal@gmail.com> |
---|---|
date | Sat, 19 Jan 2008 20:35:45 +0100 |
parents | 6b3e397229c5 |
children | e8c09d13f2a5 |
line wrap: on
line source
/++ Author: Aziz Köksal License: GPL3 +/ module dil.ast.Expressions; public import dil.ast.Expression; import dil.ast.Node; import dil.ast.Types; import dil.ast.Declarations; import dil.ast.Statements; import dil.ast.Parameters; import dil.lexer.Identifier; import dil.semantic.Types; import common; class IllegalExpression : Expression { this() { mixin(set_kind); } } abstract class BinaryExpression : Expression { Expression left, right; Token* tok; this(Expression left, Expression right, Token* tok) { addChildren([left, right]); this.left = left; this.right = right; this.tok = tok; } } class CondExpression : BinaryExpression { Expression condition; this(Expression condition, Expression left, Expression right, Token* tok) { addChild(condition); super(left, right, tok); mixin(set_kind); this.condition = condition; } } class CommaExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class OrOrExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class AndAndExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class OrExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class XorExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class AndExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } abstract class CmpExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); } } class EqualExpression : CmpExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class IdentityExpression : CmpExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class RelExpression : CmpExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class InExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class LShiftExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class RShiftExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class URShiftExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class PlusExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class MinusExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class CatExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class MulExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class DivExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class ModExpression : BinaryExpression { this(Expression left, Expression right, Token* tok) { super(left, right, tok); mixin(set_kind); } } class AssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class LShiftAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class RShiftAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class URShiftAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class OrAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class AndAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class PlusAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class MinusAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class DivAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class MulAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class ModAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class XorAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } class CatAssignExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } /// DotExpression := Expression '.' Expression class DotExpression : BinaryExpression { this(Expression left, Expression right) { super(left, right, null); mixin(set_kind); } } /*++++++++++++++++++++ + Unary Expressions: + ++++++++++++++++++++*/ abstract class UnaryExpression : Expression { Expression e; this(Expression e) { addChild(e); this.e = e; } } class AddressExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class PreIncrExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class PreDecrExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class PostIncrExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class PostDecrExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class DerefExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class SignExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } bool isPos() { assert(begin !is null); return begin.kind == TOK.Plus; } bool isNeg() { assert(begin !is null); return begin.kind == TOK.Minus; } } class NotExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class CompExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class CallExpression : UnaryExpression { Expression[] args; this(Expression e, Expression[] args) { super(e); mixin(set_kind); addOptChildren(args); this.args = args; } } class NewExpression : /*Unary*/Expression { Expression[] newArgs; TypeNode type; Expression[] ctorArgs; this(/*Expression e, */Expression[] newArgs, TypeNode type, Expression[] ctorArgs) { /*super(e);*/ mixin(set_kind); addOptChildren(newArgs); addChild(type); addOptChildren(ctorArgs); this.newArgs = newArgs; this.type = type; this.ctorArgs = ctorArgs; } } class NewAnonClassExpression : /*Unary*/Expression { Expression[] newArgs; BaseClassType[] bases; Expression[] ctorArgs; CompoundDeclaration decls; this(/*Expression e, */Expression[] newArgs, BaseClassType[] bases, Expression[] ctorArgs, CompoundDeclaration decls) { /*super(e);*/ mixin(set_kind); addOptChildren(newArgs); addOptChildren(bases); addOptChildren(ctorArgs); addChild(decls); this.newArgs = newArgs; this.bases = bases; this.ctorArgs = ctorArgs; this.decls = decls; } } class DeleteExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class CastExpression : UnaryExpression { TypeNode type; this(Expression e, TypeNode type) { addChild(type); // Add type before super(). super(e); mixin(set_kind); this.type = type; } } class IndexExpression : UnaryExpression { Expression[] args; this(Expression e, Expression[] args) { super(e); mixin(set_kind); addChildren(args); this.args = args; } } class SliceExpression : UnaryExpression { Expression left, right; this(Expression e, Expression left, Expression right) { super(e); mixin(set_kind); assert(left ? (right !is null) : right is null); if (left) addChildren([left, right]); this.left = left; this.right = right; } } /// Module scope operator: '.' (IdentifierExpression|TemplateInstanceExpression) class ModuleScopeExpression : UnaryExpression { this(Expression e) { super(e); assert(e.kind == NodeKind.IdentifierExpression || e.kind == NodeKind.TemplateInstanceExpression ); mixin(set_kind); } } /*++++++++++++++++++++++ + Primary Expressions: + ++++++++++++++++++++++*/ class IdentifierExpression : Expression { Identifier* identifier; this(Identifier* identifier) { mixin(set_kind); this.identifier = identifier; } } class SpecialTokenExpression : Expression { Token* specialToken; this(Token* specialToken) { mixin(set_kind); this.specialToken = specialToken; } Expression value; /// The expression created in the semantic phase. } class TemplateInstanceExpression : Expression { Identifier* ident; TemplateArguments targs; this(Identifier* ident, TemplateArguments targs) { mixin(set_kind); addOptChild(targs); this.ident = ident; this.targs = targs; } } class ThisExpression : Expression { this() { mixin(set_kind); } } class SuperExpression : Expression { this() { mixin(set_kind); } } class NullExpression : Expression { this() { mixin(set_kind); } this(Type type) { this(); this.type = type; } } class DollarExpression : Expression { this() { mixin(set_kind); } } class BoolExpression : Expression { this() { mixin(set_kind); } bool toBool() { assert(begin !is null); return begin.kind == TOK.True ? true : false; } Expression value; /// IntExpression of type int. } class IntExpression : Expression { ulong number; this(ulong number, Type type) { mixin(set_kind); this.number = number; this.type = type; } this(Token* token) { auto type = Types.Int; // Should be most common case. switch (token.kind) { // case TOK.Int32: // type = Types.Int; break; case TOK.Uint32: type = Types.Uint; break; case TOK.Int64: type = Types.Long; break; case TOK.Uint64: type = Types.Ulong; break; default: assert(token.kind == TOK.Int32); } this(token.ulong_, type); } } class RealExpression : Expression { real number; this(real number, Type type) { mixin(set_kind); this.number = number; this.type = type; } this(Token* token) { auto type = Types.Double; // Most common case? switch (token.kind) { case TOK.Float32: type = Types.Float; break; // case TOK.Float64: // type = Types.Double; break; case TOK.Float80: type = Types.Real; break; case TOK.Imaginary32: type = Types.Ifloat; break; case TOK.Imaginary64: type = Types.Idouble; break; case TOK.Imaginary80: type = Types.Ireal; break; default: assert(token.kind == TOK.Float64); } this(token.real_, type); } } /++ This expression holds a complex number. It is only created in the semantic phase. +/ class ComplexExpression : Expression { creal number; this(creal number, Type type) { mixin(set_kind); this.number = number; this.type = type; } } class CharExpression : Expression { dchar character; this(dchar character) { mixin(set_kind); this.character = character; } } class StringExpression : Expression { ubyte[] str; /// The string data. Type charType; /// The character type of the string. this(ubyte[] str, Type charType) { mixin(set_kind); this.str = str; this.charType = charType; type = new TypeSArray(charType, str.length); } this(char[] str) { this(cast(ubyte[])str, Types.Char); } this(wchar[] str) { this(cast(ubyte[])str, Types.Wchar); } this(dchar[] str) { this(cast(ubyte[])str, Types.Dchar); } char[] getString() { // TODO: convert to char[] if charType !is Types.Char. return cast(char[])str; } } class ArrayLiteralExpression : Expression { Expression[] values; this(Expression[] values) { mixin(set_kind); addOptChildren(values); this.values = values; } } class AArrayLiteralExpression : Expression { Expression[] keys, values; this(Expression[] keys, Expression[] values) { assert(keys.length == values.length); mixin(set_kind); foreach (i, key; keys) addChildren([key, values[i]]); this.keys = keys; this.values = values; } } class AssertExpression : Expression { Expression expr, msg; this(Expression expr, Expression msg) { mixin(set_kind); addChild(expr); addOptChild(msg); this.expr = expr; this.msg = msg; } } class MixinExpression : Expression { Expression expr; this(Expression expr) { mixin(set_kind); addChild(expr); this.expr = expr; } } class ImportExpression : Expression { Expression expr; this(Expression expr) { mixin(set_kind); addChild(expr); this.expr = expr; } } class TypeofExpression : Expression { TypeNode type; this(TypeNode type) { mixin(set_kind); addChild(type); this.type = type; } } class TypeDotIdExpression : Expression { TypeNode type; Identifier* ident; this(TypeNode type, Identifier* ident) { mixin(set_kind); addChild(type); this.type = type; this.ident = ident; } } class TypeidExpression : Expression { TypeNode type; this(TypeNode type) { mixin(set_kind); addChild(type); this.type = type; } } class IsExpression : Expression { TypeNode type; Identifier* ident; Token* opTok, specTok; TypeNode specType; TemplateParameters tparams; // D 2.0 this(TypeNode type, Identifier* ident, Token* opTok, Token* specTok, TypeNode specType, typeof(tparams) tparams) { mixin(set_kind); addChild(type); addOptChild(specType); version(D2) addOptChild(tparams); this.type = type; this.ident = ident; this.opTok = opTok; this.specTok = specTok; this.specType = specType; this.tparams = tparams; } } class FunctionLiteralExpression : Expression { TypeNode returnType; Parameters params; FuncBodyStatement funcBody; this() { mixin(set_kind); addOptChild(returnType); addOptChild(params); addChild(funcBody); } this(TypeNode returnType, Parameters params, FuncBodyStatement funcBody) { this.returnType = returnType; this.params = params; this.funcBody = funcBody; this(); } this(FuncBodyStatement funcBody) { this.funcBody = funcBody; this(); } } /// ParenthesisExpression := "(" Expression ")" class ParenExpression : Expression { Expression next; this(Expression next) { mixin(set_kind); addChild(next); this.next = next; } } // version(D2) // { class TraitsExpression : Expression { Identifier* ident; TemplateArguments targs; this(typeof(ident) ident, typeof(targs) targs) { mixin(set_kind); addOptChild(targs); this.ident = ident; this.targs = targs; } } // } class VoidInitializer : Expression { this() { mixin(set_kind); } } class ArrayInitializer : Expression { Expression[] keys; Expression[] values; this(Expression[] keys, Expression[] values) { assert(keys.length == values.length); mixin(set_kind); foreach (i, key; keys) { addOptChild(key); // The key is optional in ArrayInitializers. addChild(values[i]); } this.keys = keys; this.values = values; } } class StructInitializer : Expression { Identifier*[] idents; Expression[] values; this(Identifier*[] idents, Expression[] values) { mixin(set_kind); addOptChildren(values); this.idents = idents; this.values = values; } } class AsmTypeExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class AsmOffsetExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class AsmSegExpression : UnaryExpression { this(Expression e) { super(e); mixin(set_kind); } } class AsmPostBracketExpression : UnaryExpression { Expression e2; /// Expression in brackets: e [ e2 ] this(Expression e, Expression e2) { super(e); mixin(set_kind); addChild(e2); this.e2 = e2; } } class AsmBracketExpression : Expression { Expression e; this(Expression e) { mixin(set_kind); addChild(e); this.e = e; } } class AsmLocalSizeExpression : Expression { this() { mixin(set_kind); } } class AsmRegisterExpression : Expression { Identifier* register; int number; // ST(0) - ST(7) or FS:0, FS:4, FS:8 this(Identifier* register, int number = -1) { mixin(set_kind); this.register = register; this.number = number; } }