#!@PYTHON@
-# mf-to-table.py -- convert spacing info in MF logs .ly and .tex
+# mf-to-table.py -- convert spacing info in MF logs .afm and .tex
#
# source file of the GNU LilyPond music typesetter
#
(options, files) = getopt.getopt(
sys.argv[1:], 'a:d:hl:o:p:t:',
- ['afm=', 'outdir=', 'dep=', 'ly=', 'tex=', 'debug', 'help', 'package='])
+ ['afm=', 'outdir=', 'dep=', 'tex=', 'debug', 'help', 'package='])
for opt in options:
o = opt[0]
def end (self,nm):
self.write ('End%s\n' % nm)
-class Ly_file(Indentable_file):
- """extra provisions for mozarella quirks"""
- def print_lit(self, str):
- self.write('\"%s\"\t' % str)
-
- def print_f_dimen(self, f):
- dimstr = '%.2f' % f
-
- # try to mask rounding errors
- if (dimstr == '-0.00'):
- dimstr = '0.00'
- self.write( dimstr +'\\pt\t');
-
- def print_dimen(self, str):
- self.print_f_dimen(atof(str))
-
- def neg_print_dimen(self, str):
- self.print_f_dimen(-atof(str));
-
- def def_symbol(self, code, lily_id, tex_id, xdim, ydim):
- self.print_lit(lily_id)
- self.print_lit('\\\\' + tex_id)
-
- self.neg_print_dimen(xdim [0])
- self.print_dimen(xdim [1])
- self.neg_print_dimen(ydim [0])
- self.print_dimen(ydim [1])
- self.write('\n')
-
class Log_reader:
"""Read logs, destill info, and put into output files"""
tags = split(line, '@:')
label = tags[0]
name = tags[1]
- ly = self.lyfile
afm = self.afmfile
if tags[0] == 'font':
- ly.indent()
- ly.write("% name=\\symboltables {\n")
self.texfile.write("% name\n")
afm.write ('FontName %s\n' % name)
afm.start ('CharMetrics')
afm.fontsize = atof(tags[2])
elif label == "group":
- ly.indent()
- ly.print_lit(name)
- ly.write(' = \\table {\n')
self.texfile.write("% " + name + "\n")
afm.groupname = name
elif label == "puorg":
- ly.dedent()
- ly.write("}\n")
self.texfile.write("\n")
elif label == "tnof":
- ly.dedent()
- ly.write("% } % $name\n")
afm.end ('CharMetrics')
afm.end('FontMetrics');
elif label == "char":
texstr = tags [8]
xdim = tags[3:5]
ydim = tags[5:7]
- ly.def_symbol(code, id, texstr, xdim, ydim)
self.texfile.write("\\fetdef\\%s{%s}\n" % (texstr, code))
afm.def_symbol (code, id, texstr, xdim, ydim)
self.depfile.write (x + '\n')
def do_file(self,filenm):
- self.lyfile.write ('\n% input from ' + filenm + '\n')
self.texfile.write ('\n% input from ' + filenm + '\n')
feta = Feta_file(filenm)
while not feta.eof():
self.writedeps (feta.dependencies)
- def __init__(self, lyfile_nm, texfile_nm, depfile_nm, afmfile_nm):
- self.lyfile = Ly_file(lyfile_nm, 'w')
+ def __init__(self, texfile_nm, depfile_nm, afmfile_nm):
self.texfile = Indentable_file(texfile_nm, 'w')
self.depfile = File (depfile_nm, 'w')
self.afmfile = Afm_file (afmfile_nm, 'w')
headerstr = '%% Creator: %s\n%% Automatically generated on\n%% Do not edit' % \
(program_id() )
- self.lyfile.write(headerstr)
self.texfile.write(headerstr)
self.depfile.write ('# automatically generated by %s\n' % program_id ())
def close(self):
- self.lyfile.close()
self.texfile.close()
self.depfile.close ()
def main():
identify()
- lyfile_nm = texfile_nm = '';
+ texfile_nm = '';
depfile_nm = ''
afmfile_nm = ''
outdir_prefix = '.'
depfile_nm = a
elif o == '--outdir' or o == '-o':
outdir_prefix = a
- elif o == '--ly' or o == '-l':
- lyfile_nm = a
elif o == '--tex' or o == '-t':
texfile_nm = a
elif o== '--help' or o == '-h':
print o
raise getopt.error
- log_reader = Log_reader(lyfile_nm, texfile_nm, depfile_nm, afmfile_nm)
+ log_reader = Log_reader( texfile_nm, depfile_nm, afmfile_nm)
log_reader.outdir = outdir_prefix
for filenm in files:
log_reader.do_file(filenm)