Mercurial > hg > ltpda
view m-toolbox/classes/+utils/@modules/buildModule.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
% BUILDMODULE builds a new module structure in the location specified by % the user. % % CALL: utils.modules.buildModule(dir, module_name) % % INPUTS: % dir - the directory in which to build the module % module_name - a name for the new module % % Example: % % utils.modules.buildModule('~/work', 'myNewModule') % % % The resulting module structure on disk looks like: % % module/ % |- classes % |- functions % |- jar % |- models % |- tests % |- classes % |- models % % % M Hewitson 21-01-11 % % $Id: buildModule.m,v 1.4 2011/03/28 11:26:57 hewitson Exp $ % function varargout = buildModule(varargin) if nargin ~= 2 help(['utils.modules.' mfilename]); error('incorrect inputs'); end % Inputs mdir = varargin{1}; if ~ischar(mdir) error('The first input should be a string indicating a directory on disk'); end mname = varargin{2}; if ~ischar(mname) error('The second input should be a string indicating the module name'); end % Make module mpath = fullfile(mdir, mname); paths = {'classes', 'functions', 'jar', 'models', 'pipelines', 'examples', 'tests', ... fullfile('tests', 'classes'), fullfile('tests', 'models')}; % Check if the directory for the new module exists if isdir(mpath) r = input(sprintf('A directory exists at the chosen location (%s). \nDo you want to overwrite it? (yes/no) ', mpath), 's'); if ~strcmpi(r, 'yes') return; end end % Make module dir [success,message,messageid] = mkdir(mdir,mname); if ~success error(messageid, 'Failed to make module directory. %s', message); end % Make all the sub directories for kk=1:numel(paths) p = paths{kk}; [success,message,messageid] = mkdir(mpath, p); if ~success error(messageid, 'Failed to make module directory %s.\n %s', fullfile(mpath, p), message); end end % create README fd = fopen(fullfile(mpath, 'README.txt'), 'w+'); fprintf(fd, 'LTPDA Module %s\n', mname); fprintf(fd, '\n'); fprintf(fd, '\n'); fprintf(fd, 'For further details see the following README files:\n'); fprintf(fd, ' classes/README_classes.txt\n'); fprintf(fd, ' functions/README_functions.txt\n'); fprintf(fd, ' jar/README_jar.txt\n'); fprintf(fd, ' models/README_models.txt\n'); fprintf(fd, ' pipelines/README_pipelines.txt\n'); fprintf(fd, ' tests/README_tests.txt\n'); fprintf(fd, ' tests/classes/README_class_tests.txt\n'); fprintf(fd, ' tests/models/README_model_tests.txt\n'); fprintf(fd, '\n'); fprintf(fd, '\n'); % copy in the README files src = fileparts(which('utils.modules.buildModule')); installREADME(src, 'README_classes.txt', mpath, 'classes'); installREADME(src, 'README_functions.txt', mpath, 'functions'); installREADME(src, 'README_jar.txt', mpath, 'jar'); installREADME(src, 'README_models.txt', mpath, 'models'); installREADME(src, 'README_pipelines.txt', mpath, 'pipelines'); installREADME(src, 'README_tests.txt', mpath, 'tests'); installREADME(src, 'README_class_tests.txt', mpath, fullfile('tests', 'classes')); installREADME(src, 'README_model_tests.txt', mpath, fullfile('tests', 'models')); % Write moduleinfo.xml writeModuleInfoXML(mpath, mname); ls(mpath) fprintf('* Module built successfully at %s\n', mpath); end function writeModuleInfoXML(mpath, name) docNode = com.mathworks.xml.XMLUtils.createDocument('moduleinfo'); docRootNode = docNode.getDocumentElement; docRootNode.setAttribute('name',name); docRootNode.setAttribute('version','1.0'); % Save the sample XML document. xmlFileName = fullfile(mpath,'moduleinfo.xml'); xmlwrite(xmlFileName,docNode); end function installREADME(src, name, mpath, mdir) src = fullfile(src, name); dest = fullfile(mpath, mdir); [success,message,messageid] = copyfile(src, dest); if ~success error(messageid, 'Failed to copy %s to %s', src, dest); end end % END