Mercurial > hg > octave-nkf
view test/unwind.tst @ 20799:e34692daf663
Extend parser to accept '_' in numbers.
* NEWS: Announce change.
* lex.ll: Define NUMBER to be a NUMREAL (real number) or NUMHEX (hex number).
Define NUMREAL to begin with a digit (D) followed by more digits or an '_'.
Define NUMHEX to begin with 0[xX], a hex digit (a-fA-F0-9), followed by '_' or
more hex digits.
Define EXPON to have a digit (D) followed by more digits or an '_'.
* lex.ll (octave_base_lexer::handle_number): Strip out any underscores before
processing number with sscanf.
* parser.tst: Add tests for new behavior.
author | Rik <rik@octave.org> |
---|---|
date | Mon, 05 Oct 2015 14:05:58 -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");