Added support for the extended commands 'midi_channel' and 'midi_program'
[ahxm.git] / TODO
blobe5f4f3be2d678416da472391c16ef52ae2c31a86
1 Ann Hell Ex Machina TODO / Bug List
2 ===================================
4 Release Critical Bugs
5 ---------------------
7  * 1017: mp_doccer documentation is severely outdated.
8  * 1022: Add file name to compiler errors.
9  * 1030: Refactorize the output system to always use a forked process.
10  * 1032: Refactorize input, ss_gen and ss_ins to always use pointers to
11    struct ss_wave instead of copies of them.
12  * 1040: Get rid of all _ prefixed symbols.
13  * 1041: Consider the possibility to avoid having #define CHANNELS at all
14    and always use it as dynamic structures or buffers.
16 Open Bugs
17 ---------
19  * 1034: tempo_from_wave() will never work; when the wave is loaded, it's
20    too late for the tempo to be set, as the ss_song stream has no tempo
21    information. The only solution is to just print the optimal tempo, for
22    the ahxm programmer to change it manually.
24 Pending Enhancements
25 --------------------
27  * 1002: Build an audio filtering tool to test effects.
28  * 1003: There should exist 'some kind' of effect for note volumes
29    to add a random variation, to add 'humanity'. This cannot
30    be a standard digital effect as it should be different
31    for each note.
32  * 1005: Vibrato should be variable (from 'no-vibrato' to 'some-vibrato'
33    in the same note).
34  * 1006: A 'choose' option, to take randomly one block or another
35    (blocks seem appropriate, but further study is necessary). A random
36    seed script command is also necessary.
37  * 1007: Support for 'tonalities'; fixed transpositions for each note of
38    the octave so that, for example, a 'f' is always a 'f#'.
39  * 1008: Support for 'keyboard splits': ranges of notes that a track will
40    ignore. This should allow to have multiple tracks playing the same
41    notes but with different channel maps and, for example, having a
42    guitar glissando pan from left to right.
43  * 1010: Loop stretching ('stretch wave without pitch change to last
44    exactly N time units').
45  * 1011: Loop matching ('change wave pitch to last exactly N time units').
46  * 1020: When a source file includes multiple songs, there should exist a
47    way to mark song / track changes. This should be used to include text
48    messages as ID3 tags or even to generate .cue / .toc files.
50 Closed
51 ------
53  * 1000: Convert current event queue to two event queues. The first
54    stage queue should store notes and the second note on / note off
55    events (Tue, 17 Aug 2004 12:00:00 +0200).
56  * 1004: Vibrato for generators (Fri, 13 Aug 2004 11:05:00 +0200).
57  * 1009: Set tempo from a sample loop ('set tempo so that this wave
58    will match exactly one/N measures') (Fri, 16 Aug 2004 18:08:00 +0200).
59  * 1013: Volume should be a command ('v', for example) and not be
60    inherited from previous notes. There should also be settable as
61    relative inc/decrements (as octaves) (Mon, 30 Aug 2004 14:37:59 +0200).
62  * 1014: doc/language.txt is severely outdated
63    (Mon, 30 Aug 2004 15:13:00 +0200)
64  * 1015: Upgrade build system (new config.sh, makefile.in, etc.).
65    (Thu, 09 Sep 2004 18:56:29 +0200).
66  * 1016: Integrate the new compiler (Sun, 12 Sep 2004 16:13:11 +0200).
67  * 1001: Generator should use queues of active / free generators.
68    (Sun, 17 Oct 2004 12:50:10 +0200).
69  * 1012: Portamento should not have a 'time', only a frequency
70    inc/decrement per time unit (Sun, 17 Oct 2004 13:18:04 +0200).
71  * 1018: The 'default' driver should not be bound to the first usable
72    one, but be a sequential try of all available drivers
73    (Thu, 11 Nov 2004 12:18:12 +0100).
74  * 1019: Add libartsc support (Thu, 11 Nov 2004 12:30:02 +0100).
75  * 1023: The SS_FRAMES lex/yacc token should be SS_MSECS, that is,
76    the compiler should not use frames but milliseconds
77    (Tue, 19 Apr 2005 20:05:46 +0200).
78  * 1024: The 'event1' and 'event2' stuff is ugly. It should be called,
79    respectively, 'note stream' (as it's, more or less, device independent)
80    and 'ss stream', which depends of softsynth, frames and such. In the
81    future, there could exist a 'midi stream' if MIDI output is supported
82    (Closed by #1025; Wed, 20 Apr 2005 17:30:31 +0200).
83  * 1033: SONG_EV_SS_NOTE won't work, because freq can't be calculated
84    on compilation time; instead, it should be a generic message
85    (Sat, 23 Apr 2005 10:52:35 +0200).
86  * 1026: Get rid of event.c and event.h (Sat, 23 Apr 2005 12:28:47 +0200).
87  * 1027: Get rid of effect.c and effect.h (Sat, 23 Apr 2005 12:28:51 +0200).
88  * 1031: Add lex/yacc code for processing absolute notes (A1, C#4, F&3)
89    (Sat, 23 Apr 2005 16:14:21 +0200).
90  * 1036: Unify song event types; ss_song should use the same event types
91    (Sun, 24 Apr 2005 10:29:22 +0200).
92  * 1035: The number of compiled tracks should be available somewhere
93    (Sun, 24 Apr 2005 10:35:19 +0200).
94  * 1037: ss_ins_frame() is flawed; as it directly mixes into frame[],
95    each intrument's ss effects affect the previous ones
96    (Mon, 25 Apr 2005 16:42:28 +0200).
97  * 1025: 'event1' has been moved to song.c (generic song event stream)
98    and 'event2' has been moved to ss_song.c (softsynth song event stream),
99    but due to almost all of ss_song.c being private, there is no way to
100    order the instruments and the effects to do anything until a way of
101    storing them is decided. So, project state is really critical now as
102    nothing works (last working version was 'cvs update -D 20050419').
103    (Mon, 25 Apr 2005 18:16:48 +0200).
104  * 1039: Volumes can't be set as integer numbers (0 and 1 should be valid)
105    (Mon, 25 Apr 2005 18:26:06 +0200).
106  * 1038: Comments can't be written inside extended commands
107    (Mon, 25 Apr 2005 18:31:55 +0200).
108  * 1021: Add line number to compiler errors (Mon, 25 Apr 2005 19:11:01 +0200).
109  * 1028: input.c should be ss_input.c (Wed, 27 Apr 2005 08:08:49 +0200).
110  * 1029: output.c should be ss_output.c (Wed, 27 Apr 2005 16:59:34 +0200).
112 Email bugs to angel@triptico.com