Commit 9f4e7b8f authored by Dag Sverre Seljebotn's avatar Dag Sverre Seljebotn

ClassNode to new temps

parent 6b9f9037
...@@ -687,14 +687,18 @@ class CCodeWriter(object): ...@@ -687,14 +687,18 @@ class CCodeWriter(object):
# generation (labels and temps state etc.) # generation (labels and temps state etc.)
# globalstate GlobalState contains state global for a C file (input file info, # globalstate GlobalState contains state global for a C file (input file info,
# utility code, declared constants etc.) # utility code, declared constants etc.)
# emit_linenums boolean whether or not to write #line pragmas # emit_linenums boolean whether or not to write #line pragmas
#
# pyclass_stack list used during recursive code generation to pass information
# about the current class one is in
def __init__(self, create_from=None, buffer=None, copy_formatting=False, emit_linenums=None): def __init__(self, create_from=None, buffer=None, copy_formatting=False, emit_linenums=None):
if buffer is None: buffer = StringIOTree() if buffer is None: buffer = StringIOTree()
self.buffer = buffer self.buffer = buffer
self.marker = None self.marker = None
self.last_marker_line = 0 self.last_marker_line = 0
self.source_desc = "" self.source_desc = ""
self.pyclass_stack = []
self.funcstate = None self.funcstate = None
self.level = 0 self.level = 0
......
...@@ -3567,7 +3567,7 @@ class DictItemNode(ExprNode): ...@@ -3567,7 +3567,7 @@ class DictItemNode(ExprNode):
return iter([self.key, self.value]) return iter([self.key, self.value])
class ClassNode(ExprNode): class ClassNode(NewTempExprNode):
# Helper class used in the implementation of Python # Helper class used in the implementation of Python
# class definitions. Constructs a class object given # class definitions. Constructs a class object given
# a name, tuple of bases and class dictionary. # a name, tuple of bases and class dictionary.
...@@ -3615,7 +3615,6 @@ class UnboundMethodNode(NewTempExprNode): ...@@ -3615,7 +3615,6 @@ class UnboundMethodNode(NewTempExprNode):
# class definitions. Constructs an unbound method # class definitions. Constructs an unbound method
# object from a class and a function. # object from a class and a function.
# #
# class_cname string C var holding the class object
# function ExprNode Function object # function ExprNode Function object
subexprs = ['function'] subexprs = ['function']
...@@ -3628,11 +3627,12 @@ class UnboundMethodNode(NewTempExprNode): ...@@ -3628,11 +3627,12 @@ class UnboundMethodNode(NewTempExprNode):
gil_message = "Constructing an unbound method" gil_message = "Constructing an unbound method"
def generate_result_code(self, code): def generate_result_code(self, code):
class_cname = code.pyclass_stack[-1].classobj.result()
code.putln( code.putln(
"%s = PyMethod_New(%s, 0, %s); %s" % ( "%s = PyMethod_New(%s, 0, %s); %s" % (
self.result(), self.result(),
self.function.py_result(), self.function.py_result(),
self.class_cname, class_cname,
code.error_goto_if_null(self.result(), self.pos))) code.error_goto_if_null(self.result(), self.pos)))
code.put_gotref(self.py_result()) code.put_gotref(self.py_result())
......
...@@ -1781,13 +1781,12 @@ class DefNode(FuncDefNode): ...@@ -1781,13 +1781,12 @@ class DefNode(FuncDefNode):
self.analyse_default_values(env) self.analyse_default_values(env)
if env.is_py_class_scope: if env.is_py_class_scope:
self.synthesize_assignment_node(env) self.synthesize_assignment_node(env)
def synthesize_assignment_node(self, env): def synthesize_assignment_node(self, env):
import ExprNodes import ExprNodes
self.assmt = SingleAssignmentNode(self.pos, self.assmt = SingleAssignmentNode(self.pos,
lhs = ExprNodes.NameNode(self.pos, name = self.name), lhs = ExprNodes.NameNode(self.pos, name = self.name),
rhs = ExprNodes.UnboundMethodNode(self.pos, rhs = ExprNodes.UnboundMethodNode(self.pos,
class_cname = env.class_obj_cname,
function = ExprNodes.PyCFunctionNode(self.pos, function = ExprNodes.PyCFunctionNode(self.pos,
pymethdef_cname = self.entry.pymethdef_cname))) pymethdef_cname = self.entry.pymethdef_cname)))
self.assmt.analyse_declarations(env) self.assmt.analyse_declarations(env)
...@@ -2530,8 +2529,7 @@ class PyClassDefNode(ClassDefNode): ...@@ -2530,8 +2529,7 @@ class PyClassDefNode(ClassDefNode):
self.classobj.analyse_expressions(env) self.classobj.analyse_expressions(env)
genv = env.global_scope() genv = env.global_scope()
cenv = self.scope cenv = self.scope
cenv.class_dict_cname = self.dict.result() cenv.class_dict_cname = self.dict.result() # TODO newtemps -- move to code generation
cenv.namespace_cname = cenv.class_obj_cname = self.classobj.result()
self.body.analyse_expressions(cenv) self.body.analyse_expressions(cenv)
self.target.analyse_target_expression(env, self.classobj) self.target.analyse_target_expression(env, self.classobj)
self.dict.release_temp(env) self.dict.release_temp(env)
...@@ -2542,12 +2540,16 @@ class PyClassDefNode(ClassDefNode): ...@@ -2542,12 +2540,16 @@ class PyClassDefNode(ClassDefNode):
self.body.generate_function_definitions(self.scope, code) self.body.generate_function_definitions(self.scope, code)
def generate_execution_code(self, code): def generate_execution_code(self, code):
code.pyclass_stack.append(self)
cenv = self.scope
self.dict.generate_evaluation_code(code) self.dict.generate_evaluation_code(code)
self.classobj.generate_evaluation_code(code) self.classobj.generate_evaluation_code(code)
cenv.namespace_cname = cenv.class_obj_cname = self.classobj.result()
self.body.generate_execution_code(code) self.body.generate_execution_code(code)
self.target.generate_assignment_code(self.classobj, code) self.target.generate_assignment_code(self.classobj, code)
self.dict.generate_disposal_code(code) self.dict.generate_disposal_code(code)
self.dict.free_temps(code) self.dict.free_temps(code)
code.pyclass_stack.pop()
class CClassDefNode(ClassDefNode): class CClassDefNode(ClassDefNode):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment