Browse Source

Merge branch 'master' into nocache

pull/158/head
Louis 9 years ago
parent
commit
bbea40d9b2
  1. 50
      .appveyor.yml
  2. 22
      README.rst
  3. 3
      patacrep/__init__.py
  4. 24
      patacrep/build.py
  5. 2
      patacrep/content/song.py
  6. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_chord
  7. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_chordlist
  8. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_comment
  9. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_define
  10. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_endofline
  11. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_error
  12. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_guitar_comment
  13. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_image
  14. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_line
  15. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_newline
  16. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_partition
  17. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_space
  18. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_tablature
  19. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_verse
  20. 0
      patacrep/data/ast_templates/chordpro/chordpro/content_word
  21. 0
      patacrep/data/ast_templates/chordpro/chordpro/song
  22. 0
      patacrep/data/ast_templates/chordpro/chordpro/song_body
  23. 10
      patacrep/data/ast_templates/chordpro/chordpro/song_header
  24. 0
      patacrep/data/ast_templates/chordpro/html/content_chord
  25. 0
      patacrep/data/ast_templates/chordpro/html/content_chordlist
  26. 0
      patacrep/data/ast_templates/chordpro/html/content_comment
  27. 0
      patacrep/data/ast_templates/chordpro/html/content_define
  28. 0
      patacrep/data/ast_templates/chordpro/html/content_define_list
  29. 0
      patacrep/data/ast_templates/chordpro/html/content_endofline
  30. 0
      patacrep/data/ast_templates/chordpro/html/content_error
  31. 0
      patacrep/data/ast_templates/chordpro/html/content_guitar_comment
  32. 0
      patacrep/data/ast_templates/chordpro/html/content_image
  33. 0
      patacrep/data/ast_templates/chordpro/html/content_line
  34. 0
      patacrep/data/ast_templates/chordpro/html/content_metadata_cover
  35. 0
      patacrep/data/ast_templates/chordpro/html/content_newline
  36. 0
      patacrep/data/ast_templates/chordpro/html/content_partition
  37. 0
      patacrep/data/ast_templates/chordpro/html/content_space
  38. 0
      patacrep/data/ast_templates/chordpro/html/content_tablature
  39. 0
      patacrep/data/ast_templates/chordpro/html/content_verse
  40. 0
      patacrep/data/ast_templates/chordpro/html/content_word
  41. 0
      patacrep/data/ast_templates/chordpro/html/song
  42. 0
      patacrep/data/ast_templates/chordpro/html/song_body
  43. 0
      patacrep/data/ast_templates/chordpro/html/song_header
  44. 0
      patacrep/data/ast_templates/chordpro/latex/content_chord
  45. 0
      patacrep/data/ast_templates/chordpro/latex/content_chordlist
  46. 0
      patacrep/data/ast_templates/chordpro/latex/content_comment
  47. 0
      patacrep/data/ast_templates/chordpro/latex/content_define
  48. 0
      patacrep/data/ast_templates/chordpro/latex/content_endofline
  49. 0
      patacrep/data/ast_templates/chordpro/latex/content_error
  50. 0
      patacrep/data/ast_templates/chordpro/latex/content_guitar_comment
  51. 2
      patacrep/data/ast_templates/chordpro/latex/content_image
  52. 0
      patacrep/data/ast_templates/chordpro/latex/content_line
  53. 0
      patacrep/data/ast_templates/chordpro/latex/content_newline
  54. 6
      patacrep/data/ast_templates/chordpro/latex/content_partition
  55. 0
      patacrep/data/ast_templates/chordpro/latex/content_space
  56. 0
      patacrep/data/ast_templates/chordpro/latex/content_tablature
  57. 0
      patacrep/data/ast_templates/chordpro/latex/content_verse
  58. 0
      patacrep/data/ast_templates/chordpro/latex/content_word
  59. 4
      patacrep/data/ast_templates/chordpro/latex/song
  60. 0
      patacrep/data/ast_templates/chordpro/latex/song_body
  61. 12
      patacrep/errors.py
  62. 0
      patacrep/songbook/__init__.py
  63. 13
      patacrep/songs/chordpro/__init__.py
  64. 1
      patacrep/songs/chordpro/ast.py
  65. 6
      patacrep/songs/chordpro/data/latex/content_partition
  66. 7
      setup.py
  67. 5
      test/test_chordpro/tags.sgc
  68. 4
      test/test_chordpro/tags.source
  69. 10
      test/test_chordpro/tags.tex
  70. 18
      test/test_compilation/test_compilation.py
  71. 18
      texlive_packages.txt
  72. 2
      tox.ini

