annotate python/c3/typecheck.py @ 159:5e1dd04cb61c

Added attempt to assembler
author Windel Bouwman
date Fri, 08 Mar 2013 17:16:22 +0100
parents b28a11c01dbe
children 8104fc8b5e90
rev   line source
150
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
1 from .astnodes import BaseType, Variable, Designator, Function
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
2 from .astnodes import CompoundStatement, Assignment, VariableUse
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
3 from .astnodes import Binop, Unop, Constant
155
b28a11c01dbe Simplified IR classes
Windel Bouwman
parents: 152
diff changeset
4 from .astnodes import IfStatement, WhileStatement, ReturnStatement, ProcedureCall
150
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
5 from .astnodes import FunctionType, BaseType
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
6 from . import astnodes
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
7 from .scope import topScope
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
8
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
9 class TypeChecker:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
10 def __init__(self, diag):
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
11 self.diag = diag
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
12 def checkPackage(self, pkg):
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
13 for s in pkg.scope:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
14 self.check(s)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
15 def resolveDesignator(self, d):
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
16 if d.scope.hasSymbol(d.tname):
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
17 return d.scope.getSymbol(d.tname)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
18 else:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
19 msg = 'Cannot resolve name {0}'.format(d.tname)
152
b73bc14a3aa3 Light coupling ide and c3 frontend
Windel Bouwman
parents: 150
diff changeset
20 self.diag.error(msg, d.loc)
150
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
21 def check(self, sym):
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
22 if type(sym) is Variable:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
23 if type(sym.typ) is Designator:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
24 sym.typ = self.resolveDesignator(sym.typ)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
25 elif type(sym) is Function:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
26 for s in sym.scope:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
27 self.check(s)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
28 self.check(sym.typ)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
29 self.check(sym.body)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
30 elif type(sym) is CompoundStatement:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
31 for s in sym.statements:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
32 self.check(s)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
33 elif type(sym) is IfStatement:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
34 self.check(sym.condition)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
35 self.check(sym.truestatement)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
36 self.check(sym.falsestatement)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
37 elif type(sym) is VariableUse:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
38 if type(sym.target) is Designator:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
39 sym.target = self.resolveDesignator(sym.target)
155
b28a11c01dbe Simplified IR classes
Windel Bouwman
parents: 152
diff changeset
40 elif type(sym) is ProcedureCall:
b28a11c01dbe Simplified IR classes
Windel Bouwman
parents: 152
diff changeset
41 if type(sym.proc) is Designator:
b28a11c01dbe Simplified IR classes
Windel Bouwman
parents: 152
diff changeset
42 sym.proc = self.resolveDesignator(sym.proc)
150
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
43 elif type(sym) is Assignment:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
44 self.check(sym.lval)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
45 self.check(sym.rval)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
46 elif type(sym) is ReturnStatement:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
47 self.check(sym.expr)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
48 elif type(sym) is Constant:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
49 if type(sym.value) is int:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
50 sym.typ = topScope.getSymbol('int')
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
51 elif type(sym) is FunctionType:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
52 if type(sym.returntype) is Designator:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
53 sym.returntype = self.resolveDesignator(sym.returntype)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
54 self.check(sym.returntype)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
55 elif type(sym) is Binop:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
56 self.check(sym.a)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
57 self.check(sym.b)
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
58 if type(sym.a) is Constant and type(sym.b) is Constant:
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
59 # Possibly fold expression
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
60 pass
4ae0e02599de Added type check start and analyze phase
Windel Bouwman
parents:
diff changeset
61