Mercurial > octave
view scripts/set/private/validsetargs.m @ 27245:9ded07d2c44f
validsetargs.m: Validate "rows" flag when "legacy" flag also present.
* validsetargs.m: Change "elseif (nargin == 4)" to "else" so that tests
on varargin are run regardless of the size of varargin.
Update error messages to use '"rows" flag' for clarity.
* union.m: Add BIST tests for "rows" flag with "legacy" flag present.
author | Rik <rik@octave.org> |
---|---|
date | Fri, 12 Jul 2019 15:26:36 -0700 |
parents | 9f44123dc25b |
children | e2ba5f061806 |
line wrap: on
line source
## Copyright (C) 2000-2019 Paul Kienzle ## Copyright (C) 2009-2010 Jaroslav Hajek ## ## 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 ## <https://www.gnu.org/licenses/>. ## Validate arguments for binary set operation. function [x, y] = validsetargs (caller, x, y, varargin) isallowedarraytype = @(x) isnumeric (x) || ischar (x) || islogical (x); if (nargin == 3) icx = iscellstr (x); icy = iscellstr (y); if (icx || icy) if (icx && ischar (y)) y = cellstr (y); elseif (icy && ischar (x)) x = cellstr (x); elseif (icy && isempty (x)) x = {}; elseif (icx && isempty (y)) y = {}; elseif (! (icx && icy)) error ("%s: cell array of strings cannot be combined with a nonstring value", caller); endif elseif (! (isallowedarraytype (x) && isallowedarraytype (y))) error ("%s: A and B must be arrays or cell arrays of strings", caller); endif else for arg = varargin switch (arg{1}) case "legacy" ## Accepted option, do nothing. case "rows" if (iscell (x) || iscell (y)) error ('%s: cells not supported with "rows" flag', caller); elseif (! (isallowedarraytype (x) && isallowedarraytype (y))) error ("%s: A and B must be arrays or cell arrays of strings", caller); else if (ndims (x) > 2 || ndims (y) > 2) error ('%s: A and B must be 2-dimensional matrices with "rows" flag', caller); elseif (columns (x) != columns (y) && ! (isempty (x) || isempty (y))) error ("%s: number of columns in A and B must match", caller); endif endif otherwise error ("%s: invalid option: %s", caller, arg{1}); endswitch endfor endif endfunction ## BIST tests for function are in union.m