Browse Source

Merge branch 'master' of git://lohrun.net/songbook

Conflicts:
	songs/Debout_Sur_Le_Zinc/Comme_un_frisson.sg
	songs/Debout_Sur_Le_Zinc/Elle_m_ennuie.sg
	songs/Debout_Sur_Le_Zinc/J_ai_deja_donne.sg
	songs/Debout_Sur_Le_Zinc/Les_angles.sg
	songs/Debout_Sur_Le_Zinc/Sur_le_fil.sg
	songs/Les_Cowboys_Fringants/Entre_deux_taxis.sg
remotes/origin/split-songs
olivier desrobert 13 years ago
parent
commit
e397c30624
  1. 49
      NEWS
  2. 1
      books/naheulbeuk.sb
  3. 3
      books/volume-1.sb
  4. 44
      books/volume-5.sb
  5. BIN
      img/The_Music_Machine_by_hit_squad.jpg
  6. 20
      makefile
  7. 23
      songbook.py
  8. 8
      templates/ancient.tmpl
  9. 15
      templates/minimal.tmpl
  10. 8
      templates/patacrep-en.tmpl
  11. 8
      templates/patacrep.tmpl
  12. 19
      tex/crepbook.cls
  13. 6
      utils/header-last-volume
  14. 51
      utils/last-volume.sh
  15. 27
      utils/release.sh
  16. 27
      utils/rules.py
  17. 31
      utils/tarball.sh

49
NEWS

@ -1,4 +1,45 @@
version 3.5.6
Dimitri Delporte:
Belyscendre - Hélas madame
Francis Cabrel - La corrida
Romain Goffe:
The Bloody Irish Boys - Drunk tonight
Jacques Dutronc - La fille du Père Noël
broph:
Calvin Russel - Down down down
olivier desrobert:
: Debout sur le zinc - J'ai déjà donné
: Debout sur le zinc - Comme un frisson
: Debout sur le Zinc
: Debout sur le zinc - Elle m'ennuie
: Debout sur le zinc - les angles
version 3.5.5
Kaosun:
Thomas Fersen - Bambi
Thomas Fersen - Croque
Thomas Fersen - Irène
Thomas Fersen - L'histoire d'une heure
Thomas Fersen - Les cravates
Thomas Fersen - Louise
Gary Jules - Mad world
Les Fatals Picards - Au mariage de Kévin et de ma soeur
Thomas Fersen - Rititi, ratata
Thomas Fersen - Le bouton
Anis - Dans tes yeux
Les Cowboys Fringants - Ces temps-ci
Le clandestin - Rue Grenelle
Jali - Española
La rue kétanou - Sao Loucas
Les Cowboys Fringants - 8 secondes
Debout sur le Zinc - Scylla
Romain Goffe:
Les Booze Brothers - Fields of Athenry
The Dubliners - The wild rover
version 3.5.4 version 3.5.4
BeXa: BeXa:
Jeanne Moreau - Les mots de rien Jeanne Moreau - Les mots de rien
@ -57,7 +98,7 @@ Romain Goffe:
broph: broph:
Jean-Pierre Mader - Macumba Jean-Pierre Mader - Macumba
Noir Désir - Les écorchés Noir Désir - Les écorchés
Louis Bertignac - Ces idées là Louis Bertignac - Ces idées là 
Rita Mitsouko - C'est comme ça Rita Mitsouko - C'est comme ça
Calvin Russel - Baby I love you Calvin Russel - Baby I love you
Calvin Russel - Crossroad Calvin Russel - Crossroad
@ -216,7 +257,7 @@ songbook (v0.8)
The Rolling Stones - Angie The Rolling Stones - Angie
The Rolling Stones - Ruby Tuesday The Rolling Stones - Ruby Tuesday
Simon & Garfunkel - Me and Julio down by the schoolyard Simon & Garfunkel - Me and Julio down by the schoolyard
Georges Brassens - À l'ombre du cœur de ma mie Georges Brassens - À l'ombre du coeur de ma mie
Georges Brassens - Je me suis fait tout petit Georges Brassens - Je me suis fait tout petit
Yuki Kajiura - Jr Yuki Kajiura - Jr
Crep - Kartopo Crep - Kartopo
@ -247,7 +288,7 @@ songbook (v0.8)
Mes souliers sont rouges - Sortis du bois Mes souliers sont rouges - Sortis du bois
Les Ogres de Barback - L'ennui et le jour Les Ogres de Barback - L'ennui et le jour
Gogol Bordello - Supertheory of supereverything Gogol Bordello - Supertheory of supereverything
Tri Yann - Les filles de Redon + update cover Tri Yann - Les filles de Redon
Tri Yann - Kiss the children for me Mary Tri Yann - Kiss the children for me Mary
Les Fatals Picards - Goldorak est mort Les Fatals Picards - Goldorak est mort
Charles Aznavour - Les comédiens Charles Aznavour - Les comédiens
@ -290,7 +331,7 @@ songbook (v0.8)
Les hurlements d'Léo - Une danseuse Les hurlements d'Léo - Une danseuse
Les hurlements d'Léo - À bout d'souffle Les hurlements d'Léo - À bout d'souffle
Jacques Brel - Amsterdam Jacques Brel - Amsterdam
Jacques Brel - Ces gens-là Jacques Brel - Ces gens-là 
Jacques Brel - La valse à mille temps Jacques Brel - La valse à mille temps
Cookie Dingler - Femme libérée Cookie Dingler - Femme libérée
Jacques Higelin - Poil dans la main Jacques Higelin - Poil dans la main