50
.appveyor.yml

@ -0,0 +1,50 @@
environment:
matrix:
- PYTHON: "C:\\Python34"
PYTHON_VERSION: "3.4.x" # currently 3.4.3
PYTHON_ARCH: "32"
install:
# Download setup scripts and unzip
- ps: "wget https://github.com/cloudify-cosmo/appveyor-utils/archive/master.zip -OutFile ./master.zip"
- "7z e master.zip */appveyor/* -oappveyor"
# Install Python (from the official .msi of http://python.org) and pip when
# not already installed.
- "powershell ./appveyor/install.ps1"
# Prepend newly installed Python to the PATH of this build (this cannot be
# done from inside the powershell script as it would require to restart
# the parent CMD process).
- "SET PATH=%PYTHON%;%PYTHON%\\Scripts;%PATH%"
# Check that we have the expected version and architecture for Python
- "python --version"
- "python -c \"import struct; print(struct.calcsize('P') * 8)\""
# Download miktex portable (if not cached)
- ps: "If (!(Test-Path miktex-portable.exe)){wget http://mirrors.ctan.org/systems/win32/miktex/setup/miktex-portable-2.9.5719.exe -OutFile ./miktex-portable.exe}"
# Unzip miktex portable
- "7z x miktex-portable.exe * -aot -omiktex > nul"
# Let the binaries be directly callable
- cmd: set PATH=%PATH%;C:\projects\patacrep\miktex\miktex\bin
# Update fonts
- cmd: luaotfload-tool.exe --update
# Manually install required texlive packages
- cmd: mpm.exe --install-some texlive_packages.txt
build: false # Not a C# project, build stuff at the test step instead.
before_test:
- "pip install tox"
test_script:
- "tox"
# Cache Miktex Portable file
cache:
- C:\projects\patacrep\miktex-portable.exe

22
README.rst

@ -1,7 +1,9 @@
Patacrep, a songbook compilation chain Patacrep, a songbook compilation chain
====================================== ======================================
|sources| |build| |pypi| |documentation| |license| |sources| |pypi| |documentation| |license|
|build-travis| |build-appveyor|
This package provides a compilation toolchain that produce LaTeX This package provides a compilation toolchain that produce LaTeX
songbook using the LaTeX songs package. A new LaTeX document class is songbook using the LaTeX songs package. A new LaTeX document class is
@ -22,10 +24,14 @@ Installation
Using pip Using pip
^^^^^^^^^ ^^^^^^^^^
As simple as:: For the stable version, as simple as::
pip3 install patacrep pip3 install patacrep
Or for the latest version::
pip3 install https://github.com/patacrep/patacrep/archive/master.zip
For developement For developement
^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^
@ -34,7 +40,7 @@ Clone Patacrep repos::
git clone git://github.com/patacrep/patacrep.git git clone git://github.com/patacrep/patacrep.git
cd patacrep cd patacrep
pip3 install -r Requirements.txt pip3 install -r Requirements.txt
python3 setup.py install python3 setup.py develop
Quick and dirty Debian (and Ubuntu?) package Quick and dirty Debian (and Ubuntu?) package
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
@ -54,8 +60,8 @@ Run
Look for existing songbook files in `patadata <http://github.com/patacrep/patadata>`_. Look for existing songbook files in `patadata <http://github.com/patacrep/patadata>`_.
More informations Documentation
----------------- -------------
The full documentation is hosted by readthedoc, here : http://patacrep.readthedocs.org/. The full documentation is hosted by readthedoc, here : http://patacrep.readthedocs.org/.
@ -72,5 +78,7 @@ Contact & Forums
:target: http://www.gnu.org/licenses/gpl-2.0.html :target: http://www.gnu.org/licenses/gpl-2.0.html
.. |sources| image:: https://img.shields.io/badge/sources-patacrep-brightgreen.svg .. |sources| image:: https://img.shields.io/badge/sources-patacrep-brightgreen.svg
:target: http://github.com/patacrep/patacrep :target: http://github.com/patacrep/patacrep
.. |build| image:: https://travis-ci.org/patacrep/patacrep.svg?branch=master .. |build-travis| image:: https://img.shields.io/travis-ci/patacrep/patacrep/master.svg?label=GNU/Linux
:target: https://travis-ci.org/patacrep/patacrep :target: https://travis-ci.org/patacrep/patacrep/branches
.. |build-appveyor| image:: https://img.shields.io/appveyor/ci/oliverpool/patacrep/master.svg?label=Windows
:target: https://ci.appveyor.com/project/oliverpool/patacrep/branch/master

