annotate chordtools/parseintervals.m @ 1:8973548174c1 tip

adding tools to repo
author christopherh
date Mon, 06 May 2013 14:43:47 +0100
parents
children
rev   line source
christopherh@1 1 %
christopherh@1 2 % PARSEINTERVALS
christopherh@1 3 %
christopherh@1 4 % [parintervals, success, errormessage] = parseintervals(interval_list, {verbose})
christopherh@1 5 %
christopherh@1 6 % Parses a comma delimited list of intervals to an array of degrees, their
christopherh@1 7 % associated accidentals and whether or not they are present (presence
christopherh@1 8 % denoted by a '*' in front of an interval in the input interval_list).
christopherh@1 9 %
christopherh@1 10 % Success = 1 if symbols parsed correctly, 0 otherwise.
christopherh@1 11 %
christopherh@1 12 % If optional argument 'verbose' is 1, function prints any errormessage to
christopherh@1 13 % the screen.
christopherh@1 14 %
christopherh@1 15 % calls parseinterval
christopherh@1 16 %
christopherh@1 17 % returns: intervals (array of int: [degree,accidental,present])
christopherh@1 18 % success (boolean)
christopherh@1 19 % errormessage (string)
christopherh@1 20 %
christopherh@1 21 %
christopherh@1 22 % Author: Christopher Harte, March 2009
christopherh@1 23 %
christopherh@1 24 % Copyright: Centre for Digital Music, Queen Mary University of London 2005
christopherh@1 25 %
christopherh@1 26 % This file is part of the C4DM Chord Toolkit V2.0
christopherh@1 27 %
christopherh@1 28 % The C4DM Chord Toolkit is free software; you can redistribute it and/or
christopherh@1 29 % modify it under the terms of the GNU General Public License as published
christopherh@1 30 % by the Free Software Foundation; either version 2 of the License, or
christopherh@1 31 % (at your option) any later version.
christopherh@1 32 %
christopherh@1 33 % The C4DM Chord Toolkit is distributed in the hope that it will be useful,
christopherh@1 34 % but WITHOUT ANY WARRANTY; without even the implied warranty of
christopherh@1 35 % MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
christopherh@1 36 % GNU General Public License for more details.
christopherh@1 37 %
christopherh@1 38 % You should have received a copy of the GNU General Public License
christopherh@1 39 % along with the C4DM Toolkit; if not, write to the Free Software
christopherh@1 40 % Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
christopherh@1 41
christopherh@1 42 %
christopherh@1 43 function [parintervals, success, errormessage] = parseintervals(interval_list, verbose)
christopherh@1 44
christopherh@1 45 % set verbose default to 0
christopherh@1 46 if nargin < 2
christopherh@1 47 verbose = 0;
christopherh@1 48 end
christopherh@1 49
christopherh@1 50 errormessage = '';
christopherh@1 51
christopherh@1 52 ilength = length(interval_list);
christopherh@1 53
christopherh@1 54 index = 1;
christopherh@1 55
christopherh@1 56 tempindex = 1;
christopherh@1 57
christopherh@1 58 tempstring = '';
christopherh@1 59
christopherh@1 60 success = 1;
christopherh@1 61
christopherh@1 62 parindex = 1;
christopherh@1 63
christopherh@1 64 parintervals = [];
christopherh@1 65
christopherh@1 66
christopherh@1 67 while index <= ilength
christopherh@1 68
christopherh@1 69
christopherh@1 70 while (interval_list(index) ~= ',')
christopherh@1 71
christopherh@1 72 tempstring(tempindex) = interval_list(index);
christopherh@1 73 tempindex = tempindex +1;
christopherh@1 74 index = index + 1;
christopherh@1 75
christopherh@1 76 if(index > ilength)
christopherh@1 77 break;
christopherh@1 78 end
christopherh@1 79
christopherh@1 80 if (interval_list(index) == ',') && (index == ilength)
christopherh@1 81 success = 0;
christopherh@1 82 errormessage = sprintf(['Error in parseintervals: interval list finishes with a comma "' interval_list '"\n']);
christopherh@1 83 end
christopherh@1 84
christopherh@1 85
christopherh@1 86 end
christopherh@1 87
christopherh@1 88 [parintervals(parindex,1),parintervals(parindex,2),parintervals(parindex,3),ok, error] = parseinterval(tempstring);
christopherh@1 89 % concatenate error messages if there are any...
christopherh@1 90 errormessage = [errormessage error];
christopherh@1 91
christopherh@1 92 if(ok == 1)
christopherh@1 93 tempstring = '';
christopherh@1 94 tempindex = 1;
christopherh@1 95 parindex = parindex + 1;
christopherh@1 96 index = index + 1;
christopherh@1 97 else
christopherh@1 98
christopherh@1 99 errormessage = [errormessage sprintf(['Error in parseintervals: incorrect interval in list "' interval_list '"\n'])];
christopherh@1 100 success = 0;
christopherh@1 101 index = ilength +1;
christopherh@1 102 end
christopherh@1 103
christopherh@1 104
christopherh@1 105 end
christopherh@1 106
christopherh@1 107 if (success == 0) && (verbose == 1)
christopherh@1 108
christopherh@1 109 fprintf(1,errormessage)
christopherh@1 110
christopherh@1 111 end
christopherh@1 112
christopherh@1 113
christopherh@1 114
christopherh@1 115
christopherh@1 116
christopherh@1 117
christopherh@1 118
christopherh@1 119
christopherh@1 120
christopherh@1 121