Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
88220f98
Commit
88220f98
authored
May 20, 2009
by
DaniloFreitas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
p_cpp_class_definition (working)
parent
2bc546f0
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
16 additions
and
23 deletions
+16
-23
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+16
-23
No files found.
Cython/Compiler/Parsing.py
View file @
88220f98
...
@@ -2530,7 +2530,7 @@ def p_module(s, pxd, full_module_name):
...
@@ -2530,7 +2530,7 @@ def p_module(s, pxd, full_module_name):
option_comments = option_comments)
option_comments = option_comments)
#Implementing...
Not testet yet
#Implementing...
def p_cpp_class_definition(s, pos, ctx):
def p_cpp_class_definition(s, pos, ctx):
# s.sy == 'cppclass'
# s.sy == 'cppclass'
...
@@ -2541,8 +2541,8 @@ def p_cpp_class_definition(s, pos, ctx):
...
@@ -2541,8 +2541,8 @@ def p_cpp_class_definition(s, pos, ctx):
s.next()
s.next()
module_path.append(class_name)
module_path.append(class_name)
class_name = p_ident(s)
class_name = p_ident(s)
if module_path
and ctx.visibility != 'extern'
:
if module_path:
error(pos, "
Qualified
class
name
only
allowed
for
'extern'
C
++
class
")
error(pos, "
Qualified
class
name
not
allowed
C
++
class
")
if module_path and s.sy == 'IDENT' and s.systring == 'as':
if module_path and s.sy == 'IDENT' and s.systring == 'as':
s.next()
s.next()
as_name = p_ident(s)
as_name = p_ident(s)
...
@@ -2554,21 +2554,20 @@ def p_cpp_class_definition(s, pos, ctx):
...
@@ -2554,21 +2554,20 @@ def p_cpp_class_definition(s, pos, ctx):
base_class_module = None
base_class_module = None
base_class_name = None
base_class_name = None
if s.sy == '(':
if s.sy == '(':
s.next()
base_class_path = [p_ident(s)]
base_class = True
base_class = True
while (base_class):
while (base_class):
s.next()
base_class_path = [p_ident(s)]
base_class = False
while s.sy == '.':
while s.sy == '.':
s.next()
s.next()
base_class_path.append(p_ident(s))
base_class_path.append(p_ident(s))
base_class
= False
base_class
es.append(base_class_path)
if s.sy == ',':
if s.sy == ',':
base_class = True
base_class = True
base_classes.append(base_class_path)
base_class_path = []
base_class_path = []
s.expect(')')
s.expect(')')
base_class_modules = ["
.
".join(path[:-1]) for path in base_classes]
base_classes = ["
.
".join(path) for path in base_classes]
base_class_names = [path[-1] for path in base_classes]
if s.sy == '[':
if s.sy == '[':
if ctx.visibility not in ('public', 'extern'):
if ctx.visibility not in ('public', 'extern'):
error(s.position(), "
Name
options
only
allowed
for
'public'
or
'extern'
C
++
class
")
error(s.position(), "
Name
options
only
allowed
for
'public'
or
'extern'
C
++
class
")
...
@@ -2580,17 +2579,15 @@ def p_cpp_class_definition(s, pos, ctx):
...
@@ -2580,17 +2579,15 @@ def p_cpp_class_definition(s, pos, ctx):
body_level = 'cpp_class'
body_level = 'cpp_class'
doc, body = p_suite(s, Ctx(level = body_level), with_doc = 1)
doc, body = p_suite(s, Ctx(level = body_level), with_doc = 1)
else:
else:
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 ctx.visibility == 'extern':
if not module_path:
error(pos, "
Module
name
required
for
'extern'
C
++
class
")
if typeobj_name:
if typeobj_name:
error(pos, "
Type
object
name
specification
not
allowed
for
'extern'
C
++
class
")
error(pos, "
Type
object
name
specification
not
allowed
for
'extern'
C
++
class
")
elif ctx.visibility == 'public':
elif ctx.visibility == 'public':
if not objstruct_name:
if not objstruct_name:
error(pos, "
Object
struct
name
specification
required
for
'public'
C
++
class
")
error(pos, "
Object
struct
name
specification
required
for
'public
w
'
C
++
class
")
if not typeobj_name:
if not typeobj_name:
error(pos, "
Type
object
name
specification
required
for
'public'
C
++
class
")
error(pos, "
Type
object
name
specification
required
for
'public'
C
++
class
")
elif ctx.visibility == 'private':
elif ctx.visibility == 'private':
...
@@ -2598,18 +2595,14 @@ def p_cpp_class_definition(s, pos, ctx):
...
@@ -2598,18 +2595,14 @@ def p_cpp_class_definition(s, pos, ctx):
error(pos, "
Only
'public'
C
++
class
can
be
declared
'api'")
error(pos, "
Only
'public'
C
++
class
can
be
declared
'api'")
else:
else:
error(pos, "
Invalid
class
visibility
'%s'" % ctx.visibility)
error(pos, "
Invalid
class
visibility
'%s'" % ctx.visibility)
return Nodes.CppClassDefNode(pos,
return Nodes.CppClassNode(pos,
name = class_name,
namespace = None,
cname = None,
base_classes = base_classes,
visibility = ctx.visibility,
visibility = ctx.visibility,
typedef_flag = ctx.typedef_flag,
api = ctx.api,
module_name = "
.
".join(module_path),
class_name = class_name,
as_name = as_name,
base_class_modules = base_class_modules,
base_class_names = base_class_names,
objstruct_name = objstruct_name,
typeobj_name = typeobj_name,
in_pxd = ctx.level == 'module_pxd',
in_pxd = ctx.level == 'module_pxd',
attributes = None,
doc = doc,
doc = doc,
body = body)
body = body)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment