Commit c6050b86 authored by Danilo Freitas's avatar Danilo Freitas

same work

parent 28601834
...@@ -1080,20 +1080,27 @@ class ImagNode(AtomicNewTempExprNode): ...@@ -1080,20 +1080,27 @@ class ImagNode(AtomicNewTempExprNode):
class NewExprNode(AtomicExprNode): class NewExprNode(AtomicExprNode):
type = PyrexTypes.cpp_class_type type = PyrexTypes.cpp_class_type
subexpr = ['args'] subexpr = ['cppclass']
def analyse_types(self, env): def analyse_types(self, env):
for arg in self.args: entry = env.lookup(self.cppclass)
arg.analyse_types(env) if entry is None or not entry.is_cpp_class:
error(self.pos, "new operator can only be applied to a C++ class")
return
def coerce_to(self, type, env): constructor = entry.scope.lookup('__init__')
return self if constructor is None:
print "no constructor declared"
# create one
self.class_entry = entry
self.type = PyrexTypes.CPtrType(entry.type)
self.func_type = constructor.type
def generate_result_code(self, code): def generate_result_code(self, code):
pass pass
def calculate_result_code(self): def calculate_result_code(self):
return "" return "new " + self.entry.cname
class NameNode(AtomicExprNode): class NameNode(AtomicExprNode):
...@@ -2377,10 +2384,11 @@ class SimpleCallNode(CallNode): ...@@ -2377,10 +2384,11 @@ class SimpleCallNode(CallNode):
if func_type.is_cpp_class: if func_type.is_cpp_class:
for arg in self.args: for arg in self.args:
arg.analyse_types(env) arg.analyse_types(env)
entry = env.lookup(self.function.name) entry = env.lookup(self.function.cppclass)
print entry.name
self.type = entry.type self.type = entry.type
self.function.type = PyrexTypes.CppMethodType(self.function.name, self.function.type = PyrexTypes.CppMethodType(self.function.cppclass,
PyrexTypes.CppClassType(self.function.name, "cppclass", PyrexTypes.CppClassType(self.function.cppclass, "cppclass",
entry.scope, 0, entry.cname, []), self.args) entry.scope, 0, entry.cname, []), self.args)
self.analyse_c_function_call(env) self.analyse_c_function_call(env)
else: else:
......
...@@ -292,12 +292,11 @@ def p_power(s): ...@@ -292,12 +292,11 @@ def p_power(s):
return n1 return n1
def p_new_expr(s): def p_new_expr(s):
# s.systring == 'new' # s.systring == 'new'.
pos = s.position() pos = s.position()
s.next() s.next()
args = p_simple_expr_list(s) name = p_ident(s)
return ExprNodes.NewExprNode(pos, args = args) return p_call(s, ExprNodes.NewExprNode(pos, cppclass = name))
#trailer: '(' [arglist] ')' | '[' subscriptlist ']' | '.' NAME #trailer: '(' [arglist] ')' | '[' subscriptlist ']' | '.' NAME
......
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