diff m-toolbox/classes/@LTPDAworkbench/cb_exportWS.m @ 0:f0afece42f48

Import.
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Wed, 23 Nov 2011 19:22:13 +0100
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/m-toolbox/classes/@LTPDAworkbench/cb_exportWS.m	Wed Nov 23 19:22:13 2011 +0100
@@ -0,0 +1,74 @@
+% CB_EXPORTWS stores the selected blocks outputs to the workspace
+%
+% CALL: LTPDAworkbench.cb_exportWS
+%
+% M Hewitson 13-11-08
+%
+% $Id: cb_exportWS.m,v 1.5 2010/08/06 19:10:48 ingo Exp $
+%
+function cb_exportWS(varargin)
+  
+  wb = varargin{1};
+  
+  % Get all selected blocks
+  sbs = awtinvoke(wb.mp, 'getSelectedBlocks');
+  
+  outvars = {};
+  for ii=0:sbs.size()-1
+    block = sbs.get(ii);
+    
+    % if this is a MElementWithPorts
+    if isa(block, 'mpipeline.canvas.MElementWithPorts')
+      
+      % loop over all outputs
+      outports = block.getOutputs();
+      for kk=0:outports.size()-1
+        op = outports.get(kk);
+        % get variable name
+        outvar = LTPDAworkbench.getWS_VarName(wb.UUID, block, op.getNumber);
+        outvars = [outvars {outvar}];
+      end
+    end
+  end
+  
+  % Check if each var exists in the workspace, and then store in workspace
+  try
+    for kk=1:numel(outvars)
+      
+      % get class of the object
+      cl = evalin('base', [ 'class(' outvars{kk} ')']);
+      
+      % get new var name
+      %   - this means split the outvar at the last '.'
+      nv = getVar(outvars{kk});
+      
+      if ismember(cl, utils.helper.ltpda_userclasses)
+%         cmd  = [nv ' = ' cl '(' outvars{kk} ');'];
+        cmd  = [nv ' = copy(' outvars{kk} ',1);'];
+      else
+        cmd  = [nv ' = ' outvars{kk} ';'];
+      end
+      evalin('base', cmd);
+    end
+  catch
+    utils.helper.errorDlg('Unable to export selected objects. Has the pipeline been executed?', 'Export to workspace error');
+  end
+  
+  
+end
+
+function nv = getVar(ov)
+  
+  nv = '';
+  
+  for kk=length(ov):-1:1
+    if ov(kk) == '.'
+      break
+    else
+      nv = [nv ov(kk)];
+    end
+  end
+  
+  nv = nv(end:-1:1);
+  
+end