1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
## Copyright (C) 2010-2015 Ben Abbott
##
## 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/>.
## -*- texinfo -*-
## @deftypefn {Function File} {} setappdata (@var{h}, @var{name}, @var{value})
## @deftypefnx {Function File} {} setappdata (@var{h}, @var{name1}, @var{value1}, @var{name2}, @var{value3}, @dots{})
## Set the application data @var{name} to @var{value} for the graphics object
## with handle @var{h}.
##
## @var{h} may also be a vector of graphics handles. If the application data
## with the specified @var{name} does not exist, it is created. Multiple
## @var{name}/@var{value} pairs can be specified at a time.
##
## @seealso{getappdata, isappdata, rmappdata, guidata, get, set, getpref, setpref}
## @end deftypefn
## Author: Ben Abbott <bpabbott@mac.com>
## Created: 2010-07-15
function setappdata (h, varargin)
h = h(:).';
if (! all (ishandle (h)))
error ("setappdata: H must be a scalar or vector of graphic handles");
elseif (mod (numel (varargin), 2) != 0)
error ("setappdata: NAME/VALUE arguments must occur in pairs");
endif
for hg = h
try
appdata = get (hg, "__appdata__");
catch
appdata = struct ();
addproperty ("__appdata__", hg, "any", appdata);
end_try_catch
for narg = 1:2:numel (varargin)
if (ischar (varargin{narg}))
appdata.(varargin{narg}) = varargin{narg+1};
elseif (iscellstr (varargin{narg}))
## Handle cell arrays like set() does.
set (hg, "__appdata__", appdata);
setappdata (hg, vertcat (varargin{narg}', varargin{narg+1}'){:});
appdata = get (hg, "__appdata__");
else
error ("setappdata: NAME must be a string or cellstr");
endif
endfor
set (hg, "__appdata__", appdata);
endfor
endfunction
%!test
%! unwind_protect
%! setappdata (0, "%hello%", "world");
%! assert (isappdata (0, "%hello%"), true);
%! assert (getappdata (0, "%hello%"), "world");
%! unwind_protect_cleanup
%! rmappdata (0, "%hello%");
%! end_unwind_protect
%!test
%! unwind_protect
%! setappdata (0, "%data1%", ones (3), "%data2%", "hello world");
%! assert (getappdata (0, "%data1%"), ones (3));
%! assert (getappdata (0, "%data2%"), "hello world");
%! setappdata (0, "%data1%", zeros (3));
%! assert (getappdata (0, "%data1%"), zeros (3));
%! unwind_protect_cleanup
%! rmappdata (0, "%data1%", "%data2%");
%! end_unwind_protect
## Test input validation
%!error <H must be a scalar .* graphic handle> rmappdata (-1, "hello")
%!error <NAME must be a string> setappdata (0, 1, 2)
%!error <NAME/VALUE arguments must occur in pairs> setappdata (0, "1")
|