Source code for ly.pitch.translate
# This file is part of python-ly, https://pypi.python.org/pypi/python-ly
#
# Copyright (c) 2008 - 2015 by Wilbert Berendsen
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
# See http://www.gnu.org/licenses/ for more information.
"""
Translating the language of pitch names
"""
from __future__ import unicode_literals
import ly.document
import ly.pitch
[docs]def translate(cursor, language, default_language="nederlands"):
r"""Changes the language of the pitch names.
May raise ly.pitch.PitchNameNotAvailable if the current pitch language
has no quarter tones.
Returns True if there also was a \language or \include language command
that was changed. If not and the cursor specified only a part of the
document, you could warn the user that a language or include command
should be added to the document. Or you could call insert_language to
add a language command to the top of the document.
"""
start = cursor.start
cursor.start = 0
source = ly.document.Source(cursor, tokens_with_position=True)
pitches = ly.pitch.PitchIterator(source, default_language)
tokens = pitches.tokens()
writer = ly.pitch.pitchWriter(language)
if start > 0:
# consume tokens before the selection, following the language
source.consume(tokens, start)
cursor.start = start
changed = False # track change of \language or \include language command
with cursor.document as d:
for t in tokens:
if isinstance(t, ly.lex.lilypond.Note):
# translate the pitch name
p = pitches.read(t)
if p:
n = writer(*p)
if n != t:
d[t.pos:t.end] = n
elif isinstance(t, ly.pitch.LanguageName):
if t != language:
# change the language name in a command
d[t.pos:t.end] = language
changed = True
return changed
[docs]def insert_language(document, language, version=None):
r"""Inserts a language command in the document.
The command is inserted at the top or just below the version line.
If the LilyPond version specified < (2, 13, 38), the \include command
is used, otherwise the newer \language command.
"""
# maybe TODO: determine version automatically from document
if version and version < (2, 13, 38):
text = '\\include "{0}.ly"\n'
else:
text = '\\language "{0}"\n'
text = text.format(language)
# insert language command on top of file, but below version
with document:
for b in document:
if '\\version' not in document.tokens(b):
pos = document.position(b)
document[pos:pos] = text
break
else:
pos = document.size()
document[pos:pos] = '\n\n' + text