view m-toolbox/classes/+utils/@xml/read_sinfo_xml.m @ 44:409a22968d5e default

Add unit tests
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Tue, 06 Dec 2011 18:42:11 +0100
parents f0afece42f48
children
line wrap: on
line source

% READ_SINFO_XML reads a submission info struct from a simple XML file.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%
% READ_SINFO_XML reads a submission info struct from a simple XML file.
% 
%  CALL:   sinfo = utils.helper.read_sinfo_xml(file)
% 
% The XML file should have a main node called 'submission_info'. Then all
% sub-nodes supported by the sinfo fields will be read. 
% 
% For example:
% 
% <submission_info>
%   <experiment_title>
%   some nice experiment we can use
%   </experiment_title>
%   <experiment_description>
%   Some nice experiment we did with some crazy results.
%   But sometimes it takes a new line to describe in detail.
%   </experiment_description>
% </submission_info>
% 
% Supported fields:
% 
% 'experiment_title'
% 'experiment_description'
% 'analysis_description'
% 'quantity'
% 'keywords'
% 'reference_ids'
% 'additional_comments'
% 'additional_authors'
%
% M Hewitson 08-02-10
% 
% $Id: read_sinfo_xml.m,v 1.1 2010/04/19 14:31:05 ingo Exp $
% 

function pl = read_sinfo_xml(file)
  
  xdoc = xmlread(file);
  
  fields = {'experiment_title', ...
    'experiment_description', ...
    'analysis_description', ...
    'quantity', ...
    'keywords', ...
    'reference_ids', ...
    'additional_comments',...
    'additional_authors'};
  
  pl = plist();
  % Look for a submission info node
  for ii=1:xdoc.getLength
    item = xdoc.item(ii-1);
    if strcmp(char(item.getNodeName), 'submission_info')      
      % Now get all the fields
      for kk=1:item.getLength
        node = item.item(kk-1);        
        name = char(node.getNodeName);
        if any(strcmp(name, fields))
          pl.append(name, strtrim(char(node.getTextContent)));
        end
      end
    end
  end
  
end