1
books/naheulbeuk.sb

@ -15,6 +15,7 @@
"title" : "Le Donjon de Naheulbeuk", "title" : "Le Donjon de Naheulbeuk",
"version" : "0.4.1", "version" : "0.4.1",
"songs" : [ "songs" : [
"Belyscendre/Helas_madame.sg",
"Belyscendre/Mon_pere_veut_me_marier.sg", "Belyscendre/Mon_pere_veut_me_marier.sg",
"Belyscendre/Prends_garde_au_loup.sg", "Belyscendre/Prends_garde_au_loup.sg",
"Le_Donjon_de_Naheulbeuk/10_sous_dans_ma_poche.sg", "Le_Donjon_de_Naheulbeuk/10_sous_dans_ma_poche.sg",

3
books/volume-1.sb

@ -7,8 +7,9 @@
"pictures" "pictures"
], ],
"booktype" : "chorded", "booktype" : "chorded",
"picture" : "feel-the-music",
"picturecopyright" : "foxygamergirl @ deviantart.com",
"subtitle" : "Tome 1", "subtitle" : "Tome 1",
"title" : "Recueil de chansons pour guitare",
"songs" : [ "songs" : [
"Alain_Bashung/Gaby_oh_gaby.sg", "Alain_Bashung/Gaby_oh_gaby.sg",
"Amy_MacDonald/Mr._Rock_n_Roll.sg", "Amy_MacDonald/Mr._Rock_n_Roll.sg",

44
books/volume-5.sb

@ -0,0 +1,44 @@
{
"template" : "patacrep.tmpl",
"lang" : "french",
"bookoptions" : [
"diagram",
"lilypond",
"pictures"
],
"booktype" : "chorded",
"picture" : "The_Music_Machine_by_hit_squad",
"picturecopyright" : "hit-squad @ deviantart.com",
"subtitle" : "Tome 5",
"songs" : [
"Anis/Dans_tes_yeux.sg",
"Belyscendre/Helas_madame.sg",
"Calvin_Russell/Down_down_down.sg",
"Debout_Sur_Le_Zinc/Comme_un_frisson.sg",
"Debout_Sur_Le_Zinc/Elle_m_ennuie.sg",
"Debout_Sur_Le_Zinc/J_ai_deja_donne.sg",
"Debout_Sur_Le_Zinc/Les_angles.sg",
"Debout_Sur_Le_Zinc/Scylla.sg",
"Debout_Sur_Le_Zinc/Sur_le_fil.sg",
"Francis_Cabrel/La_corrida.sg",
"Gary_Jules/Mad_world.sg",
"Jacques_Dutronc/La_fille_du_Pere_Noel.sg",
"Jali/Espanola.sg",
"La_Rue_Ketanou/Sao_loucas.sg",
"Le_clandestin/Rue_Grenelle.sg",
"Les_Booze_Brothers/Fields_of_Athenry.sg",
"Les_Cowboys_Fringants/8_secondes.sg",
"Les_Cowboys_Fringants/Ces_temps_ci.sg",
"Les_Fatals_Picards/Au_mariage_de_Kevin_et_de_ma_soeur.sg",
"The_Bloody_Irish_Boys/Drunk_tonight.sg",
"The_Dubliners/The_wild_rover.sg",
"Thomas_Fersen/Bambi.sg",
"Thomas_Fersen/Croque.sg",
"Thomas_Fersen/Irene.sg",
"Thomas_Fersen/Le_bouton.sg",
"Thomas_Fersen/Les_cravates.sg",
"Thomas_Fersen/L_histoire_d_une_heure.sg",
"Thomas_Fersen/Louise.sg",
"Thomas_Fersen/Rititi_ratata_il_parait_qu_elles_aiment_.sg",
"Yves_Simon/Les_bateaux_du_metro.sg"]
}

BIN
img/The_Music_Machine_by_hit_squad.jpg

Binary file not shown.

After

Width:  |  Height:  |  Size: 199 KiB

20
makefile

@ -24,6 +24,8 @@ PDF = $(TARGETS:%=%.pdf)
CHORDS = chords.tex CHORDS = chords.tex
CHORDS_SRC = $(shell ls songs/*/*.sg) CHORDS_SRC = $(shell ls songs/*/*.sg)
DATE = $(shell date +%d)-$(shell date +%m)-$(shell date +%Y)
PRINT=printf "%s\n" PRINT=printf "%s\n"
PRINTTAB=printf "\t%s\n" PRINTTAB=printf "\t%s\n"
@ -40,10 +42,7 @@ else
LILYFILE=$(LILY_SRC:%.ly=%.pdf) LILYFILE=$(LILY_SRC:%.ly=%.pdf)
endif endif
LATEX=pdflatex $(LATEX_OPTIONS) LATEX=pdflatex $(LATEX_OPTIONS)
STAFF = "Staff"
#STAFF = "TabStaff"
############################################################ ############################################################
### Targets ### Targets
@ -61,7 +60,6 @@ clean:
$(TARGETS:%=%.toc) $(TARGETS:%=%.out) $(TARGETS:%=%.log) \ $(TARGETS:%=%.toc) $(TARGETS:%=%.out) $(TARGETS:%=%.log) \
$(TARGETS:%=%.nav) $(TARGETS:%=%.snm) $(TARGETS:%=%.nav) $(TARGETS:%=%.snm)
@rm -f *.sbx *.sxd *.sxc @rm -f *.sbx *.sxd *.sxc
@rm -f lilypond/*.ps
@rm -f *.pyc @rm -f *.pyc
cleanall: clean cleanall: clean
@ -88,11 +86,23 @@ $(PDF): %.pdf: %.tex %.aux
$(MAKE_SONGBOOK) -s $< -d -o $@ $(MAKE_SONGBOOK) -s $< -d -o $@
%.pdf: %.ly %.pdf: %.ly
@$(LILYPOND) --format=pdf -e '(define-public songbookstaff $(STAFF))' --output=$(@:%.pdf=%) $< @$(LILYPOND) --format=pdf -e '(define-public songbookstaff "$(SONGBOOKSTAFF)")' --output=$(@:%.pdf=%) $<
$(CHORDS): $(CHORDS_SRC) $(CHORDS): $(CHORDS_SRC)
$(MAKE_CHORDS) -o $@ $(MAKE_CHORDS) -o $@
archive: clean
tar -czvf songbook-$(DATE).tar.gz \
--exclude=*pdf \
--exclude=.git --exclude=.gitignore \
--exclude=$(BOOKS_DIR)/default.sb \
--exclude=perso/* --exclude=perso \
--exclude=build/* --exclude=build \
--exclude=covers/* --exclude=covers \
--exclude=data/* --exclude=data \
--exclude=*tar.gz \
../songbook
ifeq (.pdf,$(suffix $(MAKECMDGOALS))) ifeq (.pdf,$(suffix $(MAKECMDGOALS)))
include $(MAKECMDGOALS:%.pdf=%.d) include $(MAKECMDGOALS:%.pdf=%.d)
else ifneq ($(MAKECMDGOALS),clean) else ifneq ($(MAKECMDGOALS),clean)

23
songbook.py

@ -9,13 +9,32 @@ import re
import json import json
import locale import locale
import sortindex import sortindex
import shutil
def copyCovers():
'''
Copy all covers found in songs/ hierarchy into a same folder. This
allows a much faster search for pdflatex since the \graphicspath
macro now only contains a single directory instead of quite a long
list to search through.
'''
#create "covers/" directory if it does not exist
d = os.path.dirname("covers/")
if not os.path.exists(d):
os.makedirs(d)
covers = list(set(glob.glob('songs/*/*.jpg')))
for cover in covers:
f = "covers/" + os.path.basename(cover)
if(os.path.exists(f) == False):
shutil.copy(cover, f)
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 ]
def songslist(songs): def songslist(songs):
directories = set(["img/"] + map(lambda x: "songs/" + os.path.dirname(x), songs)) directories = set(["img/"] + map(lambda x: "songs/" + os.path.dirname(x), songs))
result = ['\\graphicspath{'] + [ ' {{{0}/}},'.format(d) for d in directories ] + ['}'] + [ '\\input{{songs/{0}}}'.format(s.strip()) for s in songs ] result = [ '\\input{{songs/{0}}}'.format(s.strip()) for s in songs ]
return '\n'.join(result) return '\n'.join(result)
def parseTemplate(template): def parseTemplate(template):
@ -187,6 +206,8 @@ def main():
sb = json.load(f) sb = json.load(f)
f.close() f.close()
copyCovers()
if depend: if depend:
makeDepend(sb, output) makeDepend(sb, output)
else: else:

8
templates/ancient.tmpl

@ -30,8 +30,8 @@
%%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true}, %%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true},
%%: {"name":"lang", "description":"Language", "default":"english"}, %%: {"name":"lang", "description":"Language", "default":"english"},
%%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]}, %%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]},
%%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","lilypond","pictures","tabs"], "join":",", "mandatory":true, "default":["diagram","pictures"]}, %%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","importantdiagramonly","lilypond","pictures","tabs","repeatchords","onesongperpage"], "join":",", "mandatory":true, "default":["diagram","pictures"]},
%%: {"name":"version", "description":"Version", "default":"3.5.4"}, %%: {"name":"version", "description":"Version", "default":"3.5.6"},
%%: {"name":"subtitle", "description":"Subtitle"}, %%: {"name":"subtitle", "description":"Subtitle"},
%%: {"name":"web", "description":"Web", "default":"http://www.patacrep.com"}, %%: {"name":"web", "description":"Web", "default":"http://www.patacrep.com"},
%%: {"name":"mail", "description":"Email", "default":"crep@team-on-fire.com"}, %%: {"name":"mail", "description":"Email", "default":"crep@team-on-fire.com"},
@ -67,9 +67,7 @@
\newindex{titleidx}{\getname_title} \newindex{titleidx}{\getname_title}
\newauthorindex{authidx}{\getname_auth} \newauthorindex{authidx}{\getname_auth}
\graphicspath{ \graphicspath{ {covers/}, {img/} }
{img/},
}
\definecolor{SongNumberBgColor}{HTML}{\getsongnumberbgcolor} \definecolor{SongNumberBgColor}{HTML}{\getsongnumberbgcolor}
\definecolor{NoteBgColor}{HTML}{\getnotebgcolor} \definecolor{NoteBgColor}{HTML}{\getnotebgcolor}

