py/mpconfig: Enable module delegation if sys needs it.
Otherwise you can get into the confusing state where e.g. sys.ps1 is enabled in config (via `MICROPY_PY_SYS_PS1_PS2`) but still doesn't actually get enabled. Also verify that the required delegation options are enabled in modsys.c. This work was funded through GitHub Sponsors. Signed-off-by: Jim Mussared <jim.mussared@gmail.com>
This commit is contained in:
parent
e6926d6021
commit
7d2ee8aed0
|
@ -19,7 +19,6 @@
|
|||
#define MICROPY_OPT_MATH_FACTORIAL (0)
|
||||
#define MICROPY_REPL_EMACS_KEYS (0)
|
||||
#define MICROPY_PY_BUILTINS_COMPLEX (0)
|
||||
#define MICROPY_MODULE_ATTR_DELEGATION (0)
|
||||
#define MICROPY_PY_FUNCTION_ATTRS (0)
|
||||
#define MICROPY_PY_DELATTR_SETATTR (0)
|
||||
#define MICROPY_PY_BUILTINS_STR_CENTER (0)
|
||||
|
|
14
py/modsys.c
14
py/modsys.c
|
@ -195,7 +195,21 @@ STATIC mp_obj_t mp_sys_settrace(mp_obj_t obj) {
|
|||
MP_DEFINE_CONST_FUN_OBJ_1(mp_sys_settrace_obj, mp_sys_settrace);
|
||||
#endif // MICROPY_PY_SYS_SETTRACE
|
||||
|
||||
|
||||
#if MICROPY_PY_SYS_PS1_PS2 && !MICROPY_PY_SYS_ATTR_DELEGATION
|
||||
#error "MICROPY_PY_SYS_PS1_PS2 requires MICROPY_PY_SYS_ATTR_DELEGATION"
|
||||
#endif
|
||||
|
||||
#if MICROPY_PY_SYS_TRACEBACKLIMIT && !MICROPY_PY_SYS_ATTR_DELEGATION
|
||||
#error "MICROPY_PY_SYS_TRACEBACKLIMIT requires MICROPY_PY_SYS_ATTR_DELEGATION"
|
||||
#endif
|
||||
|
||||
#if MICROPY_PY_SYS_ATTR_DELEGATION && !MICROPY_MODULE_ATTR_DELEGATION
|
||||
#error "MICROPY_PY_SYS_ATTR_DELEGATION requires MICROPY_MODULE_ATTR_DELEGATION"
|
||||
#endif
|
||||
|
||||
#if MICROPY_PY_SYS_ATTR_DELEGATION
|
||||
// Must be kept in sync with the enum at the top of mpstate.h.
|
||||
STATIC const uint16_t sys_mutable_keys[] = {
|
||||
#if MICROPY_PY_SYS_PS1_PS2
|
||||
MP_QSTR_ps1,
|
||||
|
|
|
@ -842,7 +842,7 @@ typedef double mp_float_t;
|
|||
// Whether modules can use MP_REGISTER_MODULE_DELEGATION() to delegate failed
|
||||
// attribute lookups to a custom handler function.
|
||||
#ifndef MICROPY_MODULE_ATTR_DELEGATION
|
||||
#define MICROPY_MODULE_ATTR_DELEGATION (MICROPY_CONFIG_ROM_LEVEL_AT_LEAST_EXTRA_FEATURES)
|
||||
#define MICROPY_MODULE_ATTR_DELEGATION (MICROPY_PY_SYS_ATTR_DELEGATION || MICROPY_CONFIG_ROM_LEVEL_AT_LEAST_EXTRA_FEATURES)
|
||||
#endif
|
||||
|
||||
// Whether to call __init__ when importing builtin modules for the first time.
|
||||
|
|
|
@ -40,6 +40,8 @@
|
|||
// memory system, runtime and virtual machine. The state is a global
|
||||
// variable, but in the future it is hoped that the state can become local.
|
||||
|
||||
#if MICROPY_PY_SYS_ATTR_DELEGATION
|
||||
// Must be kept in sync with sys_mutable_keys in modsys.c.
|
||||
enum {
|
||||
#if MICROPY_PY_SYS_PS1_PS2
|
||||
MP_SYS_MUTABLE_PS1,
|
||||
|
@ -50,6 +52,7 @@ enum {
|
|||
#endif
|
||||
MP_SYS_MUTABLE_NUM,
|
||||
};
|
||||
#endif // MICROPY_PY_SYS_ATTR_DELEGATION
|
||||
|
||||
// This structure contains dynamic configuration for the compiler.
|
||||
#if MICROPY_DYNAMIC_COMPILER
|
||||
|
|
Loading…
Reference in New Issue