2014-11-27 20:30:33 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2017-06-30 09:22:17 +02:00
|
|
|
// options to control how MicroPython is built
|
2014-11-27 20:30:33 +00:00
|
|
|
|
2015-12-18 21:07:58 +00:00
|
|
|
#define MICROPY_OBJ_REPR (MICROPY_OBJ_REPR_C)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_ALLOC_PATH_MAX (128)
|
2016-05-10 15:34:30 +03:00
|
|
|
#define MICROPY_ALLOC_LEXER_INDENT_INIT (8)
|
|
|
|
#define MICROPY_ALLOC_PARSE_RULE_INIT (48)
|
|
|
|
#define MICROPY_ALLOC_PARSE_RULE_INC (8)
|
|
|
|
#define MICROPY_ALLOC_PARSE_RESULT_INC (8)
|
|
|
|
#define MICROPY_ALLOC_PARSE_CHUNK_INIT (64)
|
2016-10-11 16:23:20 +11:00
|
|
|
#define MICROPY_PERSISTENT_CODE_LOAD (1)
|
2016-12-09 16:47:47 +11:00
|
|
|
#define MICROPY_EMIT_XTENSA (1)
|
2016-12-09 17:05:51 +11:00
|
|
|
#define MICROPY_EMIT_INLINE_XTENSA (1)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_MEM_STATS (0)
|
2015-12-26 16:30:37 +02:00
|
|
|
#define MICROPY_DEBUG_PRINTERS (1)
|
2016-04-13 11:46:18 +03:00
|
|
|
#define MICROPY_DEBUG_PRINTER_DEST mp_debug_print
|
2017-01-27 15:16:08 +11:00
|
|
|
#define MICROPY_READER_VFS (MICROPY_VFS)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_ENABLE_GC (1)
|
2017-06-23 20:10:52 +03:00
|
|
|
#define MICROPY_ENABLE_FINALISER (1)
|
2016-02-13 15:44:53 +02:00
|
|
|
#define MICROPY_STACK_CHECK (1)
|
2016-10-14 01:27:53 +11:00
|
|
|
#define MICROPY_ENABLE_EMERGENCY_EXCEPTION_BUF (1)
|
2016-12-15 15:52:47 +11:00
|
|
|
#define MICROPY_KBD_EXCEPTION (1)
|
2016-04-01 14:22:28 +03:00
|
|
|
#define MICROPY_REPL_EVENT_DRIVEN (0)
|
2016-01-30 20:05:57 +02:00
|
|
|
#define MICROPY_REPL_AUTO_INDENT (1)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_HELPER_REPL (1)
|
|
|
|
#define MICROPY_HELPER_LEXER_UNIX (0)
|
|
|
|
#define MICROPY_ENABLE_SOURCE_LINE (1)
|
2015-05-13 00:18:41 +01:00
|
|
|
#define MICROPY_MODULE_WEAK_LINKS (1)
|
2016-02-12 23:36:26 +00:00
|
|
|
#define MICROPY_CAN_OVERRIDE_BUILTINS (1)
|
2016-05-12 12:49:36 +01:00
|
|
|
#define MICROPY_USE_INTERNAL_ERRNO (1)
|
2017-02-15 17:45:36 +11:00
|
|
|
#define MICROPY_ENABLE_SCHEDULER (1)
|
2016-08-14 01:02:35 +03:00
|
|
|
#define MICROPY_PY_ALL_SPECIAL_METHODS (1)
|
2015-12-18 21:07:58 +00:00
|
|
|
#define MICROPY_PY_BUILTINS_COMPLEX (0)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY_BUILTINS_STR_UNICODE (1)
|
|
|
|
#define MICROPY_PY_BUILTINS_BYTEARRAY (1)
|
|
|
|
#define MICROPY_PY_BUILTINS_MEMORYVIEW (1)
|
|
|
|
#define MICROPY_PY_BUILTINS_FROZENSET (1)
|
|
|
|
#define MICROPY_PY_BUILTINS_SET (1)
|
|
|
|
#define MICROPY_PY_BUILTINS_SLICE (1)
|
2016-10-11 12:22:36 +02:00
|
|
|
#define MICROPY_PY_BUILTINS_SLICE_ATTRS (1)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY_BUILTINS_PROPERTY (1)
|
2017-01-03 15:01:31 -08:00
|
|
|
#define MICROPY_PY_DESCRIPTORS (1)
|
2017-06-01 15:43:20 +10:00
|
|
|
#define MICROPY_PY_BUILTINS_INPUT (1)
|
2017-01-21 23:22:44 +11:00
|
|
|
#define MICROPY_PY_BUILTINS_HELP (1)
|
|
|
|
#define MICROPY_PY_BUILTINS_HELP_TEXT esp_help_text
|
2017-02-24 18:26:51 +11:00
|
|
|
#define MICROPY_PY_BUILTINS_HELP_MODULES (1)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY___FILE__ (0)
|
|
|
|
#define MICROPY_PY_GC (1)
|
|
|
|
#define MICROPY_PY_ARRAY (1)
|
2016-02-12 23:36:26 +00:00
|
|
|
#define MICROPY_PY_ARRAY_SLICE_ASSIGN (1)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY_COLLECTIONS (1)
|
2016-05-22 02:57:05 +03:00
|
|
|
#define MICROPY_PY_COLLECTIONS_ORDEREDDICT (1)
|
2017-10-20 12:21:41 -07:00
|
|
|
#define MICROPY_PY_MATH (0)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY_CMATH (0)
|
|
|
|
#define MICROPY_PY_IO (1)
|
2016-05-31 21:46:02 +03:00
|
|
|
#define MICROPY_PY_IO_FILEIO (1)
|
2017-10-18 12:50:20 -07:00
|
|
|
#define MICROPY_PY_STRUCT (0)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY_SYS (1)
|
2016-02-12 23:36:26 +00:00
|
|
|
#define MICROPY_PY_SYS_MAXSIZE (1)
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_PY_SYS_EXIT (1)
|
|
|
|
#define MICROPY_PY_SYS_STDFILES (1)
|
2016-10-11 16:22:21 +11:00
|
|
|
#define MICROPY_PY_SYS_STDIO_BUFFER (1)
|
2016-05-10 23:27:29 +01:00
|
|
|
#define MICROPY_PY_UERRNO (1)
|
2015-12-25 22:04:24 +02:00
|
|
|
#define MICROPY_PY_UBINASCII (1)
|
|
|
|
#define MICROPY_PY_UCTYPES (1)
|
2015-12-31 16:09:00 +02:00
|
|
|
#define MICROPY_PY_UHASHLIB (1)
|
2016-10-06 12:28:28 +11:00
|
|
|
#define MICROPY_PY_UHASHLIB_SHA1 (MICROPY_PY_USSL && MICROPY_SSL_AXTLS)
|
2016-02-13 10:41:10 +00:00
|
|
|
#define MICROPY_PY_UHEAPQ (1)
|
2016-12-23 14:49:13 +03:00
|
|
|
#define MICROPY_PY_UTIMEQ (1)
|
2015-12-25 22:04:24 +02:00
|
|
|
#define MICROPY_PY_UJSON (1)
|
2017-06-27 17:37:24 -07:00
|
|
|
#define MICROPY_PY_URANDOM (0)
|
2016-02-13 10:41:10 +00:00
|
|
|
#define MICROPY_PY_URE (1)
|
2016-12-02 16:44:31 +11:00
|
|
|
#define MICROPY_PY_USELECT (1)
|
2016-10-14 20:13:02 +03:00
|
|
|
#define MICROPY_PY_UTIME_MP_HAL (1)
|
2016-02-13 10:41:10 +00:00
|
|
|
#define MICROPY_PY_UZLIB (1)
|
2015-12-28 10:23:30 +00:00
|
|
|
#define MICROPY_PY_LWIP (1)
|
2015-12-31 00:52:01 +02:00
|
|
|
#define MICROPY_PY_MACHINE (1)
|
2017-04-11 00:12:20 +03:00
|
|
|
#define MICROPY_PY_MACHINE_PIN_MAKE_NEW mp_pin_make_new
|
2016-05-31 14:25:19 +01:00
|
|
|
#define MICROPY_PY_MACHINE_PULSE (1)
|
2016-04-12 13:55:20 +01:00
|
|
|
#define MICROPY_PY_MACHINE_I2C (1)
|
2016-09-01 15:10:27 +10:00
|
|
|
#define MICROPY_PY_MACHINE_SPI (1)
|
2016-12-08 14:41:58 +11:00
|
|
|
#define MICROPY_PY_MACHINE_SPI_MAKE_NEW machine_hspi_make_new
|
2016-04-11 21:25:28 +03:00
|
|
|
#define MICROPY_PY_WEBSOCKET (1)
|
2016-04-29 19:38:21 +03:00
|
|
|
#define MICROPY_PY_WEBREPL (1)
|
2016-04-29 19:15:26 +03:00
|
|
|
#define MICROPY_PY_WEBREPL_DELAY (20)
|
2017-11-05 17:09:40 -05:00
|
|
|
#define MICROPY_PY_FRAMEBUF (1)
|
2015-12-26 16:30:37 +02:00
|
|
|
#define MICROPY_PY_MICROPYTHON_MEM_INFO (1)
|
2016-03-29 11:13:32 +03:00
|
|
|
#define MICROPY_PY_OS_DUPTERM (1)
|
2018-01-09 20:41:41 -05:00
|
|
|
#define MICROPY_CPYTHON_COMPAT (0)
|
2015-12-17 22:15:04 +00:00
|
|
|
#define MICROPY_LONGINT_IMPL (MICROPY_LONGINT_IMPL_MPZ)
|
2015-12-18 21:07:58 +00:00
|
|
|
#define MICROPY_FLOAT_IMPL (MICROPY_FLOAT_IMPL_FLOAT)
|
2016-04-07 00:38:08 +03:00
|
|
|
#define MICROPY_ERROR_REPORTING (MICROPY_ERROR_REPORTING_NORMAL)
|
2016-07-22 00:57:55 +03:00
|
|
|
#define MICROPY_WARNINGS (1)
|
|
|
|
#define MICROPY_PY_STR_BYTES_CMP_WARN (1)
|
2016-01-03 07:19:04 +02:00
|
|
|
#define MICROPY_STREAMS_NON_BLOCK (1)
|
2016-07-30 20:05:56 +03:00
|
|
|
#define MICROPY_STREAMS_POSIX_API (1)
|
2016-01-31 22:24:16 +00:00
|
|
|
#define MICROPY_MODULE_FROZEN_STR (1)
|
2016-05-11 16:57:29 +01:00
|
|
|
#define MICROPY_MODULE_FROZEN_MPY (1)
|
2016-03-17 23:06:47 +08:00
|
|
|
#define MICROPY_MODULE_FROZEN_LEXER mp_lexer_new_from_str32
|
2016-05-11 16:57:29 +01:00
|
|
|
#define MICROPY_QSTR_EXTRA_POOL mp_qstr_frozen_const_pool
|
2014-11-27 20:30:33 +00:00
|
|
|
|
2017-01-27 15:16:08 +11:00
|
|
|
#define MICROPY_VFS (1)
|
2016-03-27 17:13:47 +03:00
|
|
|
#define MICROPY_FATFS_ENABLE_LFN (1)
|
|
|
|
#define MICROPY_FATFS_RPATH (2)
|
|
|
|
#define MICROPY_FATFS_MAX_SS (4096)
|
|
|
|
#define MICROPY_FATFS_LFN_CODE_PAGE (437) /* 1=SFN/ANSI 437=LFN/U.S.(OEM) */
|
|
|
|
#define MICROPY_VFS_FAT (1)
|
2016-08-01 00:03:55 +03:00
|
|
|
#define MICROPY_ESP8266_APA102 (1)
|
2016-10-09 00:56:46 +03:00
|
|
|
#define MICROPY_ESP8266_NEOPIXEL (1)
|
2016-03-27 17:13:47 +03:00
|
|
|
|
2016-11-03 15:50:59 -07:00
|
|
|
extern void ets_event_poll(void);
|
2016-03-11 10:41:10 +07:00
|
|
|
#define MICROPY_EVENT_POLL_HOOK {ets_event_poll();}
|
2016-04-02 01:32:55 +03:00
|
|
|
#define MICROPY_VM_HOOK_COUNT (10)
|
|
|
|
#define MICROPY_VM_HOOK_INIT static uint vm_hook_divisor = MICROPY_VM_HOOK_COUNT;
|
|
|
|
#define MICROPY_VM_HOOK_POLL if (--vm_hook_divisor == 0) { \
|
|
|
|
vm_hook_divisor = MICROPY_VM_HOOK_COUNT; \
|
|
|
|
extern void ets_loop_iter(void); \
|
|
|
|
ets_loop_iter(); \
|
|
|
|
}
|
|
|
|
#define MICROPY_VM_HOOK_LOOP MICROPY_VM_HOOK_POLL
|
|
|
|
#define MICROPY_VM_HOOK_RETURN MICROPY_VM_HOOK_POLL
|
2016-03-11 10:41:10 +07:00
|
|
|
|
2014-11-27 20:30:33 +00:00
|
|
|
// type definitions for the specific machine
|
|
|
|
|
|
|
|
#define MICROPY_MAKE_POINTER_CALLABLE(p) ((void*)((mp_uint_t)(p)))
|
|
|
|
|
2016-02-12 23:36:26 +00:00
|
|
|
#define MP_SSIZE_MAX (0x7fffffff)
|
|
|
|
|
2014-11-27 20:30:33 +00:00
|
|
|
#define UINT_FMT "%u"
|
|
|
|
#define INT_FMT "%d"
|
|
|
|
|
|
|
|
typedef int32_t mp_int_t; // must be pointer size
|
|
|
|
typedef uint32_t mp_uint_t; // must be pointer size
|
|
|
|
typedef long mp_off_t;
|
2015-12-28 10:23:30 +00:00
|
|
|
typedef uint32_t sys_prot_t; // for modlwip
|
2016-07-30 17:46:36 +03:00
|
|
|
// ssize_t, off_t as required by POSIX-signatured functions in stream.h
|
|
|
|
#include <sys/types.h>
|
2014-11-27 20:30:33 +00:00
|
|
|
|
2015-04-09 23:56:15 +01:00
|
|
|
#define MP_PLAT_PRINT_STRN(str, len) mp_hal_stdout_tx_strn_cooked(str, len)
|
2016-12-09 16:47:47 +11:00
|
|
|
void *esp_native_code_commit(void*, size_t);
|
|
|
|
#define MP_PLAT_COMMIT_EXEC(buf, len) esp_native_code_commit(buf, len)
|
2015-04-09 23:56:15 +01:00
|
|
|
|
2016-05-31 21:46:02 +03:00
|
|
|
#define mp_type_fileio fatfs_type_fileio
|
|
|
|
#define mp_type_textio fatfs_type_textio
|
|
|
|
|
2017-01-27 15:16:08 +11:00
|
|
|
// use vfs's functions for import stat and builtin open
|
|
|
|
#define mp_import_stat mp_vfs_import_stat
|
|
|
|
#define mp_builtin_open mp_vfs_open
|
|
|
|
#define mp_builtin_open_obj mp_vfs_open_obj
|
|
|
|
|
2014-11-27 20:30:33 +00:00
|
|
|
// extra built in names to add to the global namespace
|
|
|
|
#define MICROPY_PORT_BUILTINS \
|
2017-08-21 21:34:23 +10:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_open), MP_ROM_PTR(&mp_builtin_open_obj) },
|
2014-11-27 20:30:33 +00:00
|
|
|
|
|
|
|
// extra built in modules to add to the list of known ones
|
2015-01-23 00:34:16 +02:00
|
|
|
extern const struct _mp_obj_module_t esp_module;
|
2015-06-12 17:16:52 +03:00
|
|
|
extern const struct _mp_obj_module_t network_module;
|
2017-06-27 15:17:30 -07:00
|
|
|
extern const struct _mp_obj_module_t os_module;
|
2017-06-27 17:37:24 -07:00
|
|
|
extern const struct _mp_obj_module_t random_module;
|
2017-06-27 15:17:30 -07:00
|
|
|
extern const struct _mp_obj_module_t storage_module;
|
2017-10-18 12:50:20 -07:00
|
|
|
extern const struct _mp_obj_module_t struct_module;
|
2015-12-28 10:23:30 +00:00
|
|
|
extern const struct _mp_obj_module_t mp_module_lwip;
|
2015-12-31 00:52:01 +02:00
|
|
|
extern const struct _mp_obj_module_t mp_module_machine;
|
2017-06-22 16:17:46 +10:00
|
|
|
extern const struct _mp_obj_module_t mp_module_onewire;
|
2016-11-03 15:50:59 -07:00
|
|
|
extern const struct _mp_obj_module_t microcontroller_module;
|
|
|
|
extern const struct _mp_obj_module_t board_module;
|
2017-10-20 12:21:41 -07:00
|
|
|
extern const struct _mp_obj_module_t math_module;
|
2017-04-10 13:32:19 -07:00
|
|
|
extern const struct _mp_obj_module_t analogio_module;
|
|
|
|
extern const struct _mp_obj_module_t digitalio_module;
|
|
|
|
extern const struct _mp_obj_module_t pulseio_module;
|
|
|
|
extern const struct _mp_obj_module_t busio_module;
|
2016-11-03 15:50:59 -07:00
|
|
|
extern const struct _mp_obj_module_t bitbangio_module;
|
|
|
|
extern const struct _mp_obj_module_t time_module;
|
2017-08-07 14:30:11 -07:00
|
|
|
extern const struct _mp_obj_module_t multiterminal_module;
|
2017-10-23 12:29:17 -04:00
|
|
|
extern const struct _mp_obj_module_t neopixel_write_module;
|
2014-11-27 20:30:33 +00:00
|
|
|
|
|
|
|
#define MICROPY_PORT_BUILTIN_MODULES \
|
2015-01-23 00:34:16 +02:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_esp), (mp_obj_t)&esp_module }, \
|
2016-03-23 16:25:55 +02:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_socket), (mp_obj_t)&mp_module_lwip }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_usocket), (mp_obj_t)&mp_module_lwip }, \
|
2015-06-12 17:16:52 +03:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_network), (mp_obj_t)&network_module }, \
|
2017-06-27 15:17:30 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_os), (mp_obj_t)&os_module }, \
|
2017-09-01 23:07:12 -04:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_machine), (mp_obj_t)&mp_module_machine }, \
|
2017-08-21 21:34:23 +10:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR__onewire), MP_ROM_PTR(&mp_module_onewire) }, \
|
2016-11-03 15:50:59 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_microcontroller), (mp_obj_t)µcontroller_module }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_board), (mp_obj_t)&board_module }, \
|
2017-04-10 13:32:19 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_analogio), (mp_obj_t)&analogio_module }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_digitalio), (mp_obj_t)&digitalio_module }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_pulseio), (mp_obj_t)&pulseio_module }, \
|
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_busio), (mp_obj_t)&busio_module }, \
|
2016-11-03 15:50:59 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_bitbangio), (mp_obj_t)&bitbangio_module }, \
|
2017-06-27 15:17:30 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_storage), (mp_obj_t)&storage_module }, \
|
2017-06-27 17:37:24 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_random), (mp_obj_t)&random_module }, \
|
2017-10-18 12:50:20 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_struct), (mp_obj_t)&struct_module }, \
|
2017-10-20 12:21:41 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_math), (mp_obj_t)&math_module }, \
|
2016-11-03 15:50:59 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_time), (mp_obj_t)&time_module }, \
|
2017-08-07 14:30:11 -07:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_multiterminal), (mp_obj_t)&multiterminal_module }, \
|
2017-10-23 12:29:17 -04:00
|
|
|
{ MP_OBJ_NEW_QSTR(MP_QSTR_neopixel_write),(mp_obj_t)&neopixel_write_module }, \
|
2014-11-27 20:30:33 +00:00
|
|
|
|
2015-05-13 00:18:41 +01:00
|
|
|
#define MICROPY_PORT_BUILTIN_MODULE_WEAK_LINKS \
|
2017-08-21 21:34:23 +10:00
|
|
|
{ MP_ROM_QSTR(MP_QSTR_json), MP_ROM_PTR(&mp_module_ujson) }, \
|
|
|
|
{ MP_ROM_QSTR(MP_QSTR_errno), MP_ROM_PTR(&mp_module_uerrno) }, \
|
|
|
|
{ MP_ROM_QSTR(MP_QSTR_select), MP_ROM_PTR(&mp_module_uselect) }, \
|
|
|
|
{ MP_ROM_QSTR(MP_QSTR_socket), MP_ROM_PTR(&mp_module_lwip) }, \
|
2015-05-13 00:18:41 +01:00
|
|
|
|
2015-01-07 23:38:50 +00:00
|
|
|
#define MP_STATE_PORT MP_STATE_VM
|
|
|
|
|
|
|
|
#define MICROPY_PORT_ROOT_POINTERS \
|
2015-05-02 21:24:25 +02:00
|
|
|
const char *readline_hist[8]; \
|
2016-04-14 11:15:43 +01:00
|
|
|
mp_obj_t pin_irq_handler[16]; \
|
2015-01-07 23:38:50 +00:00
|
|
|
|
2014-11-27 20:30:33 +00:00
|
|
|
// We need to provide a declaration/definition of alloca()
|
|
|
|
#include <alloca.h>
|
|
|
|
|
|
|
|
// board specifics
|
|
|
|
|
2015-10-30 23:03:58 +00:00
|
|
|
#define MICROPY_MPHALPORT_H "esp_mphal.h"
|
2014-11-27 20:30:33 +00:00
|
|
|
#define MICROPY_HW_BOARD_NAME "ESP module"
|
|
|
|
#define MICROPY_HW_MCU_NAME "ESP8266"
|
2016-05-02 18:54:46 +01:00
|
|
|
#define MICROPY_PY_SYS_PLATFORM "esp8266"
|
2015-12-29 20:44:55 +02:00
|
|
|
|
2016-10-19 00:20:10 +03:00
|
|
|
#define MP_FASTCODE(n) __attribute__((section(".iram0.text." #n))) n
|
|
|
|
|
2015-12-29 20:44:55 +02:00
|
|
|
#define _assert(expr) ((expr) ? (void)0 : __assert_func(__FILE__, __LINE__, __func__, #expr))
|