]> git.donarmstrong.com Git - lilypond.git/blob - TODO
release: 0.1.49
[lilypond.git] / TODO
1 Features you cannot find in the doco as working, should be mentioned here.
2
3 This is an assorted collection of stuff that will be done, might be
4 done, or is an idea that I want to think about
5
6 Most of the items are marked in the code as well, with full explanation. 
7 grep for TODO and ugh/ugr
8
9 0.2:
10
11         * check for groff / troff/ nroff et
12
13         * use kpsepath to find all TeX dirs
14         - configure.in 
15         - clean-fonts.sh
16         
17         * nicen examples:
18         - remove all \multi
19         - break-up heavily-nested score blocks
20
21         * --metafont
22
23         * disable spaces in TeX stuff
24
25         * height of dyns.
26         
27         * handle ^C for tmp/file creation.
28
29         * WWW mirror/archive for the mailing lists.
30
31         * dots & rest collisions.
32
33         * add a screenshot to the website. :)
34
35         * documentation
36         - introduction?
37         - info?
38         - LaTeX?
39         - more manpages?
40
41         * naming Mozarella, Madeira, Muella?
42
43         * versioning for Feta
44
45         * bf: abbrevs over whole note
46
47         * the warning about the negative slur/tie length appears twice
48         which is irritating.
49
50         * The `3' in the meter key is a one or two pixels too thin (at 600dpi)
51         in the middle:
52
53         * better hshift (dots, distance, head dependent)
54
55         * tie/slur dir & curvature
56
57         * stem len adjustable
58
59         * mindist for spanners
60
61         
62
63 STUFF
64
65
66         * give Items/Spanners access to unbroken originals      
67
68         * scoping for properties
69
70         {       c4
71                 \multi 2  < { \stemup .. } { \stemdown .. } >
72                 c2 
73         }
74
75         this modifies \stem for the c2
76
77         * use properties for:
78         - Text_style
79         - default_octave
80         - plet?
81         - default_duration?
82         - default abbreviation
83         - Staff_sym size
84         - default tempo.
85         - font size
86         - bartypes (get rid of derived Span_bar_engravers)
87         - cadenza mode? 
88         - MIDI instrument
89         - staff title
90
91         * page handling:
92         - papersizes
93         - PS output
94         - optimal pagebreaking.
95
96         * put errorlevel in Input class
97
98         * AFM for font input?
99
100 3RD PARTY BUGS:
101
102         * gdb on RedHat 5
103
104         * xdvi: PS in magnifying glass.
105
106         * Fix profiling. gprof bugreport?
107
108 PROJECTS
109
110         * Unicode support?
111         - 16 bit Strings
112         - -u switch
113         - detect of 16/8 bit files
114         - examples to go with it.
115
116         * Spring_spacer:
117         - write a faster Spring_spacer (without matrices if possible)
118         - use straight LP to find minimal "fitting force"
119         - relate energybound to linelen unitspace fontsize etc.
120         - used fixed point fp
121
122         * \header
123         - output header info to MIDI too.
124
125
126         * Makefile stuff:
127         - shared lib on Solaris too.
128         - check libtool
129
130         * Add mudela-output to Rosegarden.
131
132         * a musical dictionary. See Documentation/vocabulary-*, other
133 languages:
134         - italian
135         - german
136         - dutch
137         - swedish
138          .. ?
139
140         * chords
141         - guitar chords
142         - chord names
143         - basso continuo
144         - Syntax/parser
145         - MIDI output?
146         - typesetting
147
148         * integrate midi-elts from mi2mu and lily?
149
150         * Debug logs:
151         - derive lily_stream, Dstream, texstream from ostream?
152         - indentable stream as baseclass for TeX stream, lily stream, Dstream.
153         - use dstream feature in mi2mu
154         - integrate IO checking into stream class
155
156         * input converters
157         - NIFF?
158         - ABC? 
159         - SMDL?
160
161         * add to MIDI output:
162         - tempo change
163         - repeat
164         - slurs
165         - dynamics etc.
166
167         * grace notes
168         - make separate class for Grace_*_engravers 
169         (which is at Voice_gravs level)
170         - make encapsulated spacing problems.
171
172         * On-demand loading of simple-engravers?
173
174         * accidentals per Voice_group
175
176         * Convert all ref/bib stuff into BibTeX.
177
178         * Output class, handles : (smallish)
179         - help text /(c) notice?
180         - version line
181         - warning /errors/progress
182         - abort on error/warning; exit status
183         - quiet/ignore-version options
184         - logfile output
185
186         * piano staff
187
188         * elaborate Staff_side baseclass:
189         - scripts
190         - text
191         - slur start/end
192
193         * cautionary accidental
194
195         * Output an output format independent (ofi) typeset file; and 
196           make ofi2 TeX, MusiXTex, Display PostScript, PostScript,
197           Ascii... interpreters. (difficult)
198
199         - poor man's ascii output possible?
200         - MusiXTeX output possible? (would have to be done before break calc.)
201         - NIFF ?
202         - Common Music Notation
203         - PostScript output (esp. Beams, Slurs, etc)
204         - Move all Score_elems, into libmutype.a
205  
206         * Documentation
207         - Doc Mutopia (Music To The People) 
208         - Doc (C) stuff of sheet music
209         - a better format?  SGML?  TeX?  Info?
210         - a tutorial
211
212         * TeX spanners , use texbeam.cc as an example (smallish)
213         - Glissando
214         - trill
215         - bracket
216
217         * Rewrite Stem, Beam and Rhythmic_grouping (hairy)
218         - [c8. c32 c32]
219         - doc on Rhythmic_grouping
220         - general shaving on Beam and Stem
221         - use plet grouping
222         - separate visual from rhythmic info even more
223         - beams over bars
224
225         * Redo fonts
226         - adapt for multiple font sizes.
227
228         * lines:
229         - Ledger lines, should be separate item: Ledger_lines, Ledger_lines
230         - set different line sizes / thicknesses
231         - beam stem showthrough, inter beam sizes (french vs german style)
232
233         * Collisions
234         - left/right note balls should be handled by Collision:
235         < \multi 2; { \stem 1; <b c> } { <f as b> } >
236
237         * Keys:
238         - merge key{item} & localkey{item}?
239         - do conventional keys (C G A, F B E, a e fis, d as des, etc ), 
240           besides lists of flats/sharps, possibly via declaration
241         - key transposition. 
242         - key undo: \key bes; .. . \key; should print natural   
243         - special key: \key bes 'b bis';
244         - spacing, national styles?
245
246         * Support for TAB
247         - redo Notehead to allow digits as heads
248         - add a \tablature {} lexer mode for easy entering
249
250         * should adjust stemlength for flag number.
251
252         * breaking:
253         - caching breakpoints
254         - saving them
255         - allowing users to set them.
256         - penalties
257         - specify number of lines
258
259         * Rhythmic staff.
260
261         * Baroque superstaff
262
263 SEVERELY LACKING:
264
265         * SPEED!
266
267         * multibar rests
268
269         * markers
270
271
272 INPUTLANGUAGE
273
274         * c4 4 4 4 for c4 c4 c4 c4?
275
276         * neatly (and readably) expressing concurrent
277         voices
278
279         * <c f a>4 ?
280
281         * Viola mode?
282
283                 @c c g e g 
284         for
285                 c g es g, 
286
287                 @A c g e g
288         for
289                 cis gis e gis
290
291         * relative mode for pitch entering
292
293         * bracket (bracketplets)
294
295         * configure pitch_byte
296
297         * rest name configurable
298
299         * Raw request syntax
300
301 SMALLISH PROJECTS
302
303         * progress when creating MIDI elts.
304
305         * A range for context errors (eg. mark both { and }. )
306
307         * lyric in staff  (sharpsharp in staff, text below)
308
309         * write Dynamic_line (to group dynamics horizontally)
310
311         * use Real for all y positions.
312         - use translate_axis( .. ,Y_AXIS) 
313
314         * half-sharps, half-flats
315
316         * adaptive accidental spacing.
317
318         * handle EOF graciously in error messages.
319
320         * caching Item/spanner dimensions.
321
322         * centered whole rest
323
324         * qtor, btor, mtor-> tor( QUIET_ver ), tor( DEBUG_ver ), etc.
325         - use tors feature in lily (?)
326
327         * declare notenametab?
328
329         * midi esp.: use I32 iso int where 32 bits are needed (or assumed...)
330
331         * Flower types:
332         - A decent scalar type
333         - String hash
334         - Pointer hash
335
336         * binsearch/hash for identifiers
337
338         * stafftypes: voice names/ instrument names.
339
340         * TeX stuff:    
341         - Decent TeX titledefs (\tempo, \metron, etc. )
342         - decent TeX page layout
343
344         * lily \tempo
345
346         * C meter iso 4/4, idem for alla breve, etc.
347
348         * textspanner: center position
349
350         * Brackets
351         
352         * Scripts:
353         - stack scripts in chords:
354           % fingering:        footing:
355             < a-4 c-2 g-1 >   < c-\ltoe e-\lheel >
356         - script-spacing
357         - slur parts as a script
358         - stack parameterised scripts for fingering and footing:
359
360             % toe to bheel   four to five
361             %   ^_u            4_5  
362             %     -                           
363             %  --|x--         --|x--
364             %  --|---         --|---
365             %  --|---         --|---
366           (where "to" is a tiny bow)
367
368         * auxilliary file for caching info.
369
370         * Text_crescendo
371
372         * clean solution for staffsize in items.
373
374         * revise calcideal
375
376         * volta
377
378 IDEAS
379
380         * Output abstract data structures associated with
381 Mudela.
382
383         * create libmudela, or liblily_frontend
384
385         * move MIDI stuff (including Quantization) to a ANSI C libmidi library.
386
387         * use an embedded language: Python, Scheme
388         for: 
389                 - Score_elems
390                 - Engraver
391                 - Translators
392                 - Complex mudela?
393
394         * y -dims in internote? Staff-space? X-dimensions?
395
396         * Spacing_request for manually adjusting spacing
397
398         * caching breakpoints
399
400         * #c <-> cis
401
402         * breath marks 
403
404         * used fixedpoint arithmetic for min. energy.
405
406         * move towards incremental algorithms.
407
408         * far fetched language ideas
409         - design meta-language like TeX and Metafont
410         - programming/macros input
411
412         * Global type registration.
413
414                 My_class * p = create_object( My_class )
415                 Type t = get_type ( *p );
416                 if ( t <= get_type( q ))
417                         ..
418
419         * naming of Voice_group/Voice
420
421         * versioning stuff (cvt mudela, mudela, etc.)
422
423         * a real convert-mudela
424
425         * dots into separate item.
426
427         * use String iso Text_def for lyrics.
428
429         * Klavarskribo?
430
431         * lyrics in chords still fuck up.
432
433         * rewire acknowledge_element() logic with a process_acknowledged()
434
435         * pushgroup/popgroup
436
437         * multi threading?
438           - 1 thread per element/ 1 thread per line
439           - 1 thread per Translator
440
441         * Use hooks/dependency graphs for properties