Browse Source

Sort songs and indexes based on user locale

remotes/origin/cmake
Guillaume Bouchard 14 years ago
committed by Romain Goffe
parent
commit
ed47e575af
  1. 5
      songbook-makeindex.py
  2. 6
      songbook.py
  3. 29
      title_sort.py

5
songbook-makeindex.py

@ -14,6 +14,8 @@ import os.path
import glob import glob
import re import re
from optparse import OptionParser from optparse import OptionParser
import title_sort
import locale
# Pattern set to ignore latex command in title prefix # Pattern set to ignore latex command in title prefix
keywordPattern = re.compile(r"^%(\w+)\s?(\w*)") keywordPattern = re.compile(r"^%(\w+)\s?(\w*)")
@ -59,7 +61,7 @@ class index:
def idxBlockToStr(self, letter, entries): def idxBlockToStr(self, letter, entries):
str = '\\begin{idxblock}{'+letter+'}'+'\n' str = '\\begin{idxblock}{'+letter+'}'+'\n'
for key in sorted(entries.keys()): for key in sorted(entries.keys(), key=title_sort.sortkey):
str += self.entryToStr(key, entries[key]) str += self.entryToStr(key, entries[key])
str += '\\end{idxblock}'+'\n' str += '\\end{idxblock}'+'\n'
return str return str
@ -98,6 +100,7 @@ def usage(exitCode=None):
sys.exit(exitCode) sys.exit(exitCode)
def main(): def main():
locale.setlocale(locale.LC_ALL, '')
usage = "usage: %prog [options] FILE" usage = "usage: %prog [options] FILE"
parser = OptionParser(usage) parser = OptionParser(usage)
parser.add_option("-o", "--output", dest="filename", parser.add_option("-o", "--output", dest="filename",

6
songbook.py

@ -7,6 +7,8 @@ import os.path
import glob import glob
import re import re
import json import json
import locale
import titlesort
def matchRegexp(reg, iterable): def matchRegexp(reg, iterable):
return [ m.group(1) for m in (reg.match(l) for l in iterable) if m ] return [ m.group(1) for m in (reg.match(l) for l in iterable) if m ]
@ -94,7 +96,8 @@ def makeTexFile(sb, output):
# output songslist # output songslist
if songs == "all": if songs == "all":
songs = map(lambda x: x[6:], glob.glob('songs/*/*.sg')) songs = map(lambda x: x[6:], glob.glob('songs/*/*.sg'))
songs.sort() songs.sort(key=title_sort.sortkey)
if len(songs) > 0: if len(songs) > 0:
out.write(formatDefinition('songslist', songslist(songs))) out.write(formatDefinition('songslist', songslist(songs)))
out.write('\\makeatother\n') out.write('\\makeatother\n')
@ -150,6 +153,7 @@ def usage():
print "No usage information yet." print "No usage information yet."
def main(): def main():
locale.setlocale(locale.LC_ALL, '') # set script locale to match user's
try: try:
opts, args = getopt.getopt(sys.argv[1:], opts, args = getopt.getopt(sys.argv[1:],
"hs:o:d", "hs:o:d",

29
title_sort.py

@ -0,0 +1,29 @@
#coding:utf8
import re
import warnings
import locale
iecPattern = re.compile(r"\IeC {\\(.*?)}")
replacePattern = {
'`A': 'À',
'oe ': 'œ',
"'e" : 'é',
"'o" : 'ó',
"c C" : 'ç',
}
def sortkey(value):
'''
From a title, return something usable for sorting. It handles locale (but
don't forget to call locale.setlocale(locale.LC_ALL, '')). It also try to
handle the sort with crappy latex escape sequences. Some chars may not be
handled by this function, so add them to *replacePattern* dictionnary.
'''
def repl(match):
try:
return replacePattern[match.group(1)]
except KeyError:
warnings.warn("Error, no match to replace %s in %s. You should add it in the coresponding table in title_solt.py" % (match.group(0), match.group(1)))
return locale.strxfrm(iecPattern.sub(repl, value))
Loading…
Cancel
Save