3
patacrep/__init__.py

@ -17,3 +17,6 @@ __version__ = '.'.join([str(number) for number in __TUPLE_VERSION__])
# etc.) # etc.)
__DATADIR__ = os.path.abspath(resource_filename(__name__, 'data')) __DATADIR__ = os.path.abspath(resource_filename(__name__, 'data'))
def pkg_datapath(*path):
"""Return the package data path"""
return os.path.join(__DATADIR__, *path)

24
patacrep/build.py

@ -6,7 +6,7 @@ import glob
import logging import logging
import threading import threading
import os.path import os.path
from subprocess import Popen, PIPE, call from subprocess import Popen, PIPE, call, check_call
from patacrep import __DATADIR__, authors, content, errors, files from patacrep import __DATADIR__, authors, content, errors, files
from patacrep.index import process_sxd from patacrep.index import process_sxd
@ -168,10 +168,6 @@ class SongbookBuilder(object):
self._lualatex_options.append("--shell-escape") self._lualatex_options.append("--shell-escape")
if not self.interactive: if not self.interactive:
self._lualatex_options.append("-halt-on-error") self._lualatex_options.append("-halt-on-error")
for datadir in self.songbook.config["datadir"]:
self._lualatex_options.append(
'--include-directory="{}"'.format(datadir)
)
def build_steps(self, steps=None): def build_steps(self, steps=None):
"""Perform steps on the songbook by calling relevant self.build_*() """Perform steps on the songbook by calling relevant self.build_*()
@ -217,13 +213,27 @@ class SongbookBuilder(object):
LOGGER.info("Building '{}.pdf'".format(self.basename)) LOGGER.info("Building '{}.pdf'".format(self.basename))
self._run_once(self._set_latex) self._run_once(self._set_latex)
compiler = "lualatex"
# Test if the LaTeX compiler is accessible
try:
check_call(
[compiler, "--version"],
stdin=PIPE,
stdout=PIPE,
stderr=PIPE,
universal_newlines=True,
)
except Exception as error:
raise errors.ExecutableNotFound(compiler)
# Perform compilation
try: try:
process = Popen( process = Popen(
["lualatex"] + self._lualatex_options + [self.basename], [compiler] + self._lualatex_options + [self.basename],
stdin=PIPE, stdin=PIPE,
stdout=PIPE, stdout=PIPE,
stderr=PIPE, stderr=PIPE,
env=os.environ,
universal_newlines=True, universal_newlines=True,
) )
except Exception as error: except Exception as error:

2
patacrep/content/song.py

@ -42,7 +42,7 @@ class SongRenderer(Content):
{song} {song}
""").format( """).format(
separator="%"*80, separator="%"*80,
path=self.song.subpath, path=files.path2posix(self.song.subpath),
song=self.song.render(output=context['filename']), song=self.song.render(output=context['filename']),
) )

0
patacrep/songs/chordpro/data/chordpro/content_chord → patacrep/data/ast_templates/chordpro/chordpro/content_chord

0
patacrep/songs/chordpro/data/chordpro/content_chordlist → patacrep/data/ast_templates/chordpro/chordpro/content_chordlist

0
patacrep/songs/chordpro/data/chordpro/content_comment → patacrep/data/ast_templates/chordpro/chordpro/content_comment

0
patacrep/songs/chordpro/data/chordpro/content_define → patacrep/data/ast_templates/chordpro/chordpro/content_define

0
patacrep/songs/chordpro/data/chordpro/content_endofline → patacrep/data/ast_templates/chordpro/chordpro/content_endofline