15
templates/minimal.tmpl

@ -28,7 +28,7 @@
%%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true}, %%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true},
%%: {"name":"lang", "description":"Language", "default":"english"}, %%: {"name":"lang", "description":"Language", "default":"english"},
%%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]}, %%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]},
%%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","lilypond","tabs","pictures"], "join":",", "mandatory":true, "default":["pictures"]}, %%: {"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"}
%%:] %%:]
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@ -40,19 +40,14 @@
\usepackage[portuguese,spanish,english,french]{babel} \usepackage[portuguese,spanish,english,french]{babel}
\lang{\getlang} \lang{\getlang}
\graphicspath{ {covers/}, {img/} }
\newindex{titleidx}{\getname_title} \nosongnumbers
\newauthorindex{authidx}{\getname_auth} \pagestyle{empty}
\graphicspath{ {img/} }
%hide song number
\renewcommand{\printsongnum}[1]{}
\setlength{\songnumwidth}{0.1cm}
\begin{document} \begin{document}
\begin{songs}{titleidx,authidx} \begin{songs}{}
\getsongslist \getsongslist
\end{songs} \end{songs}

8
templates/patacrep-en.tmpl

@ -30,8 +30,8 @@
%%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true}, %%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true},
%%: {"name":"lang", "description":"Language", "default":"english"}, %%: {"name":"lang", "description":"Language", "default":"english"},
%%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]}, %%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]},
%%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","lilypond","pictures","tabs"], "join":",", "mandatory":true, "default":["diagram","pictures"]}, %%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","importantdiagramonly","lilypond","pictures","tabs","repeatchords","onesongperpage"], "join":",", "mandatory":true, "default":["diagram","pictures"]},
%%: {"name":"version", "description":"Version", "default":"3.5.4"}, %%: {"name":"version", "description":"Version", "default":"3.5.6"},
%%: {"name":"subtitle", "description":"Subtitle"}, %%: {"name":"subtitle", "description":"Subtitle"},
%%: {"name":"web", "description":"Web", "default":"http://www.patacrep.com"}, %%: {"name":"web", "description":"Web", "default":"http://www.patacrep.com"},
%%: {"name":"mail", "description":"Email", "default":"crep@team-on-fire.com"}, %%: {"name":"mail", "description":"Email", "default":"crep@team-on-fire.com"},
@ -67,9 +67,7 @@
\newindex{titleidx}{\getname_title} \newindex{titleidx}{\getname_title}
\newauthorindex{authidx}{\getname_auth} \newauthorindex{authidx}{\getname_auth}
\graphicspath{ \graphicspath{ {covers/}, {img/} }
{img/},
}
\definecolor{SongNumberBgColor}{HTML}{\getsongnumberbgcolor} \definecolor{SongNumberBgColor}{HTML}{\getsongnumberbgcolor}
\definecolor{NoteBgColor}{HTML}{\getnotebgcolor} \definecolor{NoteBgColor}{HTML}{\getnotebgcolor}

