Mercurial > octave-antonio
view test/unwind.tst @ 20133:bef9086a6725
inpolygon.m: Overhaul function and fix bug #40970.
* NEWS: Announce changes in inpolygon definition.
* inpolygon.m: Use 'in |= on' to include points on the boundary since this is
what Matlab does. Rewrite docstring with new definition. Change error()
messages to be more explicit. Add more input validation tests.
author | Rik <rik@octave.org> |
---|---|
date | Sat, 25 Apr 2015 20:50:36 -0700 |
parents | 4197fc428c7d |
children |
line wrap: on
line source
## Copyright (C) 2006-2015 John W. Eaton ## ## This file is part of Octave. ## ## Octave is free software; you can redistribute it and/or modify it ## under the terms of the GNU General Public License as published by ## the Free Software Foundation; either version 3 of the License, or (at ## your option) any later version. ## ## Octave is distributed in the hope that it will be useful, but ## WITHOUT ANY WARRANTY; without even the implied warranty of ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ## General Public License for more details. ## ## You should have received a copy of the GNU General Public License ## along with Octave; see the file COPYING. If not, see ## <http://www.gnu.org/licenses/>. %!function y = f (x) %! global g; %! save_g = g; %! unwind_protect %! g = 0; %! y = g; %! [1,2;x]; %! g = 1; %! y = [y, g]; %! unwind_protect_cleanup %! g = save_g; %! y = [y, g]; %! end # "end" is part of test, check not using "end_unwind_protect" %!endfunction %! %!test %! global g = -1; %! y = f ([3,4]); %! assert (y, [0,1,-1]); %!function y = f (x) %! global g; %! save_g = g; %! unwind_protect %! g = 0; %! y = g; %! [1,2;x]; %! g = 1; %! y = [y, g]; %! unwind_protect_cleanup %! g = save_g; %! y = [y, g]; %! assert (y, [0,-1]); %! end_unwind_protect %!endfunction %! %!test %! global g = -1; %! fail ("y = f (3);", "mismatch");