PyAPI: remove code for Python 3.10

This commit is contained in:
Campbell Barton
2024-01-10 10:04:10 +11:00
parent 4d9063739c
commit e1f04aee4b
2 changed files with 18 additions and 122 deletions

View File

@@ -312,23 +312,21 @@ static bool is_opcode_secure(const int opcode)
return true;
switch (opcode) {
# if PY_VERSION_HEX >= 0x030b0000 /* Python 3.11 & newer. */
OK_OP(CACHE)
OK_OP(POP_TOP)
OK_OP(PUSH_NULL)
OK_OP(NOP)
# if PY_VERSION_HEX < 0x030c0000
# if PY_VERSION_HEX < 0x030c0000
OK_OP(UNARY_POSITIVE)
# endif
# endif
OK_OP(UNARY_NEGATIVE)
OK_OP(UNARY_NOT)
OK_OP(UNARY_INVERT)
OK_OP(BINARY_SUBSCR)
OK_OP(GET_LEN)
# if PY_VERSION_HEX < 0x030c0000
# if PY_VERSION_HEX < 0x030c0000
OK_OP(LIST_TO_TUPLE)
# endif
# endif
OK_OP(RETURN_VALUE)
OK_OP(SWAP)
OK_OP(BUILD_TUPLE)
@@ -337,12 +335,12 @@ static bool is_opcode_secure(const int opcode)
OK_OP(BUILD_MAP)
OK_OP(COMPARE_OP)
OK_OP(JUMP_FORWARD)
# if PY_VERSION_HEX < 0x030c0000
# if PY_VERSION_HEX < 0x030c0000
OK_OP(JUMP_IF_FALSE_OR_POP)
OK_OP(JUMP_IF_TRUE_OR_POP)
OK_OP(POP_JUMP_FORWARD_IF_FALSE)
OK_OP(POP_JUMP_FORWARD_IF_TRUE)
# endif
# endif
OK_OP(LOAD_GLOBAL)
OK_OP(IS_OP)
OK_OP(CONTAINS_OP)
@@ -350,10 +348,10 @@ static bool is_opcode_secure(const int opcode)
OK_OP(LOAD_FAST)
OK_OP(STORE_FAST)
OK_OP(DELETE_FAST)
# if PY_VERSION_HEX < 0x030c0000
# if PY_VERSION_HEX < 0x030c0000
OK_OP(POP_JUMP_FORWARD_IF_NOT_NONE)
OK_OP(POP_JUMP_FORWARD_IF_NONE)
# endif
# endif
OK_OP(BUILD_SLICE)
OK_OP(LOAD_DEREF)
OK_OP(STORE_DEREF)
@@ -362,17 +360,17 @@ static bool is_opcode_secure(const int opcode)
OK_OP(SET_UPDATE)
/* NOTE(@ideasman42): Don't enable dict manipulation, unless we can prove there is not way it
* can be used to manipulate the name-space (potentially allowing malicious code). */
# if 0
# if 0
OK_OP(DICT_MERGE)
OK_OP(DICT_UPDATE)
# endif
# endif
# if PY_VERSION_HEX < 0x030c0000
# if PY_VERSION_HEX < 0x030c0000
OK_OP(POP_JUMP_BACKWARD_IF_NOT_NONE)
OK_OP(POP_JUMP_BACKWARD_IF_NONE)
OK_OP(POP_JUMP_BACKWARD_IF_FALSE)
OK_OP(POP_JUMP_BACKWARD_IF_TRUE)
# endif
# endif
/* Special cases. */
OK_OP(LOAD_CONST) /* Ok because constants are accepted. */
@@ -380,91 +378,9 @@ static bool is_opcode_secure(const int opcode)
OK_OP(CALL) /* Ok, because we check its "name" before calling. */
OK_OP(KW_NAMES) /* Ok, because it's used for calling functions with keyword arguments. */
# if PY_VERSION_HEX < 0x030c0000
# if PY_VERSION_HEX < 0x030c0000
OK_OP(PRECALL) /* Ok, because it's used for calling. */
# endif
# else /* Python 3.10 and older. */
OK_OP(POP_TOP)
OK_OP(ROT_TWO)
OK_OP(ROT_THREE)
OK_OP(DUP_TOP)
OK_OP(DUP_TOP_TWO)
OK_OP(ROT_FOUR)
OK_OP(NOP)
OK_OP(UNARY_POSITIVE)
OK_OP(UNARY_NEGATIVE)
OK_OP(UNARY_NOT)
OK_OP(UNARY_INVERT)
OK_OP(BINARY_MATRIX_MULTIPLY)
OK_OP(INPLACE_MATRIX_MULTIPLY)
OK_OP(BINARY_POWER)
OK_OP(BINARY_MULTIPLY)
OK_OP(BINARY_MODULO)
OK_OP(BINARY_ADD)
OK_OP(BINARY_SUBTRACT)
OK_OP(BINARY_SUBSCR)
OK_OP(BINARY_FLOOR_DIVIDE)
OK_OP(BINARY_TRUE_DIVIDE)
OK_OP(INPLACE_FLOOR_DIVIDE)
OK_OP(INPLACE_TRUE_DIVIDE)
OK_OP(GET_LEN)
OK_OP(INPLACE_ADD)
OK_OP(INPLACE_SUBTRACT)
OK_OP(INPLACE_MULTIPLY)
OK_OP(INPLACE_MODULO)
OK_OP(BINARY_LSHIFT)
OK_OP(BINARY_RSHIFT)
OK_OP(BINARY_AND)
OK_OP(BINARY_XOR)
OK_OP(BINARY_OR)
OK_OP(INPLACE_POWER)
OK_OP(INPLACE_LSHIFT)
OK_OP(INPLACE_RSHIFT)
OK_OP(INPLACE_AND)
OK_OP(INPLACE_XOR)
OK_OP(INPLACE_OR)
OK_OP(LIST_TO_TUPLE)
OK_OP(RETURN_VALUE)
OK_OP(ROT_N)
OK_OP(BUILD_TUPLE)
OK_OP(BUILD_LIST)
OK_OP(BUILD_SET)
OK_OP(BUILD_MAP)
OK_OP(COMPARE_OP)
OK_OP(JUMP_FORWARD)
OK_OP(JUMP_IF_FALSE_OR_POP)
OK_OP(JUMP_IF_TRUE_OR_POP)
OK_OP(JUMP_ABSOLUTE)
OK_OP(POP_JUMP_IF_FALSE)
OK_OP(POP_JUMP_IF_TRUE)
OK_OP(LOAD_GLOBAL)
OK_OP(IS_OP)
OK_OP(CONTAINS_OP)
OK_OP(LOAD_FAST)
OK_OP(STORE_FAST)
OK_OP(DELETE_FAST)
OK_OP(BUILD_SLICE)
OK_OP(LOAD_DEREF)
OK_OP(STORE_DEREF)
OK_OP(LIST_EXTEND)
OK_OP(SET_UPDATE)
/* NOTE(@ideasman42): Don't enable dict manipulation, unless we can prove there is not way it
* can be used to manipulate the name-space (potentially allowing malicious code). */
# if 0
OK_OP(DICT_MERGE)
OK_OP(DICT_UPDATE)
# endif
/* Special cases. */
OK_OP(LOAD_CONST) /* Ok because constants are accepted. */
OK_OP(LOAD_NAME) /* Ok, because `PyCodeObject.names` is checked. */
OK_OP(CALL_FUNCTION) /* Ok, because we check its "name" before calling. */
OK_OP(CALL_FUNCTION_KW)
OK_OP(CALL_FUNCTION_EX)
# endif /* Python 3.10 and older. */
# endif
}
# undef OK_OP
@@ -511,16 +427,12 @@ bool BPY_driver_secure_bytecode_test_ex(PyObject *expr_code,
PyObject *co_code;
# if PY_VERSION_HEX >= 0x030b0000 /* Python 3.11 & newer. */
co_code = PyCode_GetCode(py_code);
if (UNLIKELY(!co_code)) {
PyErr_Print();
PyErr_Clear();
return false;
}
# else
co_code = py_code->co_code;
# endif
PyBytes_AsStringAndSize(co_code, (char **)&codestr, &code_len);
code_len /= sizeof(*codestr);
@@ -542,9 +454,7 @@ bool BPY_driver_secure_bytecode_test_ex(PyObject *expr_code,
}
}
# if PY_VERSION_HEX >= 0x030b0000 /* Python 3.11 & newer. */
Py_DECREF(co_code);
# endif
if (!ok) {
return false;
}

