view m-toolbox/m/gui/ltpdv/callbacks/ltpdv_fcn_run.m @ 38:3aef676a1b20 database-connection-manager

Keep backtrace on error
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Mon, 05 Dec 2011 16:20:06 +0100
parents f0afece42f48
children
line wrap: on
line source

function ltpdv_fcn_run(varargin)
  % LTPDV_FCN_RUN runs the command on the selected panel
  %
  % M Hewitson 23-04-08
  %
  % $Id: ltpdv_fcn_run.m,v 1.4 2008/09/08 12:31:43 hewitson Exp $
  %

  % Get handles
  myh     = varargin{1};
  tag     = varargin{end-2};
  panH    = varargin{end-1};
  mainfig = varargin{end};

  % Get function
  switch tag
    case 'preproc'
      listtag = 'LTPDVpreprocfcnlist';
      ptag    = 'LTPDVpreprocparampan';
      fcns = ltpdv_preproc_function_list;
    case 'spectral'
      listtag = 'LTPDVspectralfcnlist';
      ptag    = 'LTPDVspectralparampan';
      fcns = ltpdv_spectral_function_list;
    otherwise
      error('### Unknown function set');
  end
  fcnh = findobj(panH, 'Tag', listtag);
  val  = get(fcnh, 'Value');
  strs = get(fcnh, 'String');
  fcn  = strs{val};

  idx = strcmp(fcn, fcns);
  idx = find(idx(:,2));
  fcn = fcns{idx,1};
  
  % Get params
  parampanh = findobj(panH, 'Tag', ptag);
  pl = ltpdv_get_params_from_panel(parampanh);

  % Get selected objects
  objs = ltpdv_get_selected_objs(mainfig);

  % Collect AOs
  as = [];
  for j=1:numel(objs)
    obj = objs{j};
    if isa(obj, 'ao')
      as = [as obj];
    else
      warning('!!! Skipping object %s - it''s not an AO', obj.name);
    end
  end

  % Evaluate fcn
  res = feval(fcn, as, pl);

  % Add result to object list
  for j=1:numel(res)
    objs = getappdata(mainfig, 'LTPDAobjects');
    setappdata(mainfig, 'LTPDAobjects', [objs {res(j)}]);
  end
  % Refresh object list
  ltpdv_refresh_object_list(mainfig);

end

  % END