Commit bb50c3e6 authored by Robert Bradshaw's avatar Robert Bradshaw

remove stuff unused for C++ classes

parent 88220f98
...@@ -2537,17 +2537,8 @@ def p_cpp_class_definition(s, pos, ctx): ...@@ -2537,17 +2537,8 @@ def p_cpp_class_definition(s, pos, ctx):
s.next() s.next()
module_path = [] module_path = []
class_name = p_ident(s) class_name = p_ident(s)
while s.sy == '.': if s.sy == '.':
s.next()
module_path.append(class_name)
class_name = p_ident(s)
if module_path:
error(pos, "Qualified class name not allowed C++ class") error(pos, "Qualified class name not allowed C++ class")
if module_path and s.sy == 'IDENT' and s.systring == 'as':
s.next()
as_name = p_ident(s)
else:
as_name = class_name
base_classes = [] base_classes = []
objstruct_name = None objstruct_name = None
typeobj_name = None typeobj_name = None
...@@ -2569,9 +2560,7 @@ def p_cpp_class_definition(s, pos, ctx): ...@@ -2569,9 +2560,7 @@ def p_cpp_class_definition(s, pos, ctx):
s.expect(')') s.expect(')')
base_classes = [".".join(path) for path in base_classes] base_classes = [".".join(path) for path in base_classes]
if s.sy == '[': if s.sy == '[':
if ctx.visibility not in ('public', 'extern'): error(s.position(), "Name options not allowed for C++ class")
error(s.position(), "Name options only allowed for 'public' or 'extern' C++ class")
objstruct_name, typeobj_name = p_c_class_options(s)
if s.sy == ':': if s.sy == ':':
if ctx.level == 'module_pxd': if ctx.level == 'module_pxd':
body_level = 'cpp_class_pxd' body_level = 'cpp_class_pxd'
...@@ -2582,19 +2571,6 @@ def p_cpp_class_definition(s, pos, ctx): ...@@ -2582,19 +2571,6 @@ def p_cpp_class_definition(s, pos, ctx):
s.expect_newline("Syntax error in C++ class definition") s.expect_newline("Syntax error in C++ class definition")
doc = None doc = None
body = None body = None
if ctx.visibility == 'extern':
if typeobj_name:
error(pos, "Type object name specification not allowed for 'extern' C++ class")
elif ctx.visibility == 'public':
if not objstruct_name:
error(pos, "Object struct name specification required for 'publicw' C++ class")
if not typeobj_name:
error(pos, "Type object name specification required for 'public' C++ class")
elif ctx.visibility == 'private':
if ctx.api:
error(pos, "Only 'public' C++ class can be declared 'api'")
else:
error(pos, "Invalid class visibility '%s'" % ctx.visibility)
return Nodes.CppClassNode(pos, return Nodes.CppClassNode(pos,
name = class_name, name = class_name,
namespace = None, namespace = None,
......
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