8
templates/patacrep.tmpl

@ -30,8 +30,8 @@
%%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true}, %%: {"name":"booktype", "description":"Type", "type":"enum", "values":["chorded","lyric"], "default":"chorded", "mandatory":true},
%%: {"name":"lang", "description":"Language", "default":"french"}, %%: {"name":"lang", "description":"Language", "default":"french"},
%%: {"name":"instruments", "description":"Instruments", "type":"flag", "values":["guitar","ukulele"], "join":",", "mandatory":true, "default":["guitar"]}, %%: {"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"], "join":",", "mandatory":true, "default":["diagram","pictures"]}, %%: {"name":"bookoptions", "description":"Options", "type":"flag", "values":["diagram","importantdiagramonly","lilypond","pictures","tabs","repeatchords","onesongperpage"], "join":",", "mandatory":true, "default":["diagram","pictures"]},
%%: {"name":"version", "description":"Version", "default":"3.5.4"}, %%: {"name":"version", "description":"Version", "default":"3.5.6"},
%%: {"name":"subtitle", "description":"Subtitle"}, %%: {"name":"subtitle", "description":"Subtitle"},
%%: {"name":"web", "description":"Web", "default":"http://www.patacrep.com"}, %%: {"name":"web", "description":"Web", "default":"http://www.patacrep.com"},
%%: {"name":"mail", "description":"Email", "default":"crep@team-on-fire.com"}, %%: {"name":"mail", "description":"Email", "default":"crep@team-on-fire.com"},
@ -67,9 +67,7 @@
\newindex{titleidx}{\getname_title} \newindex{titleidx}{\getname_title}
\newauthorindex{authidx}{\getname_auth} \newauthorindex{authidx}{\getname_auth}
\graphicspath{ \graphicspath{ {covers/}, {img/} }
{img/},
}
\definecolor{SongNumberBgColor}{HTML}{\getsongnumberbgcolor} \definecolor{SongNumberBgColor}{HTML}{\getsongnumberbgcolor}
\definecolor{NoteBgColor}{HTML}{\getnotebgcolor} \definecolor{NoteBgColor}{HTML}{\getnotebgcolor}

