Mercurial > hg > octave-nkf
view examples/code/unwinddemo.cc @ 20473:5c088348fddb
qp.m: Overhaul function (fixes bug #45324).
* qp.m: Put input validation first. Validate both x0 and q are vectors.
Transform x0 and q to column vectors for rest of computation (bug #45324).
Use double quotes instead of single to match Octave coding conventions.
Re-wrap multi-line comments to break at meaningful boundaries. Use isargout
to avoid calculating unnecessary outputs.
author | Rik <rik@octave.org> |
---|---|
date | Mon, 15 Jun 2015 21:56:34 +0200 |
parents | 95c533ed464b |
children | 2f8500ca91d3 |
line wrap: on
line source
#include <octave/oct.h> #include <octave/unwind-prot.h> void my_err_handler (const char *fmt, ...) { // Do nothing!! } void my_err_with_id_handler (const char *id, const char *fmt, ...) { // Do nothing!! } DEFUN_DLD (unwinddemo, args, nargout, "Unwind Demo") { octave_value retval; int nargin = args.length (); if (nargin < 2) print_usage (); else { NDArray a = args(0).array_value (); NDArray b = args(1).array_value (); if (! error_state) { // Declare unwind_protect frame which lasts as long as // the variable frame has scope. unwind_protect frame; frame.add_fcn (set_liboctave_warning_handler, current_liboctave_warning_handler); frame.add_fcn (set_liboctave_warning_with_id_handler, current_liboctave_warning_with_id_handler); set_liboctave_warning_handler (my_err_handler); set_liboctave_warning_with_id_handler (my_err_with_id_handler); retval = octave_value (quotient (a, b)); } } return retval; }