From f10ed7503fa50581ec6589230585ac18acc2de7d Mon Sep 17 00:00:00 2001 From: Louis Date: Thu, 7 Mar 2013 20:25:59 +0100 Subject: [PATCH 1/6] =?UTF-8?q?D=C3=A9but=20d'un=20cahier=20des=20charges?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cahier_des_charges/charges.txt | 152 +++++++++++++++++++++++++++++++++ 1 file changed, 152 insertions(+) create mode 100644 cahier_des_charges/charges.txt diff --git a/cahier_des_charges/charges.txt b/cahier_des_charges/charges.txt new file mode 100644 index 00000000..3c502921 --- /dev/null +++ b/cahier_des_charges/charges.txt @@ -0,0 +1,152 @@ +# Index personnalisés + +Je veux être capable de créer mes propres index. Je ne veux pas choisir dans +une liste prédéfinie, mais pouvoir les personnaliser. Je veux pouvoir leur +donner le titre que je veux. + +## Proposition + +Dans le fichier general.sg, définition d'une liste : + +> indexes = [ +> "auteur", +> ("pays", "Index par pays d'origine"), +> ] + +Ceci signifie que j'aurai deux index : + +- l'un utilisant le mot-clef "auteur", ayant pour titre "Index par auteur" ; +- l'autre utilisant le mot-clef "pays", ayant pour titre "Index par pays d'origine". + +Pour chaque index, le mot clef sortas_nom est disponible, si l'on veut que le +nom qui s'affiche ne soit pas le nom par lequel l'entrée est triée. + +# Découpage du document + +Je veux pouvoir personnaliser le document, à savoir : mettre ma propre page de +titre, choisir l'ordre des éléments (index au début ou à la fin), ajouter des +pages personnalisées, etc. + +## Proposition + +### Préambule + +Dans le fichier general.sg, définition de variables : + +> preambule = "\usepackage{yfonts}" + +Cette variable permet d'ajouter des choses au préambule. Pour intégrer un fichier complet, il suffit de mettre : + +> preambule = "\input{mon_preambule.tex}" + +### Document + +Dans le fichier general.sg, possibilité de définir la variable document : + +> document = [ +> TITLE, +> INDEXES, +> SONGS, +> "appendice.tex", +> ] + +Ceci signifie que mon document comportera la page de titre, l'index, les textes +des chansons par défaut, et à la fin, intégrera mon document "appendice.tex". + +# Emplacement des chansons + +Je veux pouvoir dire à quelles chansons aller chercher. + +## Proposition + +Dans le fichier general.sg, utilisation des variables SONG_ROOT et SONG_FILES. + +> SONG_ROOT = "~/chansons" +> SONG_FILES = "*/*.tex" + +Il est possible de mettre une liste dans SONG_FILES, pour dire de prendre tous +les éléments de la liste. + +# Langue + +Je veux pouvoir dire dans quel langue est chaque chanson, et que ceci soit +ajouté automatiquement à l'appel de Babel. + +# Référence + +Je veux pouvoir faire référence à des chansons (nom, page, etc.). + +## Proposition + +Faire en sorte que la commande \label fonctionne, ou ajouter un mot-clef +"label" à \beginsong. + +Ensuite, avoir à disposition des commandes \songtitle{ref}, \songpage{ref}, +\songkeyword{ref}{keyword}. + +# Chansons de plusieurs auteurs + +Je veux pouvoir choisir l'ordre de mes chansons (classement par auteur par exemple). + +Je veux pouvoir attribuer des chansons à plusieurs auteurs, et décider dans la +partie de quel auteur elle aparaisse, et qu'elle soit référencée dans d'autre. + +Exemple : Les Oiseaux de passage, de Richepin, chantée par Brassens. Je veux +que le texte apparaisse avec les autres textes de Richepin, avec la mention « +Mise en musique par Brassens », et qu'à un endroit dans la « partie » Brassens, +apparaisse le texte « Voir aussi \songtitle{richepin_oiseau}, page +\songpage{richepin_page} ». La chanson apparaitra pour les deux auteurs dans +l'index par auteur. + +## Proposition + +> \beginsong{Chanson des cloches de baptême}[label=richepin_cloches, author=Richepin] +> \comment{Chantée par \songauthor{brassens_philistins} sous le titre \songtitle{brassens_philistins}.} +> ... +> \endsong +> +> \beginchildsong{Philistins}[parent=richepin_cloches, author=Brassens] +> Voir \songtitle{richepin_cloches}, page \pagetitle{richepin_page}. +> \endsong + +# Possibilité d'exporter en LaTeX ou PDF + +Je veux pouvoir, en ligne de commande, dire que je souhaite un export en LaTeX +ou en PDF. + +# Partitions + +Je veux pouvoir placer mes partitions Lilypond dans le même répertoire que les +chansons correspondantes. + +# PDF + +Je veux pouvoir intégrer des PDF comme chansons (partitions scannées). + +# Traductions + +Je pouvoir intégrer des traductions. + +## Proposition + +Dans le fichier general.sg, une variable avec la langue par défaut pour les +traductions. + +> DEFAULT_TRANSLATION_LANGUAGE = "francais" + +Dans un fichier de chanson : + +> \begin[english]{translation} +> Do not use your spoon with your left hand / etc. +> \end{translation} + +# Commentaires + +Je veux pouvoir ajouter des commentaires dans les chansons, qui soient mis en +valeur différement. + +# Langage du fichier de configuration + +Je propose que le fichier de configuration soit du Python : puisqu'un client +texte existe, nous pouvons considérer que quelqu'un modifiant à la main ce +fichier sait faire du Python. From fccb0181ef8c5aed25da1be9d31e237bedea6301 Mon Sep 17 00:00:00 2001 From: Louis Date: Fri, 8 Mar 2013 22:19:35 +0100 Subject: [PATCH 2/6] Cahier des charges --- cahier_des_charges/charges.txt | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/cahier_des_charges/charges.txt b/cahier_des_charges/charges.txt index 3c502921..9af8bc53 100644 --- a/cahier_des_charges/charges.txt +++ b/cahier_des_charges/charges.txt @@ -150,3 +150,8 @@ valeur différement. Je propose que le fichier de configuration soit du Python : puisqu'un client texte existe, nous pouvons considérer que quelqu'un modifiant à la main ce fichier sait faire du Python. + +# Langues + +Pouvoir définir les langues dans le fichier de configuration general.sg, pour +que babel ne soit pas bloqué. From efa6f82cf1da3eb0e531abbd3e57f62b96ccf1fc Mon Sep 17 00:00:00 2001 From: Louis Date: Fri, 8 Mar 2013 22:25:36 +0100 Subject: [PATCH 3/6] =?UTF-8?q?Correction=20du=20bug:=20un=20carnet=20sans?= =?UTF-8?q?=20chansons=20est=20autoris=C3=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- songbook-makeindex.py | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/songbook-makeindex.py b/songbook-makeindex.py index 8509aa61..0ed27d56 100755 --- a/songbook-makeindex.py +++ b/songbook-makeindex.py @@ -85,10 +85,11 @@ def processSXD(filename): type = data[0] i = 1 idx = index() - while data[i].startswith('%'): - keywords = keywordPattern.match(data[i]).groups() - idx.keyword(keywords[0],keywords[1]) - i += 1 + if len(data) > 1: + while data[i].startswith('%'): + keywords = keywordPattern.match(data[i]).groups() + idx.keyword(keywords[0],keywords[1]) + i += 1 idx.compileKeywords() for i in range(i,len(data),3): entry = processSXDEntry(data[i:i+3]) From cf866b48b1a08ab5b91ddbd511d69999ccc111d0 Mon Sep 17 00:00:00 2001 From: Louis Date: Fri, 8 Mar 2013 23:23:33 +0100 Subject: [PATCH 4/6] Autorisation de la commande \titleprefixword --- songbook-makeindex.py | 12 ++++++++++-- sortindex.py | 1 + 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/songbook-makeindex.py b/songbook-makeindex.py index 8509aa61..5a0b822b 100755 --- a/songbook-makeindex.py +++ b/songbook-makeindex.py @@ -18,7 +18,7 @@ import sortindex import locale # Pattern set to ignore latex command in title prefix -keywordPattern = re.compile(r"^%(\w+)\s?(\w*)") +keywordPattern = re.compile(r"^%(\w+)\s?(.*)$") firstLetterPattern = re.compile(r"^(?:\{?\\\w+\}?)*[^\w]*(\w)") class index: @@ -37,9 +37,17 @@ class index: self.keywords[key].append(word) def compileKeywords(self): - pass + self.prefix_patterns = [] + if 'prefix' in self.keywords: + for prefix in self.keywords['prefix']: + self.prefix_patterns.append(re.compile(r"^(%s)\b\s*(.*)$" % prefix)) def add(self, key, number, link): + for pattern in self.prefix_patterns: + match = pattern.match(key) + if match: + key = "%s (%s)" % (match.group(2), match.group(1)) + break # Only one match per key (first, key) = self.filter(key) if not self.data.has_key(first): self.data[first] = dict() diff --git a/sortindex.py b/sortindex.py index dd3d5d50..4333e5f2 100644 --- a/sortindex.py +++ b/sortindex.py @@ -28,6 +28,7 @@ replacePattern = { '~n' : 'ñ', "c C" : 'Ç', "c c" : 'ç', + "textquoteright" : "'", } def sortkey(value): From 721121ed0b05943f9b6a38696267af1ef59d898d Mon Sep 17 00:00:00 2001 From: Louis Date: Sat, 9 Mar 2013 00:14:25 +0100 Subject: [PATCH 5/6] Cachier des charge --- cahier_des_charges/charges.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/cahier_des_charges/charges.txt b/cahier_des_charges/charges.txt index 9af8bc53..21d4b611 100644 --- a/cahier_des_charges/charges.txt +++ b/cahier_des_charges/charges.txt @@ -21,6 +21,8 @@ Ceci signifie que j'aurai deux index : Pour chaque index, le mot clef sortas_nom est disponible, si l'on veut que le nom qui s'affiche ne soit pas le nom par lequel l'entrée est triée. +Utiliser la commande \newsongkey : http://songs.sourceforge.net/songsdoc/songs.html#mac.newsongkey + # Découpage du document Je veux pouvoir personnaliser le document, à savoir : mettre ma propre page de From 3c1582bdf989e49bfd62826363beb2cc076fdef8 Mon Sep 17 00:00:00 2001 From: Louis Date: Sat, 9 Mar 2013 01:57:33 +0100 Subject: [PATCH 6/6] =?UTF-8?q?Correction=20:=20Tri=20des=20chansons=20en?= =?UTF-8?q?=20prenant=20compte=20des=20pr=C3=A9fixes?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- songbook.py | 24 +++++++++++++++++++++--- templates/minimal.tmpl | 5 ++++- templates/patacrep.tmpl | 5 ++++- 3 files changed, 29 insertions(+), 5 deletions(-) diff --git a/songbook.py b/songbook.py index f443947b..aeb404ee 100755 --- a/songbook.py +++ b/songbook.py @@ -49,7 +49,17 @@ def makeCoverCache(library): def matchRegexp(reg, iterable): return [ m.group(1) for m in (reg.match(l) for l in iterable) if m ] -def songslist(library, songs): +def unprefixed(title, prefixes): + """Remove the first prefix of the list in the beginning of title (if any). + """ + for prefix in prefixes: + match = re.compile(r"^(%s)\b\s*(.*)$" % prefix).match(title) + if match: + return match.group(2) + return title + + +def songslist(library, songs, prefixes): song_objects = [] for s in songs: path = library + 'songs/' + s @@ -64,7 +74,7 @@ def songslist(library, songs): album = '' song_objects.append(Song(title, artist, album, path)) - song_objects = sorted(song_objects, key=lambda x: locale.strxfrm(x.title)) + song_objects = sorted(song_objects, key=lambda x: locale.strxfrm(unprefixed(x.title, prefixes))) song_objects = sorted(song_objects, key=lambda x: locale.strxfrm(x.album)) song_objects = sorted(song_objects, key=lambda x: locale.strxfrm(x.artist)) @@ -121,6 +131,8 @@ def makeTexFile(sb, library, output): # default value template = "patacrep.tmpl" songs = [] + titleprefixwords = "" + prefixes = [] # parse the songbook data if "template" in sb: @@ -129,6 +141,12 @@ def makeTexFile(sb, library, output): if "songs" in sb: songs = sb["songs"] del sb["songs"] + if "titleprefixwords" in sb: + prefixes = sb["titleprefixwords"] + for prefix in sb["titleprefixwords"]: + titleprefixwords += "\\titleprefixword{%s}\n" % prefix + sb["titleprefixwords"] = titleprefixwords + parameters = parseTemplate("templates/"+template) @@ -151,7 +169,7 @@ def makeTexFile(sb, library, output): songs = map(lambda x: x[len(library) + 6:], glob.glob(library + 'songs/*/*.sg')) if len(songs) > 0: - out.write(formatDefinition('songslist', songslist(library, songs))) + out.write(formatDefinition('songslist', songslist(library, songs, prefixes))) out.write('\\makeatother\n') # output template diff --git a/templates/minimal.tmpl b/templates/minimal.tmpl index 3bdcd58a..770641e6 100644 --- a/templates/minimal.tmpl +++ b/templates/minimal.tmpl @@ -29,7 +29,8 @@ %%: {"name":"lang", "description":"Language", "default":"english"}, %%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]}, %%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","importantdiagramonly","lilypond","pictures","tabs","repeatchords","onesongperpage"], "join":",", "mandatory":true, "default":["pictures"]}, -%%: {"name":"mainfontsize", "description":"Font Size", "type":"font", "default":"10"} +%%: {"name":"mainfontsize", "description":"Font Size", "type":"font", "default":"10"}, +%%: {"name":"titleprefixwords", "description":"Ignore some words in the beginning of song titles"} %%:] %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % begin document @@ -49,6 +50,8 @@ \fi% } +\gettitleprefixwords + \nosongnumbers \pagestyle{empty} diff --git a/templates/patacrep.tmpl b/templates/patacrep.tmpl index 9b78917b..9ca68eae 100644 --- a/templates/patacrep.tmpl +++ b/templates/patacrep.tmpl @@ -42,7 +42,8 @@ %%: {"name":"mainfontsize", "description":"Font Size", "type":"font", "default":"10"}, %%: {"name":"songnumberbgcolor", "description":"Number Shade", "type":"color", "default":"#D1E4AE"}, %%: {"name":"notebgcolor", "description":"Note Shade", "type":"color", "default":"#D1E4AE"}, -%%: {"name":"indexbgcolor", "description":"Index Shade", "type":"color", "default":"#D1E4AE"} +%%: {"name":"indexbgcolor", "description":"Index Shade", "type":"color", "default":"#D1E4AE"}, +%%: {"name":"titleprefixwords", "description":"Ignore some words in the beginning of song titles"} %%:] %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % begin document @@ -84,6 +85,8 @@ \renewcommand{\notebgcolor}{NoteBgColor} \renewcommand{\idxbgcolor}{IndexBgColor} +\gettitleprefixwords + \pagestyle{empty} \begin{document}