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 ());