mirror of
https://github.com/microtherion/VocalEasel.git
synced 2025-01-14 22:24:00 +00:00
220 lines
5.0 KiB
Python
220 lines
5.0 KiB
Python
|
|
||
|
# docs.py
|
||
|
|
||
|
"""
|
||
|
This module is an integeral part of the program
|
||
|
MMA - Musical Midi Accompaniment.
|
||
|
|
||
|
This program is free software; you can redistribute it and/or modify
|
||
|
it under the terms of the GNU General Public License as published by
|
||
|
the Free Software Foundation; either version 2 of the License, or
|
||
|
(at your option) any later version.
|
||
|
|
||
|
This program is distributed in the hope that it will be useful,
|
||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
GNU General Public License for more details.
|
||
|
|
||
|
You should have received a copy of the GNU General Public License
|
||
|
along with this program; if not, write to the Free Software
|
||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||
|
|
||
|
Bob van der Poel <bvdp@xplornet.com>
|
||
|
|
||
|
"""
|
||
|
|
||
|
import os
|
||
|
import time
|
||
|
|
||
|
import gbl
|
||
|
from MMA.common import *
|
||
|
import MMA.midiC
|
||
|
|
||
|
|
||
|
def docDrumNames(order):
|
||
|
""" Print LaTex table of drum names. """
|
||
|
|
||
|
notenames = ['E\\flat', 'E', 'F', 'G\\flat', 'G', 'A\\flat',
|
||
|
'A', 'B\\flat', 'B', 'C', 'D\\flat', 'D'] * 5
|
||
|
|
||
|
n=zip( MMA.midiC.drumNames, range(27,len(MMA.midiC.drumNames)+27), notenames )
|
||
|
|
||
|
if order == "a":
|
||
|
for a,v,m in sorted(n):
|
||
|
print "\\insline{%s} {%s$^{%s}$}" % (a, v, m )
|
||
|
|
||
|
else:
|
||
|
for a,v,m in n:
|
||
|
print "\\insline{%s} {%s$^{%s}$}" % (v, a, m)
|
||
|
|
||
|
def docCtrlNames(order):
|
||
|
""" Print LaTex table of MIDI controller names. """
|
||
|
|
||
|
n=zip( MMA.midiC.ctrlNames, range(len(MMA.midiC.ctrlNames)) )
|
||
|
|
||
|
if order == "a":
|
||
|
for a,v in sorted(n):
|
||
|
print "\\insline{%s} {%02x}" % (a, v)
|
||
|
|
||
|
else:
|
||
|
for a,v in n:
|
||
|
print "\\insline{%02x} {%s}" % (v, a)
|
||
|
|
||
|
def docInstNames(order):
|
||
|
""" Print LaTex table of instrument names. """
|
||
|
|
||
|
n=zip( MMA.midiC.voiceNames, range(len(MMA.midiC.voiceNames)) )
|
||
|
if order == "a":
|
||
|
for a,v in sorted(n):
|
||
|
a=a.replace('&', '\&')
|
||
|
print "\\insline{%s} {%s}" % (a, v)
|
||
|
|
||
|
else:
|
||
|
for a,v in n:
|
||
|
a=a.replace('&', '\&')
|
||
|
print "\\insline{%s} {%s}" % (v, a)
|
||
|
|
||
|
|
||
|
""" Whenever MMA encounters a DOC command, or if it defines
|
||
|
a groove with DEFGROOVE it calls the docAdd() function.
|
||
|
|
||
|
The saved docs are printed to stdout with the docDump() command.
|
||
|
This is called whenever parse() encounters an EOF.
|
||
|
|
||
|
Both routines are ignored if the -Dx command line option has
|
||
|
not been set.
|
||
|
|
||
|
Storage is done is in the following arrays.
|
||
|
"""
|
||
|
|
||
|
fname = ''
|
||
|
author=""
|
||
|
notes=""
|
||
|
defs=[]
|
||
|
|
||
|
def docAuthor(ln):
|
||
|
global author
|
||
|
|
||
|
author = ' '.join(ln)
|
||
|
|
||
|
|
||
|
def docNote(ln):
|
||
|
""" Add a doc line. """
|
||
|
|
||
|
global fname, notes
|
||
|
|
||
|
if not gbl.docs or not ln:
|
||
|
return
|
||
|
|
||
|
# Grab the arg and data, save it
|
||
|
|
||
|
fname = os.path.basename(gbl.inpath.fname)
|
||
|
if notes:
|
||
|
notes += ' '
|
||
|
notes += ' '.join(ln)
|
||
|
|
||
|
|
||
|
def docDefine(ln):
|
||
|
""" Save a DEFGROOVE comment string.
|
||
|
|
||
|
Entries are stored as a list. Each item in the list is
|
||
|
complete groove def looking like:
|
||
|
defs[ [ Name, Seqsize, Description, [ [TRACK,INST]...]] ...]
|
||
|
|
||
|
"""
|
||
|
|
||
|
global defs
|
||
|
|
||
|
l = [ ln[0], gbl.seqSize, ' '.join(ln[1:]) ]
|
||
|
for a in sorted(gbl.tnames.keys()):
|
||
|
c=gbl.tnames[a]
|
||
|
if c.sequence and len(c.sequence) != c.sequence.count(None):
|
||
|
if c.vtype=='DRUM':
|
||
|
v=MMA.midiC.valueToDrum(c.toneList[0])
|
||
|
else:
|
||
|
v=MMA.midiC.valueToInst(c.voice[0])
|
||
|
l.append( [c.name, v ] )
|
||
|
|
||
|
defs.append(l)
|
||
|
|
||
|
def docDump():
|
||
|
""" Print the LaTex docs. """
|
||
|
|
||
|
global fname, author, notes, defs
|
||
|
|
||
|
if gbl.docs == 1: # latex docs
|
||
|
if notes:
|
||
|
if fname.endswith(gbl.ext):
|
||
|
fname='.'.join(fname.split('.')[:-1])
|
||
|
print "\\filehead{%s}{%s}" % (totex(fname), totex(notes))
|
||
|
print
|
||
|
|
||
|
if defs:
|
||
|
for l in defs:
|
||
|
print " \\instable{%s}{%s}{%s}{" % \
|
||
|
(totex(l[0]), totex(l[2]), l[1] )
|
||
|
for c,v in l[3:]:
|
||
|
print " \\insline{%s}{%s}" % (c.title(), totex(v))
|
||
|
print " }"
|
||
|
|
||
|
if gbl.docs == 2: # html docs
|
||
|
if notes:
|
||
|
print '<!-- Auto-Generated by MMA on: %s -->' % time.ctime()
|
||
|
print '<HTML>'
|
||
|
print '<BODY BGCOLOR="#B7DFFF" Text=Black>'
|
||
|
if fname.endswith(gbl.ext):
|
||
|
fname='.'.join(fname.split('.')[:-1])
|
||
|
print "<H1>%s</H1>" % fname.title()
|
||
|
print "<P>%s" % notes
|
||
|
if defs:
|
||
|
print "<ul>"
|
||
|
for l in defs:
|
||
|
print "<LI><A Href=#%s>%s</a>" % (l[0], l[0])
|
||
|
print "</ul>"
|
||
|
for l in defs:
|
||
|
print '<A Name=%s></a>' % l[0]
|
||
|
print '<P>'
|
||
|
print '<Table Border=3 CELLSPACING=0 CELLPADDING=5 BGColor="#eeeeee" Width="60%">'
|
||
|
print ' <TR><TD>'
|
||
|
print ' <H2> %s </H2> ' % l[0]
|
||
|
print ' %s <B>(%s)</B> ' % ( l[2], l[1] )
|
||
|
print ' </TD></TR>'
|
||
|
print ' <TR><TD>'
|
||
|
print ' <Table CELLSPACING=0 CELLPADDING=5 BGColor="#eeeeee" Width="10%">'
|
||
|
for c,v in l[3:]:
|
||
|
print " <TR><TD> %s </TD> <TD> %s </TD></TR>" % (c.title(), v)
|
||
|
print ' </Table>'
|
||
|
print ' </TD></TR>'
|
||
|
print '</Table>'
|
||
|
print
|
||
|
print '</Body></HTML>'
|
||
|
defs = []
|
||
|
notes = ""
|
||
|
author = ""
|
||
|
|
||
|
|
||
|
|
||
|
def totex(s):
|
||
|
""" Parse a string and quote tex stuff.
|
||
|
|
||
|
Also handles proper quotation style.
|
||
|
"""
|
||
|
|
||
|
s = s.replace("$", "\\$")
|
||
|
s = s.replace("*", "$*$")
|
||
|
s = s.replace("\\", "\\\\")
|
||
|
s = s.replace("#", "\\#")
|
||
|
s = s.replace("&", "\\&")
|
||
|
|
||
|
q="``"
|
||
|
while s.count('"'):
|
||
|
i=s.find('"')
|
||
|
s=s[:i] + q + s[i+1:]
|
||
|
if q=="``":
|
||
|
q="''"
|
||
|
else:
|
||
|
a="``"
|
||
|
|
||
|
|
||
|
return s
|