Skip to content

Commit 8d92a93

Browse files
committed
[GR-52183] Re-add aliases for internal functions we used in our PyO3 branches
PullRequest: graalpython/3200
2 parents 77d844a + 3899da3 commit 8d92a93

File tree

4 files changed

+120
-1
lines changed

4 files changed

+120
-1
lines changed

graalpython/com.oracle.graal.python.cext/CMakeLists.txt

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -35,6 +35,8 @@ function(require_var var)
3535
endif()
3636
endfunction()
3737

38+
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
39+
3840
if(MSVC)
3941
message(FATAL_ERROR "C API cannot be built with MSVC")
4042
endif()

graalpython/com.oracle.graal.python.cext/src/listobject.c

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2018, 2023, Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2018, 2024, Oracle and/or its affiliates. All rights reserved.
33
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44
*
55
* The Universal Permissive License (UPL), Version 1.0
@@ -40,3 +40,7 @@
4040
*/
4141
#include "capi.h"
4242

43+
// alias for internal function, currently used in PyO3
44+
void _PyList_SET_ITEM(PyObject* a, Py_ssize_t b, PyObject* c) {
45+
return PyTruffleList_SET_ITEM(a, b, c);
46+
}

graalpython/com.oracle.graal.python.cext/src/object.c

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -799,6 +799,11 @@ Py_ssize_t PyTruffle_REFCNT(PyObject *obj) {
799799
#endif /* GRAALVM_PYTHON_LLVM_MANAGED */
800800
}
801801

802+
// alias, currently used in PyO3
803+
Py_ssize_t _Py_REFCNT(PyObject *obj) {
804+
return PyTruffle_REFCNT(obj);
805+
}
806+
802807
void PyTruffle_SET_REFCNT(PyObject* obj, Py_ssize_t cnt) {
803808
#ifndef GRAALVM_PYTHON_LLVM_MANAGED
804809
PyObject *dest;
@@ -843,6 +848,11 @@ PyTypeObject* PyTruffle_TYPE(PyObject *a) {
843848
#endif /* GRAALVM_PYTHON_LLVM_MANAGED */
844849
}
845850

851+
// alias, currently used in PyO3
852+
PyTypeObject* _Py_TYPE(PyObject *obj) {
853+
return PyTruffle_TYPE(obj);
854+
}
855+
846856
Py_ssize_t PyTruffle_SIZE(PyObject *ob) {
847857
PyVarObject* a = (PyVarObject*)ob;
848858
#ifdef GRAALVM_PYTHON_LLVM_MANAGED
@@ -878,6 +888,11 @@ Py_ssize_t PyTruffle_SIZE(PyObject *ob) {
878888
#endif /* GRAALVM_PYTHON_LLVM_MANAGED */
879889
}
880890

891+
// alias, currently used in PyO3
892+
Py_ssize_t _Py_SIZE(PyObject *obj) {
893+
return PyTruffle_SIZE(obj);
894+
}
895+
881896
void PyTruffle_SET_TYPE(PyObject *a, PyTypeObject *b) {
882897
if (points_to_py_handle_space(a)) {
883898
printf("changing the type of an object is not supported\n");
Lines changed: 98 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,98 @@
1+
# Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved.
2+
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3+
#
4+
# The Universal Permissive License (UPL), Version 1.0
5+
#
6+
# Subject to the condition set forth below, permission is hereby granted to any
7+
# person obtaining a copy of this software, associated documentation and/or
8+
# data (collectively the "Software"), free of charge and under any and all
9+
# copyright rights in the Software, and any and all patent rights owned or
10+
# freely licensable by each licensor hereunder covering either (i) the
11+
# unmodified Software as contributed to or provided by such licensor, or (ii)
12+
# the Larger Works (as defined below), to deal in both
13+
#
14+
# (a) the Software, and
15+
#
16+
# (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
17+
# one is included with the Software each a "Larger Work" to which the Software
18+
# is contributed by such licensors),
19+
#
20+
# without restriction, including without limitation the rights to copy, create
21+
# derivative works of, display, perform, and distribute the Software and make,
22+
# use, sell, offer for sale, import, export, have made, and have sold the
23+
# Software and the Larger Work(s), and to sublicense the foregoing rights on
24+
# either these or other terms.
25+
#
26+
# This license is subject to the following condition:
27+
#
28+
# The above copyright notice and either this complete permission notice or at a
29+
# minimum a reference to the UPL must be included in all copies or substantial
30+
# portions of the Software.
31+
#
32+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
33+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
34+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
35+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
36+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
37+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
38+
# SOFTWARE.
39+
40+
import sys
41+
from unittest import skipUnless
42+
from . import CPyExtTestCase, CPyExtFunction, unhandled_error_compare, GRAALPYTHON
43+
44+
45+
# Test for the presence of a few custom symbols we have that are considered
46+
# "public" because we use them in our patches to C extensions
47+
class TestPublicSymbols(CPyExtTestCase):
48+
def compile_module(self, name):
49+
type(self).mro()[1].__dict__["test_%s" % name].create_module(name)
50+
super().compile_module(name)
51+
52+
test_PyO3_symbols = CPyExtFunction(
53+
lambda args: True,
54+
lambda: (
55+
((
56+
"_Py_FalseStructReference",
57+
"_Py_TrueStructReference",
58+
"_Py_EllipsisObjectReference",
59+
"_Py_SIZE",
60+
"_Py_REFCNT",
61+
"_Py_TYPE",
62+
"_Py_NoneStructReference",
63+
"_Py_NotImplementedStructReference",
64+
"_PyList_SET_ITEM",
65+
),),
66+
),
67+
code='''
68+
#include <dlfcn.h>
69+
70+
PyObject* use_symbols_in_pyo3(PyObject* symbols) {
71+
void *sym;
72+
Py_ssize_t len = PyObject_Size(symbols);
73+
for (Py_ssize_t i = 0; i < len; i++) {
74+
sym = NULL;
75+
PyObject *o = PySequence_GetItem(symbols, i);
76+
const char* s = PyUnicode_AsUTF8(o);
77+
sym = dlsym(RTLD_DEFAULT, s);
78+
PyObject *r;
79+
if (sym == NULL) {
80+
r = PyUnicode_FromFormat("Missing %s symbol in global namespace", s);
81+
}
82+
Py_DECREF(o);
83+
if (sym == NULL) {
84+
return r;
85+
}
86+
}
87+
Py_RETURN_TRUE;
88+
}
89+
''',
90+
resultspec="O",
91+
argspec='O',
92+
callfunction="use_symbols_in_pyo3",
93+
arguments=["PyObject* a"],
94+
cmpfunc=unhandled_error_compare
95+
)
96+
97+
if not GRAALPYTHON or sys.platform != "linux":
98+
del test_PyO3_symbols

0 commit comments

Comments
 (0)