0
patacrep/songs/chordpro/data/chordpro/content_error → patacrep/data/ast_templates/chordpro/chordpro/content_error

0
patacrep/songs/chordpro/data/chordpro/content_guitar_comment → patacrep/data/ast_templates/chordpro/chordpro/content_guitar_comment

0
patacrep/songs/chordpro/data/chordpro/content_image → patacrep/data/ast_templates/chordpro/chordpro/content_image

0
patacrep/songs/chordpro/data/chordpro/content_line → patacrep/data/ast_templates/chordpro/chordpro/content_line

0
patacrep/songs/chordpro/data/chordpro/content_newline → patacrep/data/ast_templates/chordpro/chordpro/content_newline

0
patacrep/songs/chordpro/data/chordpro/content_partition → patacrep/data/ast_templates/chordpro/chordpro/content_partition

0
patacrep/songs/chordpro/data/chordpro/content_space → patacrep/data/ast_templates/chordpro/chordpro/content_space

0
patacrep/songs/chordpro/data/chordpro/content_tablature → patacrep/data/ast_templates/chordpro/chordpro/content_tablature

0
patacrep/songs/chordpro/data/chordpro/content_verse → patacrep/data/ast_templates/chordpro/chordpro/content_verse

0
patacrep/songs/chordpro/data/chordpro/content_word → patacrep/data/ast_templates/chordpro/chordpro/content_word

0
patacrep/songs/chordpro/data/chordpro/song → patacrep/data/ast_templates/chordpro/chordpro/song

0
patacrep/songs/chordpro/data/chordpro/song_body → patacrep/data/ast_templates/chordpro/chordpro/song_body

10
patacrep/songs/chordpro/data/chordpro/song_header → patacrep/data/ast_templates/chordpro/chordpro/song_header

@ -14,16 +14,20 @@
(*- for author in authors -*) (*- for author in authors -*)
{artist: (( author[1] )) (( author[0] ))} {artist: (( author[1] )) (( author[0] ))}
(* endfor *) (* endfor -*)
(*- for key in ['album', 'copyright', 'tag'] *) (*- for key in ['album', 'copyright'] *)
(* if key in metadata -*) (* if key in metadata -*)
{(( key )): (( metadata[key] ))} {(( key )): (( metadata[key] ))}
(* endif *) (* endif *)
(* endfor *) (* endfor *)
(* if 'cover' in metadata -*) (* if 'cover' in metadata -*)
{(( 'cover' )): (( metadata['cover'].argument|search_image ))} {(( 'cover' )): (( metadata['cover'].argument|search_image ))}
(* endif *) (* endif -*)
(* for tag in metadata.get("tag", [])|sortargs -*)
{tag: (( tag.argument ))}
(* endfor -*)
(*- for key in metadata.morekeys -*) (*- for key in metadata.morekeys -*)
{key: (( key.keyword )): (( key.argument ))} {key: (( key.keyword )): (( key.argument ))}

0
patacrep/songs/chordpro/data/html/content_chord → patacrep/data/ast_templates/chordpro/html/content_chord

0
patacrep/songs/chordpro/data/html/content_chordlist → patacrep/data/ast_templates/chordpro/html/content_chordlist

0
patacrep/songs/chordpro/data/html/content_comment → patacrep/data/ast_templates/chordpro/html/content_comment

0
patacrep/songs/chordpro/data/html/content_define → patacrep/data/ast_templates/chordpro/html/content_define

0
patacrep/songs/chordpro/data/html/content_define_list → patacrep/data/ast_templates/chordpro/html/content_define_list

0
patacrep/songs/chordpro/data/html/content_endofline → patacrep/data/ast_templates/chordpro/html/content_endofline

0
patacrep/songs/chordpro/data/html/content_error → patacrep/data/ast_templates/chordpro/html/content_error

0
patacrep/songs/chordpro/data/html/content_guitar_comment → patacrep/data/ast_templates/chordpro/html/content_guitar_comment

0
patacrep/songs/chordpro/data/html/content_image → patacrep/data/ast_templates/chordpro/html/content_image

0
patacrep/songs/chordpro/data/html/content_line → patacrep/data/ast_templates/chordpro/html/content_line

