runtime.h 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /*
  2. * This file is part of the MicroPython project, http://micropython.org/
  3. *
  4. * The MIT License (MIT)
  5. *
  6. * Copyright (c) 2013, 2014 Damien P. George
  7. *
  8. * Permission is hereby granted, free of charge, to any person obtaining a copy
  9. * of this software and associated documentation files (the "Software"), to deal
  10. * in the Software without restriction, including without limitation the rights
  11. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  12. * copies of the Software, and to permit persons to whom the Software is
  13. * furnished to do so, subject to the following conditions:
  14. *
  15. * The above copyright notice and this permission notice shall be included in
  16. * all copies or substantial portions of the Software.
  17. *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  21. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  24. * THE SOFTWARE.
  25. */
  26. #ifndef MICROPY_INCLUDED_PY_RUNTIME_H
  27. #define MICROPY_INCLUDED_PY_RUNTIME_H
  28. #include "py/mpstate.h"
  29. typedef enum {
  30. MP_VM_RETURN_NORMAL,
  31. MP_VM_RETURN_YIELD,
  32. MP_VM_RETURN_EXCEPTION,
  33. } mp_vm_return_kind_t;
  34. typedef enum {
  35. MP_ARG_BOOL = 0x001,
  36. MP_ARG_INT = 0x002,
  37. MP_ARG_OBJ = 0x003,
  38. MP_ARG_KIND_MASK = 0x0ff,
  39. MP_ARG_REQUIRED = 0x100,
  40. MP_ARG_KW_ONLY = 0x200,
  41. } mp_arg_flag_t;
  42. typedef union _mp_arg_val_t {
  43. bool u_bool;
  44. mp_int_t u_int;
  45. mp_obj_t u_obj;
  46. mp_rom_obj_t u_rom_obj;
  47. } mp_arg_val_t;
  48. typedef struct _mp_arg_t {
  49. uint16_t qst;
  50. uint16_t flags;
  51. mp_arg_val_t defval;
  52. } mp_arg_t;
  53. // Tables mapping operator enums to qstrs, defined in objtype.c
  54. extern const byte mp_unary_op_method_name[];
  55. extern const byte mp_binary_op_method_name[];
  56. void mp_init(void);
  57. void mp_deinit(void);
  58. void mp_handle_pending(void);
  59. void mp_handle_pending_tail(mp_uint_t atomic_state);
  60. #if MICROPY_ENABLE_SCHEDULER
  61. void mp_sched_lock(void);
  62. void mp_sched_unlock(void);
  63. static inline unsigned int mp_sched_num_pending(void) { return MP_STATE_VM(sched_sp); }
  64. bool mp_sched_schedule(mp_obj_t function, mp_obj_t arg);
  65. #endif
  66. // extra printing method specifically for mp_obj_t's which are integral type
  67. int mp_print_mp_int(const mp_print_t *print, mp_obj_t x, int base, int base_char, int flags, char fill, int width, int prec);
  68. void mp_arg_check_num(size_t n_args, size_t n_kw, size_t n_args_min, size_t n_args_max, bool takes_kw);
  69. void mp_arg_parse_all(size_t n_pos, const mp_obj_t *pos, mp_map_t *kws, size_t n_allowed, const mp_arg_t *allowed, mp_arg_val_t *out_vals);
  70. void mp_arg_parse_all_kw_array(size_t n_pos, size_t n_kw, const mp_obj_t *args, size_t n_allowed, const mp_arg_t *allowed, mp_arg_val_t *out_vals);
  71. NORETURN void mp_arg_error_terse_mismatch(void);
  72. NORETURN void mp_arg_error_unimpl_kw(void);
  73. static inline mp_obj_dict_t *mp_locals_get(void) { return MP_STATE_THREAD(dict_locals); }
  74. static inline void mp_locals_set(mp_obj_dict_t *d) { MP_STATE_THREAD(dict_locals) = d; }
  75. static inline mp_obj_dict_t *mp_globals_get(void) { return MP_STATE_THREAD(dict_globals); }
  76. static inline void mp_globals_set(mp_obj_dict_t *d) { MP_STATE_THREAD(dict_globals) = d; }
  77. mp_obj_t mp_load_name(qstr qst);
  78. mp_obj_t mp_load_global(qstr qst);
  79. mp_obj_t mp_load_build_class(void);
  80. void mp_store_name(qstr qst, mp_obj_t obj);
  81. void mp_store_global(qstr qst, mp_obj_t obj);
  82. void mp_delete_name(qstr qst);
  83. void mp_delete_global(qstr qst);
  84. mp_obj_t mp_unary_op(mp_unary_op_t op, mp_obj_t arg);
  85. mp_obj_t mp_binary_op(mp_binary_op_t op, mp_obj_t lhs, mp_obj_t rhs);
  86. mp_obj_t mp_call_function_0(mp_obj_t fun);
  87. mp_obj_t mp_call_function_1(mp_obj_t fun, mp_obj_t arg);
  88. mp_obj_t mp_call_function_2(mp_obj_t fun, mp_obj_t arg1, mp_obj_t arg2);
  89. mp_obj_t mp_call_function_n_kw(mp_obj_t fun, size_t n_args, size_t n_kw, const mp_obj_t *args);
  90. mp_obj_t mp_call_method_n_kw(size_t n_args, size_t n_kw, const mp_obj_t *args);
  91. mp_obj_t mp_call_method_n_kw_var(bool have_self, size_t n_args_n_kw, const mp_obj_t *args);
  92. mp_obj_t mp_call_method_self_n_kw(mp_obj_t meth, mp_obj_t self, size_t n_args, size_t n_kw, const mp_obj_t *args);
  93. // Call function and catch/dump exception - for Python callbacks from C code
  94. void mp_call_function_1_protected(mp_obj_t fun, mp_obj_t arg);
  95. void mp_call_function_2_protected(mp_obj_t fun, mp_obj_t arg1, mp_obj_t arg2);
  96. typedef struct _mp_call_args_t {
  97. mp_obj_t fun;
  98. size_t n_args, n_kw, n_alloc;
  99. mp_obj_t *args;
  100. } mp_call_args_t;
  101. #if MICROPY_STACKLESS
  102. // Takes arguments which are the most general mix of Python arg types, and
  103. // prepares argument array suitable for passing to ->call() method of a
  104. // function object (and mp_call_function_n_kw()).
  105. // (Only needed in stackless mode.)
  106. void mp_call_prepare_args_n_kw_var(bool have_self, size_t n_args_n_kw, const mp_obj_t *args, mp_call_args_t *out_args);
  107. #endif
  108. void mp_unpack_sequence(mp_obj_t seq, size_t num, mp_obj_t *items);
  109. void mp_unpack_ex(mp_obj_t seq, size_t num, mp_obj_t *items);
  110. mp_obj_t mp_store_map(mp_obj_t map, mp_obj_t key, mp_obj_t value);
  111. mp_obj_t mp_load_attr(mp_obj_t base, qstr attr);
  112. void mp_convert_member_lookup(mp_obj_t obj, const mp_obj_type_t *type, mp_obj_t member, mp_obj_t *dest);
  113. void mp_load_method(mp_obj_t base, qstr attr, mp_obj_t *dest);
  114. void mp_load_method_maybe(mp_obj_t base, qstr attr, mp_obj_t *dest);
  115. void mp_load_super_method(qstr attr, mp_obj_t *dest);
  116. void mp_store_attr(mp_obj_t base, qstr attr, mp_obj_t val);
  117. mp_obj_t mp_getiter(mp_obj_t o, mp_obj_iter_buf_t *iter_buf);
  118. mp_obj_t mp_iternext_allow_raise(mp_obj_t o); // may return MP_OBJ_STOP_ITERATION instead of raising StopIteration()
  119. mp_obj_t mp_iternext(mp_obj_t o); // will always return MP_OBJ_STOP_ITERATION instead of raising StopIteration(...)
  120. mp_vm_return_kind_t mp_resume(mp_obj_t self_in, mp_obj_t send_value, mp_obj_t throw_value, mp_obj_t *ret_val);
  121. mp_obj_t mp_make_raise_obj(mp_obj_t o);
  122. mp_obj_t mp_import_name(qstr name, mp_obj_t fromlist, mp_obj_t level);
  123. mp_obj_t mp_import_from(mp_obj_t module, qstr name);
  124. void mp_import_all(mp_obj_t module);
  125. NORETURN void mp_raise_msg(const mp_obj_type_t *exc_type, const char *msg);
  126. //NORETURN void nlr_raise_msg_varg(const mp_obj_type_t *exc_type, const char *fmt, ...);
  127. NORETURN void mp_raise_ValueError(const char *msg);
  128. NORETURN void mp_raise_TypeError(const char *msg);
  129. NORETURN void mp_raise_NotImplementedError(const char *msg);
  130. NORETURN void mp_raise_OSError(int errno_);
  131. NORETURN void mp_exc_recursion_depth(void);
  132. #if MICROPY_BUILTIN_METHOD_CHECK_SELF_ARG
  133. #undef mp_check_self
  134. #define mp_check_self(pred)
  135. #else
  136. // A port may define to raise TypeError for example
  137. #ifndef mp_check_self
  138. #define mp_check_self(pred) assert(pred)
  139. #endif
  140. #endif
  141. // helper functions for native/viper code
  142. mp_uint_t mp_convert_obj_to_native(mp_obj_t obj, mp_uint_t type);
  143. mp_obj_t mp_convert_native_to_obj(mp_uint_t val, mp_uint_t type);
  144. mp_obj_t mp_native_call_function_n_kw(mp_obj_t fun_in, size_t n_args_kw, const mp_obj_t *args);
  145. void mp_native_raise(mp_obj_t o);
  146. #define mp_sys_path (MP_OBJ_FROM_PTR(&MP_STATE_VM(mp_sys_path_obj)))
  147. #define mp_sys_argv (MP_OBJ_FROM_PTR(&MP_STATE_VM(mp_sys_argv_obj)))
  148. #if MICROPY_WARNINGS
  149. void mp_warning(const char *msg, ...);
  150. #else
  151. #define mp_warning(...)
  152. #endif
  153. #endif // MICROPY_INCLUDED_PY_RUNTIME_H