← Back to team overview

openlp-core team mailing list archive

[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