19
tex/crepbook.cls

@ -15,6 +15,7 @@
\newif{\ifnorepeatchords} \newif{\ifnorepeatchords}
\newif{\ifukulele} \newif{\ifukulele}
\newif{\ifguitar} \newif{\ifguitar}
\newif{\ifonesongperpage}
\tabsfalse \tabsfalse
\lilypondfalse \lilypondfalse
@ -24,6 +25,7 @@
\norepeatchordstrue \norepeatchordstrue
\ukulelefalse \ukulelefalse
\guitarfalse \guitarfalse
\onesongperpagefalse
% Options % Options
\DeclareOption{tabs}{\tabstrue} \DeclareOption{tabs}{\tabstrue}
@ -41,6 +43,7 @@
\DeclareOption{noukulele}{\ukulelefalse} \DeclareOption{noukulele}{\ukulelefalse}
\DeclareOption{guitar}{\guitartrue} \DeclareOption{guitar}{\guitartrue}
\DeclareOption{noguitar}{\guitarfalse} \DeclareOption{noguitar}{\guitarfalse}
\DeclareOption{onesongperpage}{\onesongperpagetrue}
\DeclareOption{10pt}{\PassOptionsToClass{\CurrentOption}{article}} \DeclareOption{10pt}{\PassOptionsToClass{\CurrentOption}{article}}
\DeclareOption{11pt}{\PassOptionsToClass{\CurrentOption}{article}} \DeclareOption{11pt}{\PassOptionsToClass{\CurrentOption}{article}}
@ -503,4 +506,20 @@
\fi \fi
}{}% }{}%
\ifonesongperpage%
\renewcommand\songcolumns[1]{%
\SB@cnt#1\relax%
\ifSB@preamble\else{\SB@clearpage}\fi%
\SB@numcols\SB@cnt%
\ifnum\SB@numcols>\z@%
\SB@colwidth-\columnsep%
\multiply\SB@colwidth\SB@numcols%
\advance\SB@colwidth\columnsep%
\advance\SB@colwidth\textwidth%
\divide\SB@colwidth\SB@numcols%
\else%
\ifrepchorus\SB@warnrc\fi%
\fi%
}
\fi
\makeatother \makeatother