0
patacrep/songs/chordpro/data/html/content_metadata_cover → patacrep/data/ast_templates/chordpro/html/content_metadata_cover

0
patacrep/songs/chordpro/data/html/content_newline → patacrep/data/ast_templates/chordpro/html/content_newline

0
patacrep/songs/chordpro/data/html/content_partition → patacrep/data/ast_templates/chordpro/html/content_partition

0
patacrep/songs/chordpro/data/html/content_space → patacrep/data/ast_templates/chordpro/html/content_space

0
patacrep/songs/chordpro/data/html/content_tablature → patacrep/data/ast_templates/chordpro/html/content_tablature

0
patacrep/songs/chordpro/data/html/content_verse → patacrep/data/ast_templates/chordpro/html/content_verse

0
patacrep/songs/chordpro/data/html/content_word → patacrep/data/ast_templates/chordpro/html/content_word

0
patacrep/songs/chordpro/data/html/song → patacrep/data/ast_templates/chordpro/html/song

0
patacrep/songs/chordpro/data/html/song_body → patacrep/data/ast_templates/chordpro/html/song_body

0
patacrep/songs/chordpro/data/html/song_header → patacrep/data/ast_templates/chordpro/html/song_header

0
patacrep/songs/chordpro/data/latex/content_chord → patacrep/data/ast_templates/chordpro/latex/content_chord

0
patacrep/songs/chordpro/data/latex/content_chordlist → patacrep/data/ast_templates/chordpro/latex/content_chordlist

0
patacrep/songs/chordpro/data/latex/content_comment → patacrep/data/ast_templates/chordpro/latex/content_comment

0
patacrep/songs/chordpro/data/latex/content_define → patacrep/data/ast_templates/chordpro/latex/content_define

0
patacrep/songs/chordpro/data/latex/content_endofline → patacrep/data/ast_templates/chordpro/latex/content_endofline

0
patacrep/songs/chordpro/data/latex/content_error → patacrep/data/ast_templates/chordpro/latex/content_error

0
patacrep/songs/chordpro/data/latex/content_guitar_comment → patacrep/data/ast_templates/chordpro/latex/content_guitar_comment

2
patacrep/songs/chordpro/data/latex/content_image → patacrep/data/ast_templates/chordpro/latex/content_image

@ -1,5 +1,5 @@
(* block image *) (* block image *)
(* set image = content.argument|search_image *) (* set image = content.argument|search_image|path2posix *)
(* if image *) (* if image *)
\image{(( image ))} \image{(( image ))}
(*- endif *) (*- endif *)

0
patacrep/songs/chordpro/data/latex/content_line → patacrep/data/ast_templates/chordpro/latex/content_line

0
patacrep/songs/chordpro/data/latex/content_newline → patacrep/data/ast_templates/chordpro/latex/content_newline

6
patacrep/data/ast_templates/chordpro/latex/content_partition

@ -0,0 +1,6 @@
(* block partition *)
(* set partition = content.argument|search_partition|path2posix *)
(* if partition *)
\lilypond{ ((- partition -)) }
(*- endif -*)
(*- endblock -*)

0
patacrep/songs/chordpro/data/latex/content_space → patacrep/data/ast_templates/chordpro/latex/content_space

0
patacrep/songs/chordpro/data/latex/content_tablature → patacrep/data/ast_templates/chordpro/latex/content_tablature

0
patacrep/songs/chordpro/data/latex/content_verse → patacrep/data/ast_templates/chordpro/latex/content_verse

0
patacrep/songs/chordpro/data/latex/content_word → patacrep/data/ast_templates/chordpro/latex/content_word

4
patacrep/songs/chordpro/data/latex/song → patacrep/data/ast_templates/chordpro/latex/song

@ -22,14 +22,14 @@
(* endif *) (* endif *)
(* endfor *) (* endfor *)
}, },
(* for key in ['album', 'copyright', 'tag'] *) (* for key in ['album', 'copyright'] *)
(* if key in metadata *) (* if key in metadata *)
(( key ))={(( metadata[key] ))}, (( key ))={(( metadata[key] ))},
(* endif *) (* endif *)
(* endfor *) (* endfor *)
(* if 'cover' in metadata *) (* if 'cover' in metadata *)
(* block cover *) (* block cover *)
(* set cover = metadata["cover"].argument|search_image *) (* set cover = metadata["cover"].argument|search_image|path2posix *)
(* if cover *) (* if cover *)
cover={(( cover ))}, cover={(( cover ))},
(* endif *) (* endif *)

0
patacrep/songs/chordpro/data/latex/song_body → patacrep/data/ast_templates/chordpro/latex/song_body

12
patacrep/errors.py

@ -31,6 +31,16 @@ class TemplateError(SongbookError):
else: else:
return self.message return self.message
class ExecutableNotFound(SongbookError):
"""Couldn't find a LaTeX executable."""
def __init__(self, executable):
super(ExecutableNotFound, self).__init__(
(
"""Could not find the following executable: {executable}"""
).format(executable=executable)
)
class StepError(SongbookError): class StepError(SongbookError):
"""Error during execution of one compilation step.""" """Error during execution of one compilation step."""
@ -47,7 +57,7 @@ class LatexCompilationError(StepError):
def __init__(self, basename): def __init__(self, basename):
super(LatexCompilationError, self).__init__( super(LatexCompilationError, self).__init__(
( (
"""Error while pdfLaTeX compilation of "{basename}.tex" """ """Error while LaTeX compilation of "{basename}.tex" """
"""(see {basename}.log for more information).""" """(see {basename}.log for more information)."""
).format(basename=basename) ).format(basename=basename)
) )

0
patacrep/songbook/__init__.py

13
patacrep/songs/chordpro/__init__.py

@ -3,17 +3,22 @@
from jinja2 import Environment, FileSystemLoader, contextfunction, ChoiceLoader from jinja2 import Environment, FileSystemLoader, contextfunction, ChoiceLoader
import jinja2 import jinja2
import logging import logging
import operator
import os import os
from pkg_resources import resource_filename
from patacrep import encoding, files from patacrep import encoding, files, pkg_datapath
from patacrep.songs import Song from patacrep.songs import Song
from patacrep.songs.chordpro.syntax import parse_song from patacrep.songs.chordpro.syntax import parse_song
from patacrep.templates import Renderer from patacrep.templates import Renderer
from patacrep.latex import lang2babel from patacrep.latex import lang2babel
from patacrep.files import path2posix
LOGGER = logging.getLogger(__name__) LOGGER = logging.getLogger(__name__)
def sort_directive_argument(directives):
"""Sort directives by their argument."""
return sorted(directives, key=operator.attrgetter("argument"))
class ChordproSong(Song): class ChordproSong(Song):
"""Chordpro song parser""" """Chordpro song parser"""
# pylint: disable=abstract-method # pylint: disable=abstract-method
@ -48,12 +53,14 @@ class ChordproSong(Song):
self.get_datadirs(os.path.join("templates", self.output_language)) self.get_datadirs(os.path.join("templates", self.output_language))
), ),
FileSystemLoader( FileSystemLoader(
os.path.join(resource_filename(__name__, 'data'), self.output_language) pkg_datapath('ast_templates', 'chordpro', self.output_language)
), ),
])) ]))
jinjaenv.filters['search_image'] = self.search_image jinjaenv.filters['search_image'] = self.search_image
jinjaenv.filters['search_partition'] = self.search_partition jinjaenv.filters['search_partition'] = self.search_partition
jinjaenv.filters['lang2babel'] = lang2babel jinjaenv.filters['lang2babel'] = lang2babel
jinjaenv.filters['sortargs'] = sort_directive_argument
jinjaenv.filters['path2posix'] = path2posix
try: try:
return Renderer( return Renderer(

1
patacrep/songs/chordpro/ast.py

@ -215,6 +215,7 @@ class Song(AST):
"artist": "add_author", "artist": "add_author",
"key": "add_key", "key": "add_key",
"define": "add_cumulative", "define": "add_cumulative",
"tag": "add_cumulative",
} }
def __init__(self, filename): def __init__(self, filename):

6
patacrep/songs/chordpro/data/latex/content_partition

@ -1,6 +0,0 @@
(* block partition *)
(* set partition = content.argument|search_partition *)
(* if partition *)
\lilypond{ ((- content.argument|search_partition -)) }
(*- endif -*)
(*- endblock -*)

