forked from openlp/openlp
fix verse order rebuild to handle single character verse references
rename variable to avoid using the 'type' keyword
This commit is contained in:
parent
a80a953980
commit
8439d1ed4f
@ -278,24 +278,29 @@ def clean_song(manager, song):
|
|||||||
# List for later comparison.
|
# List for later comparison.
|
||||||
compare_order = []
|
compare_order = []
|
||||||
for verse in verses:
|
for verse in verses:
|
||||||
type = VerseType.Tags[VerseType.from_loose_input(verse[0][u'type'])]
|
verse_type =
|
||||||
|
VerseType.Tags[VerseType.from_loose_input(verse[0][u'type'])]
|
||||||
sxml.add_verse_to_lyrics(
|
sxml.add_verse_to_lyrics(
|
||||||
type,
|
verse_type,
|
||||||
verse[0][u'label'],
|
verse[0][u'label'],
|
||||||
verse[1],
|
verse[1],
|
||||||
verse[0][u'lang'] if verse[0].has_key(u'lang') else None
|
verse[0][u'lang'] if verse[0].has_key(u'lang') else None
|
||||||
)
|
)
|
||||||
compare_order.append((u'%s%s' % (type, verse[0][u'label'])).upper())
|
compare_order.append((u'%s%s' % (verse_type, verse[0][u'label'])
|
||||||
|
).upper())
|
||||||
|
if verse[0][u'label'] == u'1':
|
||||||
|
compare_order.append(verse_type.upper())
|
||||||
song.lyrics = unicode(sxml.extract_xml(), u'utf-8')
|
song.lyrics = unicode(sxml.extract_xml(), u'utf-8')
|
||||||
# Rebuild the verse order, to convert translated verse tags, which might
|
# Rebuild the verse order, to convert translated verse tags, which might
|
||||||
# have been added prior to 1.9.5.
|
# have been added prior to 1.9.5.
|
||||||
order = song.verse_order.strip().split()
|
order = song.verse_order.strip().split()
|
||||||
new_order = []
|
new_order = []
|
||||||
for verse_def in order:
|
for verse_def in order:
|
||||||
new_order.append((u'%s%s' % (
|
verse_type = VerseType.Tags[VerseType.from_loose_input(verse_def[0])]
|
||||||
VerseType.Tags[VerseType.from_loose_input(verse_def[0])],
|
if len(verse_def) > 1:
|
||||||
verse_def[1:])).upper()
|
new_order.append((u'%s%s' % (verse_type, verse_def[1:])).upper())
|
||||||
)
|
else:
|
||||||
|
new_order.append(verse_type.upper())
|
||||||
song.verse_order = u' '.join(new_order)
|
song.verse_order = u' '.join(new_order)
|
||||||
# Check if the verse order contains tags for verses which do not exist.
|
# Check if the verse order contains tags for verses which do not exist.
|
||||||
for order in new_order:
|
for order in new_order:
|
||||||
|
Loading…
Reference in New Issue
Block a user