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:
parent
cb7653d925
commit
0633bbcfa5
1 changed files with 21 additions and 5 deletions
26
makedrum
26
makedrum
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue