openlp-core team mailing list archive
-
openlp-core team
-
Mailing list archive
-
Message #16064
[Merge] lp:~phill-ridout/openlp/issue-507 into lp:openlp
phill has proposed merging lp:~phill-ridout/openlp/issue-507 into lp:openlp.
Requested reviews:
Andreas Preikschat (googol)
For more details, see:
https://code.launchpad.net/~phill-ridout/openlp/issue-507/+merge/110858
A fix for issue 507. http://support.openlp.org/issues/507
The opensong database file contained verses containing sub-elements such as <i> tags. lxml considders the text of an element up until the first sub element.
--
https://code.launchpad.net/~phill-ridout/openlp/issue-507/+merge/110858
Your team OpenLP Core is subscribed to branch lp:openlp.
=== modified file 'openlp/plugins/bibles/lib/opensong.py'
--- openlp/plugins/bibles/lib/opensong.py 2012-04-04 07:26:51 +0000
+++ openlp/plugins/bibles/lib/opensong.py 2012-06-18 16:43:21 +0000
@@ -46,6 +46,22 @@
BibleDB.__init__(self, parent, **kwargs)
self.filename = kwargs['filename']
+ def get_text(self, element):
+ """
+ Recursively get all text in an objectify element and its child elements.
+
+ ``element``
+ An objectify element to get the text from
+ """
+ verse_text = u''
+ if element.text:
+ verse_text = element.text
+ for sub_element in element.iterchildren():
+ verse_text += self.get_text(sub_element)
+ if element.tail:
+ verse_text += element.tail
+ return verse_text
+
def do_import(self, bible_name=None):
"""
Loads a Bible from file.
@@ -89,7 +105,7 @@
db_book.id,
int(chapter.attrib[u'n'].split()[-1]),
int(verse.attrib[u'n']),
- unicode(verse.text))
+ unicode(self.get_text(verse)))
self.wizard.incrementProgressBar(unicode(translate(
'BiblesPlugin.Opensong', 'Importing %s %s...',
'Importing <book name> <chapter>...')) %
Follow ups