Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
Pyston
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
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
Pyston
Commits
b363d7a0
Commit
b363d7a0
authored
Nov 09, 2015
by
Kevin Modzelewski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
go for weakref
parent
54ee4c2e
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
13 additions
and
13 deletions
+13
-13
src/capi/typeobject.cpp
src/capi/typeobject.cpp
+10
-10
src/runtime/types.cpp
src/runtime/types.cpp
+3
-3
No files found.
src/capi/typeobject.cpp
View file @
b363d7a0
...
@@ -819,7 +819,7 @@ static PyObject* slot_tp_descr_get(PyObject* self, PyObject* obj, PyObject* type
...
@@ -819,7 +819,7 @@ static PyObject* slot_tp_descr_get(PyObject* self, PyObject* obj, PyObject* type
PyTypeObject
*
tp
=
Py_TYPE
(
self
);
PyTypeObject
*
tp
=
Py_TYPE
(
self
);
PyObject
*
get
;
PyObject
*
get
;
static
BoxedString
*
get_str
=
internStringImmortal
(
"__get__"
);
static
BoxedString
*
get_str
=
getStaticString
(
"__get__"
);
get
=
typeLookup
(
tp
,
get_str
);
get
=
typeLookup
(
tp
,
get_str
);
if
(
get
==
NULL
)
{
if
(
get
==
NULL
)
{
/* Avoid further slowdowns */
/* Avoid further slowdowns */
...
@@ -914,7 +914,7 @@ Box* slotTpGetattrHookInternal(Box* self, BoxedString* name, GetattrRewriteArgs*
...
@@ -914,7 +914,7 @@ Box* slotTpGetattrHookInternal(Box* self, BoxedString* name, GetattrRewriteArgs*
__getattr__, even when the attribute is present. So we use
__getattr__, even when the attribute is present. So we use
_PyType_Lookup and create the method only when needed, with
_PyType_Lookup and create the method only when needed, with
call_attribute. */
call_attribute. */
static
BoxedString
*
_getattr_str
=
internStringImmortal
(
"__getattr__"
);
static
BoxedString
*
_getattr_str
=
getStaticString
(
"__getattr__"
);
// Don't need to do this in the rewritten version; if a __getattr__ later gets removed:
// Don't need to do this in the rewritten version; if a __getattr__ later gets removed:
// - if we ever get to the "call __getattr__" portion of the rewrite, the guards will
// - if we ever get to the "call __getattr__" portion of the rewrite, the guards will
...
@@ -944,7 +944,7 @@ Box* slotTpGetattrHookInternal(Box* self, BoxedString* name, GetattrRewriteArgs*
...
@@ -944,7 +944,7 @@ Box* slotTpGetattrHookInternal(Box* self, BoxedString* name, GetattrRewriteArgs*
__getattr__, even when self has the default __getattribute__
__getattr__, even when self has the default __getattribute__
method. So we use _PyType_Lookup and create the method only when
method. So we use _PyType_Lookup and create the method only when
needed, with call_attribute. */
needed, with call_attribute. */
static
BoxedString
*
_getattribute_str
=
internStringImmortal
(
"__getattribute__"
);
static
BoxedString
*
_getattribute_str
=
getStaticString
(
"__getattribute__"
);
RewriterVar
*
r_getattribute
=
NULL
;
RewriterVar
*
r_getattribute
=
NULL
;
if
(
rewrite_args
)
{
if
(
rewrite_args
)
{
...
@@ -1129,7 +1129,7 @@ template Box* slotTpGetattrHookInternal<CXX, NOT_REWRITABLE>(Box* self, BoxedStr
...
@@ -1129,7 +1129,7 @@ template Box* slotTpGetattrHookInternal<CXX, NOT_REWRITABLE>(Box* self, BoxedStr
try
{
try
{
// TODO: runtime ICs?
// TODO: runtime ICs?
static
BoxedString
*
_new_str
=
internStringImmortal
(
"__new__"
);
static
BoxedString
*
_new_str
=
getStaticString
(
"__new__"
);
Box
*
new_attr
=
typeLookup
(
self
,
_new_str
);
Box
*
new_attr
=
typeLookup
(
self
,
_new_str
);
assert
(
new_attr
);
assert
(
new_attr
);
new_attr
=
processDescriptor
(
new_attr
,
None
,
self
);
new_attr
=
processDescriptor
(
new_attr
,
None
,
self
);
...
@@ -1142,7 +1142,7 @@ template Box* slotTpGetattrHookInternal<CXX, NOT_REWRITABLE>(Box* self, BoxedStr
...
@@ -1142,7 +1142,7 @@ template Box* slotTpGetattrHookInternal<CXX, NOT_REWRITABLE>(Box* self, BoxedStr
}
}
static
PyObject
*
slot_tp_del
(
PyObject
*
self
)
noexcept
{
static
PyObject
*
slot_tp_del
(
PyObject
*
self
)
noexcept
{
static
BoxedString
*
del_str
=
internStringImmortal
(
"__del__"
);
static
BoxedString
*
del_str
=
getStaticString
(
"__del__"
);
try
{
try
{
// TODO: runtime ICs?
// TODO: runtime ICs?
Box
*
del_attr
=
typeLookup
(
self
->
cls
,
del_str
);
Box
*
del_attr
=
typeLookup
(
self
->
cls
,
del_str
);
...
@@ -2073,7 +2073,7 @@ static struct PyMethodDef tp_new_methoddef[] = { { "__new__", (PyCFunction)tp_ne
...
@@ -2073,7 +2073,7 @@ static struct PyMethodDef tp_new_methoddef[] = { { "__new__", (PyCFunction)tp_ne
{
0
,
0
,
0
,
0
}
};
{
0
,
0
,
0
,
0
}
};
static
void
add_tp_new_wrapper
(
BoxedClass
*
type
)
noexcept
{
static
void
add_tp_new_wrapper
(
BoxedClass
*
type
)
noexcept
{
static
BoxedString
*
new_str
=
internStringImmortal
(
"__new__"
);
static
BoxedString
*
new_str
=
getStaticString
(
"__new__"
);
if
(
type
->
getattr
(
new_str
))
if
(
type
->
getattr
(
new_str
))
return
;
return
;
...
@@ -3399,7 +3399,7 @@ extern "C" void PyType_RequestHcAttrs(PyTypeObject* cls, int offset) noexcept {
...
@@ -3399,7 +3399,7 @@ extern "C" void PyType_RequestHcAttrs(PyTypeObject* cls, int offset) noexcept {
}
}
extern
"C"
void
PyType_GiveHcAttrsDictDescr
(
PyTypeObject
*
cls
)
noexcept
{
extern
"C"
void
PyType_GiveHcAttrsDictDescr
(
PyTypeObject
*
cls
)
noexcept
{
static
BoxedString
*
dict_str
=
internStringImmortal
(
"__dict__"
);
static
BoxedString
*
dict_str
=
getStaticString
(
"__dict__"
);
assert
(
!
cls
->
hasattr
(
dict_str
));
assert
(
!
cls
->
hasattr
(
dict_str
));
cls
->
giveAttr
(
dict_str
,
dict_descr
);
cls
->
giveAttr
(
dict_str
,
dict_descr
);
}
}
...
@@ -3478,12 +3478,12 @@ extern "C" int PyType_Ready(PyTypeObject* cls) noexcept {
...
@@ -3478,12 +3478,12 @@ extern "C" int PyType_Ready(PyTypeObject* cls) noexcept {
return
-
1
;
return
-
1
;
}
}
static
BoxedString
*
doc_str
=
internStringImmortal
(
"__doc__"
);
static
BoxedString
*
doc_str
=
getStaticString
(
"__doc__"
);
if
(
!
cls
->
hasattr
(
doc_str
))
{
if
(
!
cls
->
hasattr
(
doc_str
))
{
if
(
cls
->
tp_doc
)
{
if
(
cls
->
tp_doc
)
{
cls
->
giveAttr
(
doc_str
,
boxString
(
cls
->
tp_doc
));
cls
->
giveAttr
(
incref
(
doc_str
)
,
boxString
(
cls
->
tp_doc
));
}
else
{
}
else
{
cls
->
giveAttr
(
doc_str
,
None
);
cls
->
giveAttr
(
incref
(
doc_str
),
incref
(
None
)
);
}
}
}
}
...
...
src/runtime/types.cpp
View file @
b363d7a0
...
@@ -3866,6 +3866,9 @@ void setupRuntime() {
...
@@ -3866,6 +3866,9 @@ void setupRuntime() {
// being tracked in sys.modules:
// being tracked in sys.modules:
setupSys
();
setupSys
();
// Weakrefs are used for tp_subclasses:
init_weakref
();
// XXX
// XXX
_Py_ReleaseInternedStrings
();
_Py_ReleaseInternedStrings
();
for
(
auto
b
:
classes
)
for
(
auto
b
:
classes
)
...
@@ -3884,9 +3887,6 @@ void setupRuntime() {
...
@@ -3884,9 +3887,6 @@ void setupRuntime() {
exit
(
0
);
exit
(
0
);
// XXX
// XXX
// Weakrefs are used for tp_subclasses:
init_weakref
();
add_operators
(
object_cls
);
add_operators
(
object_cls
);
object_cls
->
finishInitialization
();
object_cls
->
finishInitialization
();
...
...
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