Mercurial > projects > dil
view trunk/src/Types.d @ 280:1eb54f6f392e
- Made class Type abstract.
- Added new class IntegralType and adapted parser accordingly.
author | aziz |
---|---|
date | Mon, 06 Aug 2007 18:54:01 +0000 |
parents | 79c095aae50d |
children | c1fcfbce9499 |
line wrap: on
line source
/++ Author: Aziz Köksal License: GPL3 +/ module Types; import SyntaxTree; import Token; import Expressions; enum Linkage { Invalid, C, Cpp, D, Windows, Pascal, System } enum StorageClass { None = 0, Abstract = 1, Auto = 1<<2, Const = 1<<3, Deprecated = 1<<4, Extern = 1<<5, Final = 1<<6, Invariant = 1<<7, Override = 1<<8, Scope = 1<<9, Static = 1<<10, Synchronized = 1<<11, In = 1<<12, Out = 1<<13, Ref = 1<<14, Lazy = 1<<15, Variadic = 1<<16, } class Parameter : Node { StorageClass stc; Token* stcTok; Type type; Token* ident; Expression assignExpr; this(Token* stcTok, Type type, Token* ident, Expression assignExpr) { super(NodeCategory.Other); StorageClass stc; if (stcTok !is null) { // NB: In D 2.0 StorageClass.In means final/scope/const switch (stcTok.type) { // TODO: D 2.0 invariant/const/final/scope case TOK.In: stc = StorageClass.In; break; case TOK.Out: stc = StorageClass.Out; break; case TOK.Inout: case TOK.Ref: stc = StorageClass.Ref; break; case TOK.Lazy: stc = StorageClass.Lazy; break; case TOK.Ellipses: stc = StorageClass.Variadic; default: } } this.stc = stc; this.stcTok = stcTok; this.type = type; this.ident = ident; this.assignExpr = assignExpr; } bool isVariadic() { return !!(stc & StorageClass.Variadic); } bool isOnlyVariadic() { return stc == StorageClass.Variadic; } } class Parameters : Node { Parameter[] items; this() { super(NodeCategory.Other); } bool hasVariadic() { if (items.length != 0) return items[$-1].isVariadic(); return false; } void opCatAssign(Parameter param) { items ~= param; } size_t length() { return items.length; } } enum Protection { None, Private = 1, Protected = 1<<1, Package = 1<<2, Public = 1<<3, Export = 1<<4 } class BaseClass { Protection prot; Type type; this(Protection prot, Type type) { this.prot = prot; this.type = type; } } enum TP { Type, Value, Alias, Tuple } class TemplateParameter : Node { TP tp; Type valueType; Token* ident; Type specType, defType; Expression specValue, defValue; this(TP tp, Type valueType, Token* ident, Type specType, Type defType, Expression specValue, Expression defValue) { super(NodeCategory.Other); this.tp = tp; this.valueType = valueType; this.ident = ident; this.specType = specType; this.defType = defType; this.specValue = specValue; this.defValue = defValue; } } class TemplateParameters : Node { TemplateParameter[] params; this() { super(NodeCategory.Other); } void opCatAssign(TemplateParameter parameter) { params ~= parameter; } } class TemplateArguments : Node { Node[] args; this() { super(NodeCategory.Other); } void opCatAssign(Node argument) { args ~= argument; } } enum TID { Void = TOK.Void, Char = TOK.Char, Wchar = TOK.Wchar, Dchar = TOK.Dchar, Bool = TOK.Bool, Byte = TOK.Byte, Ubyte = TOK.Ubyte, Short = TOK.Short, Ushort = TOK.Ushort, Int = TOK.Int, Uint = TOK.Uint, Long = TOK.Long, Ulong = TOK.Ulong, Float = TOK.Float, Double = TOK.Double, Real = TOK.Real, Ifloat = TOK.Ifloat, Idouble = TOK.Idouble, Ireal = TOK.Ireal, Cfloat = TOK.Cfloat, Cdouble = TOK.Cdouble, Creal = TOK.Creal, Undefined, Function, Delegate, Pointer, Array, DotList, Identifier, Typeof, TemplateInstance, Const, // D2 Invariant, // D2 } abstract class Type : Node { TID tid; Type next; this(TID tid) { this(tid, null); } this(TID tid, Type next) { super(NodeCategory.Type); this.tid = tid; this.next = next; } } class IntegralType : Type { this(TOK tok) { super(cast(TID)tok); } } class UndefinedType : Type { this() { super(TID.Undefined); } } class DotListType : Type { Type[] dotList; this(Type[] dotList) { super(TID.DotList); this.dotList = dotList; } } class IdentifierType : Type { Token* ident; this(Token* ident) { super(TID.Identifier); this.ident = ident; } } class TypeofType : Type { Expression e; this(Expression e) { super(TID.Typeof); this.e = e; } } class TemplateInstanceType : Type { Token* ident; TemplateArguments targs; this(Token* ident, TemplateArguments targs) { super(TID.TemplateInstance); this.ident = ident; this.targs = targs; } } class PointerType : Type { this(Type t) { super(TID.Pointer, t); } } class ArrayType : Type { Expression e, e2; Type assocType; this(Type t) { super(TID.Array, t); } this(Type t, Expression e, Expression e2) { this(t); this.e = e; this.e2 = e2; } this(Type t, Type assocType) { this(t); this.assocType = assocType; } } class FunctionType : Type { Type returnType; Parameters parameters; TemplateParameters tparams; this(Type returnType, Parameters parameters, TemplateParameters tparams = null) { super(TID.Function); this.returnType = returnType; this.parameters = parameters; this.tparams = tparams; } } class DelegateType : Type { this(Type func) { super(TID.Delegate, func); } } version(D2) { class ConstType : Type { this(Type t) { // If t is null: cast(const) super(TID.Const, t); } } class InvariantType : Type { this(Type t) { // If t is null: cast(invariant) super(TID.Invariant, t); } } } // version(D2)