6
utils/header-last-volume

@ -7,7 +7,7 @@
"pictures" "pictures"
], ],
"booktype" : "chorded", "booktype" : "chorded",
"picture" : "music_by_lauratheartist", "picture" : "The_Music_Machine_by_hit_squad",
"picturecopyright" : "LauraTheArtist @ deviantart.com", "picturecopyright" : "hit-squad @ deviantart.com",
"subtitle" : "Tome 4", "subtitle" : "Tome 5",
"songs" : [ "songs" : [

51
utils/last-volume.sh

@ -14,42 +14,33 @@ cd songs
ls -1 */*.sg > ../res1 ls -1 */*.sg > ../res1
cd .. cd ..
#get volume 1 list for i in 1 2 3 4
tail -n +13 "$BOOKS_DIR/volume-1.sb" > tmp1 do
head -n -2 tmp1 > list1 #get volume i list
sed -i -e "s/\",//g" -e "s/ \"//g" -e "s/\"//g" list1 tail -n +14 "$BOOKS_DIR/volume-$i.sb" > tmp$i
head -n -2 tmp$i > list$i
sed -i -e "s/\",//g" -e "s/ \"//g" -e "s/\"//g" list$i
#remove volume 1 songs #remove volume i songs
grep -vf list1 res1 > res2 grep -vf list$i res$i > res$(($i+1))
done
#get volume 2 list
tail -n +14 "$BOOKS_DIR/volume-2.sb" > tmp2
head -n -2 tmp2 > list2
sed -i -e "s/\",//g" -e "s/ \"//g" -e "s/\"//g" list2
#remove volume 2 songs
grep -vf list2 res2 > res3
#get volume 3 list
tail -n +14 "$BOOKS_DIR/volume-3.sb" > tmp3
head -n -2 tmp3 > list3
sed -i -e "s/\",//g" -e "s/ \"//g" -e "s/\"//g" list3
#remove volume 3 songs
grep -vf list3 res3 > res4
#format song list #format song list
sed -i -e "s/^/ \"/g" -e "s/$/\",/g" res4 sed -i -e "s/^/ \"/g" -e "s/$/\",/g" res$(($i+1))
head -c -2 res4 > res head -c -2 res$(($i+1)) > res
#make volume 4 sb file #make volume i+1 sb file
cat utils/header-last-volume > "$BOOKS_DIR/volume-4.sb" cat utils/header-last-volume > "$BOOKS_DIR/volume-$(($i+1)).sb"
cat res >> "$BOOKS_DIR/volume-4.sb" cat res >> "$BOOKS_DIR/volume-$(($i+1)).sb"
echo "]" >> "$BOOKS_DIR/volume-4.sb" echo "]" >> "$BOOKS_DIR/volume-$(($i+1)).sb"
echo "}" >> "$BOOKS_DIR/volume-4.sb" echo "}" >> "$BOOKS_DIR/volume-$(($i+1)).sb"
#remove tmp files #remove tmp files
rm -f res res1 res2 res3 res4 list1 list2 list3 tmp1 tmp2 tmp3 for i in 1 2 3 4
do
rm -f res$i list$i tmp$i
done
rm -f res res$(($i+1))
export GREP_OPTIONS="$GREP" export GREP_OPTIONS="$GREP"

27
utils/release.sh

@ -54,20 +54,17 @@ fi;
#build all songbooks #build all songbooks
rm -f *.d rm -f *.d
make cleanall make cleanall
make naheulbeuk.pdf make -j 4 naheulbeuk.pdf
make volume-1.pdf make -j 4 volume-1.pdf
make volume-2.pdf make -j 4 volume-2.pdf
make volume-3.pdf make -j 4 volume-3.pdf
make volume-4.pdf make -j 4 volume-4.pdf
make english.pdf make -j 4 volume-5.pdf
make french.pdf make -j 4 english.pdf
make songbook.pdf make -j 4 french.pdf
make lyricbook.pdf make -j 4 songbook.pdf
make -j 4 lyricbook.pdf
#clean make -j 4 archive
make clean
./utils/tarball.sh
git status git status
@ -76,7 +73,7 @@ then
./utils/new-songs-list.sh | cat - NEWS > /tmp/out && mv -f /tmp/out NEWS ./utils/new-songs-list.sh | cat - NEWS > /tmp/out && mv -f /tmp/out NEWS
echo "\nversion $MAIN.$MAJOR.$MINOR\n" | cat - NEWS > /tmp/out && mv -f /tmp/out NEWS echo "\nversion $MAIN.$MAJOR.$MINOR\n" | cat - NEWS > /tmp/out && mv -f /tmp/out NEWS
git add templates/*.tmpl git add templates/*.tmpl
git add books/volume-4.sb NEWS git add books/*.sb NEWS
git commit -m "patacrep release version $MAIN.$MAJOR.$MINOR" git commit -m "patacrep release version $MAIN.$MAJOR.$MINOR"
git tag "patacrep_$MAIN.$MAJOR.$MINOR" git tag "patacrep_$MAIN.$MAJOR.$MINOR"
fi fi

27
utils/rules.py

@ -12,6 +12,7 @@ re.LOCALE
word_dic = { word_dic = {
##: oe inclusion ##: oe inclusion
"coeur": "cœur", "coeur": "cœur",
"choeur": "chœur",
"boeuf": "bœuf", "boeuf": "bœuf",
"oeuvre": "œuvre", "oeuvre": "œuvre",
"soeur": "sœur", "soeur": "sœur",
@ -20,11 +21,17 @@ word_dic = {
"voeu": "vœu", "voeu": "vœu",
"oeuf": "œuf", "oeuf": "œuf",
"oe{}": "œ", "oe{}": "œ",
"\œ": "œ", "\\œ": "œ",
##: Contractions ##: Contractions
"ptit": "p'tit", "ptit": "p'tit",
"y'a": "y a",
"Y'a": "Y a",
"ptê": "p't'ê",
"p'": "p't'ê",
"p't-ê": "p't'ê",
##: Punctuation ##: Punctuation
"": "'", "": "'",
"": "'",
"Ca ": "Ça ", "Ca ": "Ça ",
"...": "{\\dots}", "...": "{\\dots}",
"": "{\\dots}", "": "{\\dots}",
@ -76,13 +83,13 @@ word_dic = {
"/Mi": "/E", "/Mi": "/E",
"/Fa": "/F", "/Fa": "/F",
"/Sol": "/G", "/Sol": "/G",
"gtab{La": "gtab{A", "tab{La": "tab{A",
"gtab{Si": "gtab{B", "tab{Si": "tab{B",
"gtab{Do": "gtab{C", "tab{Do": "tab{C",
"gtab{": "gtab{D", "tab{": "tab{D",
"gtab{Mi": "gtab{E", "tab{Mi": "tab{E",
"gtab{Fa": "gtab{F", "tab{Fa": "tab{F",
"gtab{Sol": "gtab{G", "tab{Sol": "tab{G",
"\\[La": "\\[A", "\\[La": "\\[A",
"\\[Si": "\\[B", "\\[Si": "\\[B",
"\\[Do": "\\[C", "\\[Do": "\\[C",
@ -161,9 +168,9 @@ def language_rules(string):
#ensure non-breaking spaces before symbols ? ! ; : #ensure non-breaking spaces before symbols ? ! ; :
string = re.sub("(?P<last_char>\S)(?P<symbol>[!?;:])","\g<last_char> \g<symbol>", string) string = re.sub("(?P<last_char>\S)(?P<symbol>[!?;:])","\g<last_char> \g<symbol>", string)
#... except for gtabs macros with capos #... except for gtabs macros with capos
string = re.sub("(?P<gtab>gtab.*)\s:","\g<gtab>:", string) string = re.sub("(?P<gtab>tab.?{.*)\s:","\g<gtab>:", string)
#and apply a second time for cases like \gtab{Gm}{10:X02210:} #and apply a second time for cases like \gtab{Gm}{10:X02210:}
string = re.sub("(?P<gtab>gtab.*)\s:","\g<gtab>:", string) string = re.sub("(?P<gtab>tab.?{.*)\s:","\g<gtab>:", string)
#ensure no spaces after symbols ( #ensure no spaces after symbols (
string = re.sub("(?P<symbol>[\(])\s(?P<next_char>\S)","\g<symbol>\g<next_char>", string) string = re.sub("(?P<symbol>[\(])\s(?P<next_char>\S)","\g<symbol>\g<next_char>", string)
#convert inverted commas #convert inverted commas

31
utils/tarball.sh

@ -1,31 +0,0 @@
#!/bin/sh
#Author: Romain Goffe
#Date: 13/10/2011
#Description: Build a tarball from the songbook git repo
#Copy songbook directory
cd $HOME
cp -RH songbook songbook-$(date +%d)-$(date +%m)-$(date +%Y);
#Remove unecessary directories
cd songbook-$(date +%d)-$(date +%m)-$(date +%Y);
rm -rf perso/ ;
rm -rf build/ ;
rm -rf data/ ;
rm -rf .git/ ;
rm -f .gitignore ;
rm -f utils/send.sh ;
rm -f books/tmp.sb books/default.sb
rm -f default*
#Clean tmp files
find . -name "*~" -or -name "#*#" -type f -exec rm -f {} \;
make cleanall
#Tarball
cd $HOME
tar czvf songbook.tar.gz songbook-$(date +%d)-$(date +%m)-$(date +%Y)
#Remove copy
rm -rf songbook-$(date +%d)-$(date +%m)-$(date +%Y)/
Loading…
Cancel
Save