Mercurial > pytave
comparison pyeval.cc @ 422:8247f298fd16
Raise Octave errors instead of exceptions for conversion errors
* Makefile.am (COMMON_SOURCE_FILES): Include oct-py-error.cc in the list.
(PYTAVE_HEADER_FILES): Include oct-py-error.h in the list.
* oct-py-error.cc, oct-py-error.h: New files defining error conditions.
* oct-py-types.cc (pytave::extract_py_bool, pytave::extract_py_complex,
pytave::extract_py_float, pytave::make_py_array, pytave::extract_py_scalar_map,
pytave::extract_py_int64, pytave::extract_py_uint64, pytave::extract_py_str):
Use new error condition functions instead of throwing exceptions.
(pytave::make_py_array, pytave::make_py_numeric_value, pytave::make_py_tuple):
Raise Octave error instead of throwing exceptions.
* __py_struct_from_dict__.cc (F__py_int64_scalar_value__,
F__py_uint64_scalar_value__): Remove exception handling logic.
* pycall.cc (Fpycall): Remove conversion exception handlers.
* pyeval.cc (Fpyeval): Likewise.
* pyexec.cc (Fpyexec): Likewise.
* exceptions.h (pytave::pytave_exception, pytave::octave_error_exception,
pytave::octave_parse_exception, pytave::value_convert_exception,
pytave::object_convert_exception, pytave::variable_name_exception): Delete
no longer used exception types.
author | Mike Miller <mtmiller@octave.org> |
---|---|
date | Thu, 04 May 2017 17:13:38 -0700 |
parents | 24555fba9964 |
children | 6b9de18b4bdd |
comparison
equal
deleted
inserted
replaced
421:24555fba9964 | 422:8247f298fd16 |
---|---|
85 { | 85 { |
86 pytave::python_object res = pytave::py_eval_string (code, 0, local_namespace); | 86 pytave::python_object res = pytave::py_eval_string (code, 0, local_namespace); |
87 | 87 |
88 if (nargout > 0 || ! res.is_none ()) | 88 if (nargout > 0 || ! res.is_none ()) |
89 retval(0) = pytave::py_implicitly_convert_return_value (res); | 89 retval(0) = pytave::py_implicitly_convert_return_value (res); |
90 } | |
91 catch (pytave::object_convert_exception const &) | |
92 { | |
93 error ("pyexec: error in return value type conversion"); | |
94 } | 90 } |
95 catch (pytave::error_already_set const &) | 91 catch (pytave::error_already_set const &) |
96 { | 92 { |
97 std::string message = pytave::fetch_exception_message (); | 93 std::string message = pytave::fetch_exception_message (); |
98 error ("pyeval: %s", message.c_str ()); | 94 error ("pyeval: %s", message.c_str ()); |