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
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
cython
Commits
d928e45f
Commit
d928e45f
authored
Jul 27, 2009
by
Danilo Freitas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Templates
parent
86f49e42
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
139 additions
and
7 deletions
+139
-7
Cython/Compiler/Nodes.py
Cython/Compiler/Nodes.py
+4
-0
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+44
-7
Cython/Compiler/stl.pxd
Cython/Compiler/stl.pxd
+91
-0
No files found.
Cython/Compiler/Nodes.py
View file @
d928e45f
...
...
@@ -721,6 +721,9 @@ class CSimpleBaseTypeNode(CBaseTypeNode):
else
:
type
=
py_object_type
self
.
arg_name
=
self
.
name
elif
self
.
templates
:
if
not
self
.
name
in
self
.
templates
:
error
(
self
.
pos
,
"'%s' is not a type identifier"
%
self
.
name
)
else
:
error
(
self
.
pos
,
"'%s' is not a type identifier"
%
self
.
name
)
if
self
.
complex
:
...
...
@@ -913,6 +916,7 @@ class CppClassNode(CStructOrUnionDefNode):
# attributes [CVarDefNode] or None
# entry Entry
# base_classes [string]
# templates [string] or None
def
analyse_declarations
(
self
,
env
):
scope
=
None
...
...
Cython/Compiler/Parsing.py
View file @
d928e45f
...
...
@@ -32,6 +32,7 @@ class Ctx(object):
overridable
=
0
nogil
=
0
namespace
=
None
templates
=
None
def
__init__
(
self
,
**
kwds
):
self
.
__dict__
.
update
(
kwds
)
...
...
@@ -1379,6 +1380,29 @@ def p_with_statement(s):
s
.
next
()
body
=
p_suite
(
s
)
return
Nodes
.
GILStatNode
(
pos
,
state
=
state
,
body
=
body
)
elif
s
.
systring
==
'template'
:
templates
=
[]
s
.
next
()
s
.
expect
(
'['
)
#s.next()
templates
.
append
(
s
.
systring
)
s
.
next
()
while
s
.
systring
==
','
:
s
.
next
()
templates
.
append
(
s
.
systring
)
s
.
next
()
s
.
expect
(
']'
)
if
s
.
sy
==
':'
:
s
.
next
()
s
.
expect_newline
(
"Syntax error in template function declaration"
)
s
.
expect_indent
()
body_ctx
=
Ctx
()
body_ctx
.
templates
=
templates
func_or_var
=
p_c_func_or_var_declaration
(
s
,
pos
,
body_ctx
)
s
.
expect_dedent
()
return
func_or_var
else
:
error
(
pos
,
"Syntax error in template function declaration"
)
else
:
manager
=
p_expr
(
s
)
target
=
None
...
...
@@ -1669,13 +1693,13 @@ def p_positional_and_keyword_args(s, end_sy_set, type_positions=(), type_keyword
s
.
next
()
return
positional_args
,
keyword_args
def
p_c_base_type
(
s
,
self_flag
=
0
,
nonempty
=
0
):
def
p_c_base_type
(
s
,
self_flag
=
0
,
nonempty
=
0
,
templates
=
None
):
# If self_flag is true, this is the base type for the
# self argument of a C method of an extension type.
if
s
.
sy
==
'('
:
return
p_c_complex_base_type
(
s
)
else
:
return
p_c_simple_base_type
(
s
,
self_flag
,
nonempty
=
nonempty
)
return
p_c_simple_base_type
(
s
,
self_flag
,
nonempty
=
nonempty
,
templates
=
templates
)
def
p_calling_convention
(
s
):
if
s
.
sy
==
'IDENT'
and
s
.
systring
in
calling_convention_words
:
...
...
@@ -1697,7 +1721,7 @@ def p_c_complex_base_type(s):
return
Nodes
.
CComplexBaseTypeNode
(
pos
,
base_type
=
base_type
,
declarator
=
declarator
)
def
p_c_simple_base_type
(
s
,
self_flag
,
nonempty
):
def
p_c_simple_base_type
(
s
,
self_flag
,
nonempty
,
templates
=
None
):
#print "p_c_simple_base_type: self_flag =", self_flag, nonempty
is_basic
=
0
signed
=
1
...
...
@@ -1753,7 +1777,7 @@ def p_c_simple_base_type(s, self_flag, nonempty):
name
=
name
,
module_path
=
module_path
,
is_basic_c_type
=
is_basic
,
signed
=
signed
,
complex
=
complex
,
longness
=
longness
,
is_self_arg
=
self_flag
)
is_self_arg
=
self_flag
,
templates
=
templates
)
# Treat trailing [] on type as buffer access if it appears in a context
...
...
@@ -2253,12 +2277,12 @@ def p_c_modifiers(s):
def
p_c_func_or_var_declaration
(
s
,
pos
,
ctx
):
cmethod_flag
=
ctx
.
level
in
(
'c_class'
,
'c_class_pxd'
)
modifiers
=
p_c_modifiers
(
s
)
base_type
=
p_c_base_type
(
s
,
nonempty
=
1
)
base_type
=
p_c_base_type
(
s
,
nonempty
=
1
,
templates
=
ctx
.
templates
)
declarator
=
p_c_declarator
(
s
,
ctx
,
cmethod_flag
=
cmethod_flag
,
assignable
=
1
,
nonempty
=
1
)
declarator
.
overridable
=
ctx
.
overridable
if
s
.
sy
==
':'
:
if
ctx
.
level
not
in
(
'module'
,
'c_class'
,
'module_pxd'
,
'c_class_pxd'
):
if
ctx
.
level
not
in
(
'module'
,
'c_class'
,
'module_pxd'
,
'c_class_pxd'
)
and
not
ctx
.
templates
:
s
.
error
(
"C function definition not allowed here"
)
doc
,
suite
=
p_suite
(
s
,
Ctx
(
level
=
'function'
),
with_doc
=
1
)
result
=
Nodes
.
CFuncDefNode
(
pos
,
...
...
@@ -2559,6 +2583,17 @@ def p_cpp_class_definition(s, pos, ctx):
cname = ctx.namespace + "
::
" + class_name
if s.sy == '.':
error(pos, "
Qualified
class
name
not
allowed
C
++
class
")
templates = None
if s.sy == '[':
s.next()
templates = []
templates.append(s.systring)
s.next()
while s.sy == ',':
s.next()
templates.append(s.systring)
s.next()
s.expect(']')
base_classes = []
objstruct_name = None
typeobj_name = None
...
...
@@ -2585,6 +2620,7 @@ def p_cpp_class_definition(s, pos, ctx):
s.expect_indent()
attributes = []
body_ctx = Ctx()
body_ctx.templates = templates
while s.sy != 'DEDENT':
if s.sy != 'pass':
attributes.append(
...
...
@@ -2601,7 +2637,8 @@ def p_cpp_class_definition(s, pos, ctx):
base_classes = base_classes,
visibility = ctx.visibility,
in_pxd = ctx.level == 'module_pxd',
attributes = attributes)
attributes = attributes,
templates = templates)
...
...
Cython/Compiler/stl.pxd
0 → 100644
View file @
d928e45f
cdef
extern
from
"<vector>"
namespace
std
:
cdef
cppclass
vector
[
TYPE
]:
#constructors
__init__
()
__init__
(
vector
&
)
__init__
(
int
)
__init__
(
int
,
TYPE
&
)
__init__
(
iterator
,
iterator
)
#operators
TYPE
&
__getitem__
(
int
)
TYPE
&
__setitem__
(
int
,
TYPE
&
)
vector
__new__
(
vector
&
)
bool
__eq__
(
vector
&
,
vector
&
)
bool
__ne__
(
vector
&
,
vector
&
)
bool
__lt__
(
vector
&
,
vector
&
)
bool
__gt__
(
vector
&
,
vector
&
)
bool
__le__
(
vector
&
,
vector
&
)
bool
__ge__
(
vector
&
,
vector
&
)
#others
void
assign
(
int
,
TYPE
)
#void assign(iterator, iterator)
TYPE
&
at
(
int
)
TYPE
&
back
()
iterator
begin
()
int
capacity
()
void
clear
()
bool
empty
()
iterator
end
()
iterator
erase
(
iterator
)
iterator
erase
(
iterator
,
iterator
)
TYPE
&
front
()
iterator
insert
(
iterator
,
TYPE
&
)
void
insert
(
iterator
,
int
,
TYPE
&
)
void
insert
(
iterator
,
iterator
)
int
max_size
()
void
pop_back
()
void
push_back
(
TYPE
&
)
iterator
rbegin
()
iterator
rend
()
void
reserve
(
int
)
void
resize
(
int
)
void
resize
(
int
,
TYPE
&
)
#void resize(size_type num, const TYPE& = TYPE())
int
size
()
void
swap
(
container
&
)
cdef
extern
from
"<deque>"
namespace
std
:
cdef
cppclass
deque
[
TYPE
]:
#constructors
__init__
()
__init__
(
deque
&
)
__init__
(
int
)
__init__
(
int
,
TYPE
&
)
__init__
(
iterator
,
iterator
)
#operators
TYPE
&
operator
[](
size_type
index
);
const
TYPE
&
operator
[](
size_type
index
)
const
;
deque
__new__
(
deque
&
);
bool
__eq__
(
deque
&
,
deque
&
);
bool
__ne__
(
deque
&
,
deque
&
);
bool
__lt__
(
deque
&
,
deque
&
);
bool
__gt__
(
deque
&
,
deque
&
);
bool
__le__
(
deque
&
,
deque
&
);
bool
__ge__
(
deque
&
,
deque
&
);
#others
void
assign
(
int
,
TYPE
&
)
void
assign
(
iterator
,
iterator
)
TYPE
&
at
(
int
)
TYPE
&
back
()
iterator
begin
()
void
clear
()
bool
empty
()
iterator
end
()
iterator
erase
(
iterator
)
iterator
erase
(
iterator
,
iterator
)
TYPE
&
front
()
iterator
insert
(
iterator
,
TYPE
&
)
void
insert
(
iterator
,
int
,
TYPE
&
)
void
insert
(
iterator
,
iterator
,
iterator
)
int
max_size
()
void
pop_back
()
void
pop_front
()
void
push_back
(
TYPE
&
)
void
push_front
(
TYPE
&
)
iterator
rbegin
()
iterator
rend
()
void
resize
(
int
)
void
resize
(
int
,
TYPE
&
)
int
size
()
void
swap
(
container
&
)
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