diff options
author | Daniel Campora <daniel@wipy.io> | 2015-06-29 22:45:39 +0200 |
---|---|---|
committer | Daniel Campora <daniel@wipy.io> | 2015-07-02 11:53:08 +0200 |
commit | 077812b2abe3f5e5325194f9694dad7eb38186dd (patch) | |
tree | 61db6e4f1d4c4ab954e92b77272fb32936598758 | |
parent | bdf958df30539f399edef8650947d7ff4048a8ca (diff) | |
download | micropython-077812b2abe3f5e5325194f9694dad7eb38186dd.tar.gz micropython-077812b2abe3f5e5325194f9694dad7eb38186dd.zip |
py: Add TimeoutError exception subclassed from OSError.
The TimeoutError is useful for some modules, specially the the
socket module. TimeoutError can then be alised to socket.timeout
and then Python code can differentiate between socket.error and
socket.timeout.
-rw-r--r-- | py/mpconfig.h | 5 | ||||
-rw-r--r-- | py/obj.h | 1 | ||||
-rw-r--r-- | py/objexcept.c | 6 | ||||
-rw-r--r-- | py/qstrdefs.h | 3 |
4 files changed, 13 insertions, 2 deletions
diff --git a/py/mpconfig.h b/py/mpconfig.h index 9f541ef705..e92e4c45d0 100644 --- a/py/mpconfig.h +++ b/py/mpconfig.h @@ -462,6 +462,11 @@ typedef double mp_float_t; #define MICROPY_PY_BUILTINS_RANGE_ATTRS (1) #endif +// Whether to support timeout exceptions (like socket.timeout) +#ifndef MICROPY_PY_BUILTINS_TIMEOUTERROR +#define MICROPY_PY_BUILTINS_TIMEOUTERROR (0) +#endif + // Whether to support complete set of special methods // for user classes, otherwise only the most used #ifndef MICROPY_PY_ALL_SPECIAL_METHODS @@ -426,6 +426,7 @@ extern const mp_obj_type_t mp_type_MemoryError; extern const mp_obj_type_t mp_type_NameError; extern const mp_obj_type_t mp_type_NotImplementedError; extern const mp_obj_type_t mp_type_OSError; +extern const mp_obj_type_t mp_type_TimeoutError; extern const mp_obj_type_t mp_type_OverflowError; extern const mp_obj_type_t mp_type_RuntimeError; extern const mp_obj_type_t mp_type_StopIteration; diff --git a/py/objexcept.c b/py/objexcept.c index 6c108d99cb..75369bac7c 100644 --- a/py/objexcept.c +++ b/py/objexcept.c @@ -221,8 +221,11 @@ MP_DEFINE_EXCEPTION(Exception, BaseException) MP_DEFINE_EXCEPTION(UnboundLocalError, NameError) */ MP_DEFINE_EXCEPTION(OSError, Exception) - /* +#if MICROPY_PY_BUILTINS_TIMEOUTERROR MP_DEFINE_EXCEPTION_BASE(OSError) + MP_DEFINE_EXCEPTION(TimeoutError, OSError) +#endif + /* MP_DEFINE_EXCEPTION(BlockingIOError, OSError) MP_DEFINE_EXCEPTION(ChildProcessError, OSError) MP_DEFINE_EXCEPTION(ConnectionError, OSError) @@ -235,7 +238,6 @@ MP_DEFINE_EXCEPTION(Exception, BaseException) MP_DEFINE_EXCEPTION(NotADirectoryError, OSError) MP_DEFINE_EXCEPTION(PermissionError, OSError) MP_DEFINE_EXCEPTION(ProcessLookupError, OSError) - MP_DEFINE_EXCEPTION(TimeoutError, OSError) MP_DEFINE_EXCEPTION(FileExistsError, OSError) MP_DEFINE_EXCEPTION(FileNotFoundError, OSError) MP_DEFINE_EXCEPTION(ReferenceError, Exception) diff --git a/py/qstrdefs.h b/py/qstrdefs.h index 2f51d470dd..367aea17bd 100644 --- a/py/qstrdefs.h +++ b/py/qstrdefs.h @@ -140,6 +140,9 @@ Q(MemoryError) Q(NameError) Q(NotImplementedError) Q(OSError) +#if MICROPY_PY_BUILTINS_TIMEOUTERROR +Q(TimeoutError) +#endif Q(OverflowError) Q(RuntimeError) Q(SyntaxError) |