|
@ -25,16 +25,9 @@ class Song: |
|
|
return repr((self.title, self.artist, self.album, self.path)) |
|
|
return repr((self.title, self.artist, self.album, self.path)) |
|
|
|
|
|
|
|
|
from xdg.BaseDirectory import * |
|
|
from xdg.BaseDirectory import * |
|
|
|
|
|
cachePath = os.path.join(xdg_cache_home, 'songbook') |
|
|
|
|
|
|
|
|
print 'xdg_data_home: %s' % xdg_data_home |
|
|
def makeCoverCache(library): |
|
|
print 'xdg_data_dirs: %s' % xdg_data_dirs |
|
|
|
|
|
print 'xdg_config_home: %s' % xdg_config_home |
|
|
|
|
|
print 'xdg_config_dirs: %s' % xdg_config_dirs |
|
|
|
|
|
print 'xdg_cache_home: %s' % xdg_cache_home |
|
|
|
|
|
|
|
|
|
|
|
songbook_cache_home = os.path.join(xdg_cache_home, 'songbook') |
|
|
|
|
|
|
|
|
|
|
|
def makeCoverCache(library, cachePath): |
|
|
|
|
|
''' |
|
|
''' |
|
|
Copy all pictures found in the libraries into a unique cache |
|
|
Copy all pictures found in the libraries into a unique cache |
|
|
folder. |
|
|
folder. |
|
@ -157,13 +150,16 @@ def makeTexFile(sb, library, output): |
|
|
out.write(formatDefinition('songslist', songslist(library, songs))) |
|
|
out.write(formatDefinition('songslist', songslist(library, songs))) |
|
|
out.write('\\makeatother\n') |
|
|
out.write('\\makeatother\n') |
|
|
|
|
|
|
|
|
# output grapihcs path |
|
|
|
|
|
#out.write('\\graphicspath{ {img/}, {' + songbook_cache_home + '/images/} }\n') |
|
|
|
|
|
|
|
|
|
|
|
# output template |
|
|
# output template |
|
|
commentPattern = re.compile(r"^\s*%") |
|
|
commentPattern = re.compile(r"^\s*%") |
|
|
f = open("templates/"+template) |
|
|
f = open("templates/"+template) |
|
|
content = [ line for line in f if not commentPattern.match(line) ] |
|
|
content = [ line for line in f if not commentPattern.match(line) ] |
|
|
|
|
|
|
|
|
|
|
|
for index, line in enumerate(content): |
|
|
|
|
|
if re.compile("getcachedirectory").search(line): |
|
|
|
|
|
line = line.replace("\\getcachedirectory", cachePath + "/") |
|
|
|
|
|
content[index] = line |
|
|
|
|
|
|
|
|
f.close() |
|
|
f.close() |
|
|
out.write(''.join(content)) |
|
|
out.write(''.join(content)) |
|
|
|
|
|
|
|
@ -215,7 +211,7 @@ def main(): |
|
|
try: |
|
|
try: |
|
|
opts, args = getopt.getopt(sys.argv[1:], |
|
|
opts, args = getopt.getopt(sys.argv[1:], |
|
|
"hs:o:d:l", |
|
|
"hs:o:d:l", |
|
|
["help","songbook=","output=","depend","cache","library="]) |
|
|
["help","songbook=","output=","depend","library="]) |
|
|
except getopt.GetoptError, err: |
|
|
except getopt.GetoptError, err: |
|
|
# print help and exit |
|
|
# print help and exit |
|
|
print str(err) |
|
|
print str(err) |
|
@ -225,15 +221,12 @@ def main(): |
|
|
songbook = None |
|
|
songbook = None |
|
|
depend = False |
|
|
depend = False |
|
|
output = None |
|
|
output = None |
|
|
cache = False |
|
|
|
|
|
library = './' |
|
|
library = './' |
|
|
|
|
|
|
|
|
for o, a in opts: |
|
|
for o, a in opts: |
|
|
if o in ("-h", "--help"): |
|
|
if o in ("-h", "--help"): |
|
|
usage() |
|
|
usage() |
|
|
sys.exit() |
|
|
sys.exit() |
|
|
elif o in ("--cache"): |
|
|
|
|
|
cache = True |
|
|
|
|
|
elif o in ("-s", "--songbook"): |
|
|
elif o in ("-s", "--songbook"): |
|
|
songbook = a |
|
|
songbook = a |
|
|
elif o in ("-d", "--depend"): |
|
|
elif o in ("-d", "--depend"): |
|
@ -245,7 +238,7 @@ def main(): |
|
|
else: |
|
|
else: |
|
|
assert False, "unhandled option" |
|
|
assert False, "unhandled option" |
|
|
|
|
|
|
|
|
makeCoverCache(library, os.path.join(songbook_cache_home, 'images')) |
|
|
makeCoverCache(library) |
|
|
if songbook and output: |
|
|
if songbook and output: |
|
|
f = open(songbook) |
|
|
f = open(songbook) |
|
|
sb = json.load(f) |
|
|
sb = json.load(f) |
|
|