1
0
Fork 0
mirror of https://github.com/kastdeur/pipeband-music.git synced 2025-01-08 23:13:31 +01:00

Updating makedrum script to use as semi-perfect standin for direct lilypond call.

Might be able to use the script within a lilypond-book
This commit is contained in:
Eric Teunis de Boone 2017-02-15 12:43:33 +01:00
parent cb7653d925
commit 0633bbcfa5

View file

@ -13,8 +13,9 @@ class MakeDrum:
VERSION = '0.9.7' VERSION = '0.9.7'
MASTER_DIR = os.path.dirname(os.path.abspath(__file__)) MASTER_DIR = os.path.dirname(os.path.abspath(__file__))
RUN_DIR = os.path.abspath(os.curdir) RUN_DIR = os.path.abspath(os.curdir)
TMP_DIR = './tmp' TMP_DIR = '.'
TMP_PREFIX = 'tmp_' TMP_PREFIX = 'tmp_'
OUT_DIR = '.'
def __init__(self): def __init__(self):
# Gather options and create the template file # Gather options and create the template file
@ -27,6 +28,10 @@ class MakeDrum:
parser.add_argument('--lilyversion', parser.add_argument('--lilyversion',
action='store_true', dest='show_lilyversion', default=False, action='store_true', dest='show_lilyversion', default=False,
help='show Lilypond version and exit') help='show Lilypond version and exit')
parser.add_argument('-l', '--lilycommand',
default=self.LILYPOND, dest='lilypond',
help='Command used to compile')
parser.add_argument('-i', '--include', parser.add_argument('-i', '--include',
dest='includes', nargs='*', default=[],action='append', dest='includes', nargs='*', default=[],action='append',
@ -48,6 +53,9 @@ class MakeDrum:
action='store_true', dest='view_spacing', default=False, action='store_true', dest='view_spacing', default=False,
help='Turn on "Paper.annotatespacing".') help='Turn on "Paper.annotatespacing".')
parser.add_argument('--rename',
action='store_true', dest='rename', default=False,
help='Rename the final output to it\'s relative location, replacing /\'s with -\'s')
parser.add_argument('-r', '--suffix', parser.add_argument('-r', '--suffix',
dest='suffix', default='', dest='suffix', default='',
help='String added at end of pdf\'s filename') help='String added at end of pdf\'s filename')
@ -67,7 +75,7 @@ class MakeDrum:
action='store_false', dest='clean', default=True, action='store_false', dest='clean', default=True,
help='Leave all temporary files in place') help='Leave all temporary files in place')
parser.add_argument('-d', '--out-dir', parser.add_argument('-d', '--out-dir',
dest='out_dir', default='pdf', dest='out_dir', default=self.OUT_DIR,
help='Output dir, for lilypond. If it doesn\'t exist, try to create it') help='Output dir, for lilypond. If it doesn\'t exist, try to create it')
parser.add_argument('music_file', parser.add_argument('music_file',
default='', nargs='*', default='', nargs='*',
@ -76,7 +84,8 @@ class MakeDrum:
dest='list_file', default='', dest='list_file', default='',
help='list of files to process') help='list of files to process')
self.args = parser.parse_args() # All unknown args are passed on to the lilypond command
self.args, self.unknownargs = parser.parse_known_args()
if self.args.show_version: if self.args.show_version:
print(__name__, ' ', self.VERSION) print(__name__, ' ', self.VERSION)
@ -165,8 +174,15 @@ class MakeDrum:
if paths: if paths:
paths = ' -I ' + paths paths = ' -I ' + paths
lilyout = os.path.join(self.RUN_DIR, self.args.out_dir, os.path.basename(tmp_file).replace(self.TMP_PREFIX, '').replace(".ly", '')) if self.args.rename:
lilycmd = self.LILYPOND + paths + ' --pdf --output='+lilyout+' '+tmp_file+log lilyout = os.path.join(self.RUN_DIR, self.args.out_dir, os.path.basename(tmp_file).replace(self.TMP_PREFIX, '').rsplit( ".", 1 )[ 0 ])
else:
lilyout = os.path.basename(file).rsplit( ".", 1 )[ 0 ]
unknownargs = " " + " ".join(self.unknownargs)
lilycmd = self.LILYPOND + unknownargs + paths + ' --output='+lilyout+' '+tmp_file+log
if os.system(lilycmd) != 0: if os.system(lilycmd) != 0:
self.remove_tmp_dir = False self.remove_tmp_dir = False