Mercurial > hg > ltpda
view m-toolbox/classes/@ltpda_uo/setPropertyValue.m @ 37:a4b7ceae0403 database-connection-manager
Show backtrace on unit test errors
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Mon, 05 Dec 2011 16:20:06 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
% SETPROPERTYVALUE sets the value of a property of one or more objects. % % CALL: % varargout = setPropertyValue(inputs, ... % input_names, ... % callerIsMethod, ... % propName, ... % setterFcn, ... % copy, ... % getInfo) % % % % % % The setterFcn should have the following signature: % % setterFcn(object, plist, value) % % The plist is passed to allow the setter function to modify the plist if % necessary. % % function varargout = setPropertyValue(varargin) % get inputs inputs = varargin(1:end-6); input_names = varargin{end-5}; callerIsMethod = varargin{end-4}; propName = varargin{end-3}; setterFcn = varargin{end-2}; doCopy = varargin{end-1}; getInfo = varargin{end}; % Check if this is a call for parameters if utils.helper.isinfocall(varargin{1:end-6}) varargout{1} = getInfo(varargin{3}); return end % Collect inputs if callerIsMethod objects = inputs{1}; pls = []; rest = inputs(2:end); obj_invars = {}; else [objects, obj_invars, rest] = utils.helper.collect_objects(inputs(:), '', input_names); [pls, pl_invars, rest] = utils.helper.collect_objects(rest(:), 'plist'); % Copy the user input plists because they may be modified in the setter % functions. if ~isempty(pls) pls = copy(pls, 1); end end % Process the values we want to set [objects, values] = processSetterValues(objects, pls, rest, propName); % Decide on a deep copy or a modify bs = copy(objects, doCopy); usedValues = cell(size(bs)); if isempty(setterFcn) if isempty(values) error('Please provide a value for the property ''%s''', propName); end for jj=1:numel(bs) usedValues{jj} = defaultSetter(bs(jj), values{jj}, propName); end else % Loop over objects and set the values by calling the setter function for jj = 1:numel(bs) if isempty(values) if isempty(pls) % here we create a plist so that the setterFcn has a plist in % case it wants to modify it before it goes in the history. pls = plist(); end usedValues{jj} = setterFcn(bs(jj), pls); else usedValues{jj} = setterFcn(bs(jj), pls, values{jj}); end end end % Set output varargout{1} = bs; if nargout > 1 varargout{2} = usedValues; end if nargout > 2 varargout{3} = pls; end if nargout > 3 varargout{4} = obj_invars; end end % END % Default setter function to set the description % % defaultSetter(obj, value, propertyName) % function value = defaultSetter(varargin) obj = varargin{1}; value = varargin{2}; propName = varargin{3}; % TODO: we could check the type of value here against the default/defined value obj.(propName) = value; end