View File

@@ -855,25 +855,11 @@ static void bpy_module_delay_init(PyObject *bpy_proxy)
*/
static bool bpy_module_ensure_compatible_version()
{
/* First check the Python version used matches the major version that Blender was built with.
* While this isn't essential, the error message in this case may be cryptic and misleading.
* NOTE: using `Py_LIMITED_API` would remove the need for this, in practice it's
* unlikely Blender will ever used the limited API though. */
# if PY_VERSION_HEX >= 0x030b0000 /* Python 3.11 & newer. */
/* First check the Python version used matches the major version that Blender was built with.
* While this isn't essential, the error message in this case may be cryptic and misleading.
* NOTE: using `Py_LIMITED_API` would remove the need for this, in practice it's
* unlikely Blender will ever used the limited API though. */
const uint version_runtime = Py_Version;
# else
uint version_runtime;
{
uint version_runtime_major = 0, version_runtime_minor = 0;
const char *version_str = Py_GetVersion();
if (sscanf(version_str, "%u.%u.", &version_runtime_major, &version_runtime_minor) != 2) {
/* Should never happen, raise an error to ensure this check never fails silently. */
PyErr_Format(PyExc_ImportError, "Failed to extract the version from \"%s\"", version_str);
return false;
}
version_runtime = (version_runtime_major << 24) | (version_runtime_minor << 16);
}
# endif
uint version_compile_major = PY_VERSION_HEX >> 24;
uint version_compile_minor = ((PY_VERSION_HEX & 0x00ff0000) >> 16);