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
|