view m-toolbox/classes/@plist/remove.m @ 44:409a22968d5e default

Add unit tests
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Tue, 06 Dec 2011 18:42:11 +0100 (2011-12-06)
parents f0afece42f48
children
line wrap: on
line source
% REMOVE remove a parameter from the parameter list.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% DESCRIPTION: REMOVE remove a parameter from the parameter list.
%
% CALL:        pl = remove(pl, 2)      - removes 2nd in the list
%              pl = remove(pl, 'key')  - removes parameter called 'key'
%              pl = remove(pl, 'key1', 'key2')
%              pl = remove(pl, [1 2])
%
% <a href="matlab:utils.helper.displayMethodInfo('plist', 'remove')">Parameters Description</a>
%
% VERSION:     $Id: remove.m,v 1.26 2011/04/08 08:56:21 hewitson Exp $
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

function varargout = remove(varargin)
  
  %%% Check if this is a call for parameters
  if utils.helper.isinfocall(varargin{:})
    varargout{1} = getInfo(varargin{3});
    return
  end
  
  [objs, invars, rest] = utils.helper.collect_objects(varargin(:), 'plist');
  
  % Decide on a deep copy or a modify
  objs = copy(objs, nargout);
  
  keys = rest;
  
  for ii = 1:numel(objs)
    pl = objs(ii);
    
    for jj = 1:numel(keys)
      
      if ischar(keys{jj})
        %%%%%   Remove specified key   %%%%%
        idx = [];
        np = length(pl.params);
        for i=1:np
          key = pl.params(i).key;
          if ~strcmpi(key, keys{jj})
            idx = [idx i];
          end
        end
        pl.params = pl.params(idx);
        if length(idx) == np
          warning('!!! No parameter found matching key name in %dth plist', ii);
        end
        
      elseif isnumeric(keys{jj})
        %%%%%   Remove specified position   %%%%%
        
        if max(keys{jj}) > numel(pl.params)
          error('### Index exceeds number of parameters in %dth plist', ii);
        end
        pl.params(keys{jj}) = [];
        
      elseif islogical(keys{jj})
        %%%%%   Remove specified logical position   %%%%%
        
        if numel(keys{jj}) ~= numel(pl.params)
          error('### The logical index doesn''t have the same size as the number of parameters.');
        end
        pl.params(keys{jj}) = [];
        
      else
        %%%%%   Unknown method   %%%%%
        error('### unknown indexing method')
      end
      
    end % Loop over the 'keys'
    
    if isempty(pl.params)
      pl.params = [];
    end
    objs(ii) = pl;
  end % Loop over the objects.
  
  varargout{1} = objs;
end

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%                               Local Functions                               %
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% FUNCTION:    getInfo
%
% DESCRIPTION: Get Info Object
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

function ii = getInfo(varargin)
  if nargin == 1 && strcmpi(varargin{1}, 'None')
    sets = {};
    pl   = [];
  else
    sets = {'Default'};
    pl   = getDefaultPlist;
  end
  % Build info object
  ii = minfo(mfilename, 'plist', 'ltpda', utils.const.categories.helper, '$Id: remove.m,v 1.26 2011/04/08 08:56:21 hewitson Exp $', sets, pl);
  ii.setArgsmin(1);
end

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% FUNCTION:    getDefaultPlist
%
% DESCRIPTION: Get Default Plist
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


function pl = getDefaultPlist()
  
  pl = plist();
  
  % Key
  p = param({'key', 'The key of the parameter to remove.'}, paramValue.EMPTY_STRING);
  pl.append(p);
  
end