7
setup.py

@ -21,7 +21,12 @@ setup(
"unidecode", "jinja2", "chardet", "ply", "unidecode", "jinja2", "chardet", "ply",
], ],
setup_requires=["hgtools"], setup_requires=["hgtools"],
include_package_data=True, package_data={'patacrep': [
'data/ast_templates/*/*/*',
'data/img/*',
'data/latex/*',
'data/templates/*',
]},
entry_points={ entry_points={
'console_scripts': [ 'console_scripts': [
"songbook = patacrep.songbook.__main__:main", "songbook = patacrep.songbook.__main__:main",

5
test/test_chordpro/tags.sgc

@ -0,0 +1,5 @@
{lang: en}
{title: Tag test}
{tag: a third tag}
{tag: another}
{tag: one tag}

4
test/test_chordpro/tags.source

@ -0,0 +1,4 @@
{title: Tag test}
{tag: one tag}
{tag: another}
{tag: a third tag}

10
test/test_chordpro/tags.tex

@ -0,0 +1,10 @@
\selectlanguage{english}
\beginsong{Tag test}[
by={
},
]
\endsong

18
test/test_compilation/test_compilation.py

@ -5,10 +5,12 @@
import glob import glob
import logging import logging
import os import os
import sys
import subprocess import subprocess
import unittest import unittest
from patacrep.encoding import open_read from patacrep.encoding import open_read
from patacrep.files import path2posix
from .. import dynamic # pylint: disable=unused-import from .. import dynamic # pylint: disable=unused-import
@ -67,16 +69,18 @@ class FileTest(unittest.TestCase, metaclass=dynamic.DynamicTest):
expected = expectfile.read().strip() expected = expectfile.read().strip()
expected = expected.replace( expected = expected.replace(
"@TEST_FOLDER@", "@TEST_FOLDER@",
os.path.dirname(__file__), path2posix(os.path.dirname(__file__)),
) )
expected = expected.replace( expected = expected.replace(
"@DATA_FOLDER@", "@DATA_FOLDER@",
path2posix(
subprocess.check_output( subprocess.check_output(
["python", "-c", 'import patacrep, pkg_resources; print(pkg_resources.resource_filename(patacrep.__name__, "data"))'], # pylint: disable=line-too-long [sys.executable, "-c", 'import patacrep; print(patacrep.__DATADIR__)'], # pylint: disable=line-too-long
universal_newlines=True, universal_newlines=True,
cwd=os.path.dirname(songbook), cwd=os.path.dirname(songbook),
).strip(), ).strip()
),
) )
self.assertMultiLineEqual( self.assertMultiLineEqual(
@ -108,12 +112,16 @@ class FileTest(unittest.TestCase, metaclass=dynamic.DynamicTest):
@staticmethod @staticmethod
def compile_songbook(songbook, steps=None): def compile_songbook(songbook, steps=None):
"""Compile songbook, and return the command return code.""" """Compile songbook, and return the command return code."""
command = ['python', '-m', 'patacrep.songbook', '--cache=no', songbook, '-v'] command = [sys.executable, '-m', 'patacrep.songbook', '--cache=no', songbook, '-v']
if steps: if steps:
command.extend(['--steps', steps]) command.extend(['--steps', steps])
# Continuous Integration will be verbose
if 'CI' in os.environ:
command.append('-v')
try: try:
subprocess.check_output( subprocess.check_call(
command, command,
stderr=subprocess.STDOUT, stderr=subprocess.STDOUT,
universal_newlines=True, universal_newlines=True,

18
texlive_packages.txt

@ -0,0 +1,18 @@
babel-english
babel-esperanto
babel-french
babel-german
babel-latin
babel-spanish
fancybox
framed
import
l3kernel
l3packages
mptopdf
ms
pgf
tipa
url
xcolor
xstring

2
tox.ini

@ -7,7 +7,7 @@ envlist = py34, lint
[testenv] [testenv]
commands = {envpython} setup.py test commands = {envpython} setup.py test
passenv = TRAVIS passenv = TRAVIS APPVEYOR CI
deps = deps =
[testenv:lint] [testenv:lint]

Loading…
Cancel
Save