Mercurial > hg > ltpda
view m-toolbox/classes/@workspaceBrowser/retrieveObjectsFromDialog.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 | 317b5f447f3e |
children |
line wrap: on
line source
function retrieveObjectsFromDialog(varargin) if ~isa(varargin{1}, 'mpipeline.repository.RepositoryRetrieveDialog') error('### The first input must be a mpipeline.repository.RepositoryRetrieveDialog'); end if ~isa(varargin{2}, 'java.sql.Connection') error('### The first input must be a java.sql.Connection'); end qb = varargin{1}; conn = varargin{2}; % Get object IDs obj_ids = qb.getObjectIDs; col_ids = qb.getCollectionIDs; if isempty(obj_ids) && isempty(col_ids) utils.helper.errorDlg('Please enter either a object ID or a collection ID.'); return end % object prefix obj_prefix = char(qb.getObjectPrefix); % append object type? appendObjectType = qb.appendObjectType; % binary retrieval? binaryRetrieval = qb.useBinaryRetrieval; % file extension fileext = qb.getSaveFileExtension; [objs, obj_names] = retrieveObjects(conn, obj_ids, col_ids, binaryRetrieval, obj_prefix, appendObjectType); if qb.isSaveObjects save_objects(objs, obj_names, fileext); else import_objects(objs, obj_names); end end function save_objects(objs, obj_names, fileext) for j=1:length(objs) if isvarname(obj_names{j}) save(objs{j}, [obj_names{j} char(fileext)]); else utils.helper.errorDlg('Can not save the object(s) because you used a not valid prefix name.'); end end end function import_objects(objs, obj_names) for j=1:length(objs) if isvarname(obj_names{j}) assignin('base', obj_names{j}, objs{j}); else utils.helper.errorDlg('Can not import the object(s) because you used a not valid prefix name.'); end end end function [objs, obj_names] = retrieveObjects(conn, ids, cids, retrieveBinary, prefix, appendObj) %--------------------------------------------------------------- % Retrieve these ids objs = {}; obj_names = {}; for j=1:length(ids) disp(sprintf('+ retrieving object %d', ids(j))); % determine object type try tt = utils.repository.getObjectType(conn, ids(j)); catch utils.helper.errorDlg('Object type is unknown. Does this object really exist?'); return end objname = sprintf('%s%03d', prefix, ids(j)); if appendObj objname = [objname '_' tt]; end obj_names = [obj_names {objname}]; % Retrieve object pl = plist('id', ids(j), 'conn', conn); if retrieveBinary pl.append('binary', 'yes'); end obj = eval(sprintf('%s(pl);', tt)); objs = [objs {obj}]; end %--------------------------------------------------------------- % Retrieve these Collections for k=1:length(cids) % get Ids from Cid ids = utils.repository.getCollectionIDs(conn, cids(k)); if isempty(ids) error('### This collection doesn''t seem to exist.'); end for j=1:length(ids) disp(sprintf('+ retrieving collection %d : %d', cids(k), ids(j))); tt = utils.repository.getObjectType(conn, ids(j)); if ismember(tt, utils.helper.ltpda_userclasses) % Retrieve object pl = plist('id', ids(j), 'conn', conn); obj = eval(sprintf('%s(pl);', tt)); objname = sprintf('%sC%03d_%03d', prefix, cids(k), ids(j)); if appendObj objname = [objname '_' tt]; end obj_names = [obj_names {objname}]; objs = [objs {obj}]; else warning('!!! Objects of type %s are no longer considered user objects and can not be retrieved.', tt); end end end end