2009-09-08 19:58:05 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
2013-01-01 16:33:41 +00:00
|
|
|
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
|
2009-09-08 19:58:05 +00:00
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
|
|
# --------------------------------------------------------------------------- #
|
2015-12-31 22:46:06 +00:00
|
|
|
# Copyright (c) 2008-2016 OpenLP Developers #
|
2009-09-08 19:58:05 +00:00
|
|
|
# --------------------------------------------------------------------------- #
|
|
|
|
# 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; version 2 of the License. #
|
|
|
|
# #
|
|
|
|
# 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., 59 #
|
|
|
|
# Temple Place, Suite 330, Boston, MA 02111-1307 USA #
|
|
|
|
###############################################################################
|
2009-07-13 20:08:43 +00:00
|
|
|
|
2009-02-02 19:54:38 +00:00
|
|
|
import logging
|
2014-08-24 14:40:45 +00:00
|
|
|
from lxml import etree
|
2009-07-13 20:08:43 +00:00
|
|
|
|
2016-08-07 11:20:53 +00:00
|
|
|
from openlp.core.common import translate, trace_error_handler
|
2014-08-24 14:40:45 +00:00
|
|
|
from openlp.core.lib.ui import critical_error_message_box
|
2016-08-07 10:15:43 +00:00
|
|
|
from openlp.plugins.bibles.lib.bibleimport import BibleImport
|
2016-08-07 11:20:53 +00:00
|
|
|
from openlp.plugins.bibles.lib.db import BiblesResourcesDB
|
2008-11-19 18:13:22 +00:00
|
|
|
|
2010-02-27 15:31:23 +00:00
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
2016-08-07 10:15:43 +00:00
|
|
|
# Tags we don't use and can remove the content
|
|
|
|
REMOVABLE_ELEMENTS = ('{http://www.bibletechnologies.net/2003/OSIS/namespace}note',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}milestone',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}title',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}abbr',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}catchWord',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}index',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}rdg',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}rdgGroup',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}figure')
|
|
|
|
# Tags we don't use but need to keep the content
|
|
|
|
REMOVABLE_TAGS = ('{http://www.bibletechnologies.net/2003/OSIS/namespace}p',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}l',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}lg',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}q',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}a',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}w',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}divineName',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}foreign',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}hi',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}inscription',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}mentioned',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}name',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}reference',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}seg',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}transChange',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}salute',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}signed',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}closer',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}speech',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}speaker',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}list',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}item',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}table',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}head',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}row',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}cell',
|
|
|
|
'{http://www.bibletechnologies.net/2003/OSIS/namespace}caption')
|
2013-04-18 17:45:14 +00:00
|
|
|
|
2016-08-07 11:20:53 +00:00
|
|
|
|
2011-04-27 14:54:27 +00:00
|
|
|
def replacement(match):
|
|
|
|
return match.group(2).upper()
|
|
|
|
|
2013-04-18 17:45:14 +00:00
|
|
|
|
2016-08-07 10:15:43 +00:00
|
|
|
class OSISBible(BibleImport):
|
2009-07-13 20:08:43 +00:00
|
|
|
"""
|
2011-02-24 14:43:24 +00:00
|
|
|
`OSIS <http://www.bibletechnologies.net/>`_ Bible format importer class.
|
2009-07-13 20:08:43 +00:00
|
|
|
"""
|
2011-05-26 19:13:11 +00:00
|
|
|
def do_import(self, bible_name=None):
|
2009-07-13 20:08:43 +00:00
|
|
|
"""
|
|
|
|
Loads a Bible from file.
|
|
|
|
"""
|
2016-05-21 08:31:24 +00:00
|
|
|
log.debug('Starting OSIS import from "{name}"'.format(name=self.filename))
|
2010-12-06 19:30:04 +00:00
|
|
|
success = True
|
2009-11-07 00:00:36 +00:00
|
|
|
try:
|
2016-08-07 10:15:43 +00:00
|
|
|
self.wizard.increment_progress_bar(translate('BiblesPlugin.OsisImport',
|
|
|
|
'Removing unused tags (this may take a few minutes)...'))
|
|
|
|
osis_bible_tree = self.parse_xml(self.filename, elements=REMOVABLE_ELEMENTS, tags=REMOVABLE_TAGS)
|
2014-08-27 13:10:33 +00:00
|
|
|
namespace = {'ns': 'http://www.bibletechnologies.net/2003/OSIS/namespace'}
|
2016-08-07 10:15:43 +00:00
|
|
|
# Find bible language]
|
|
|
|
language = osis_bible_tree.xpath("//ns:osisText/@xml:lang", namespaces=namespace)
|
|
|
|
language_id = self.get_language_id(language[0] if language else None, bible_name=self.filename)
|
2014-08-24 14:40:45 +00:00
|
|
|
if not language_id:
|
|
|
|
return False
|
|
|
|
num_books = int(osis_bible_tree.xpath("count(//ns:div[@type='book'])", namespaces=namespace))
|
|
|
|
# Precompile a few xpath-querys
|
|
|
|
verse_in_chapter = etree.XPath('count(//ns:chapter[1]/ns:verse)', namespaces=namespace)
|
|
|
|
text_in_verse = etree.XPath('count(//ns:verse[1]/text())', namespaces=namespace)
|
|
|
|
# Find books in the bible
|
|
|
|
bible_books = osis_bible_tree.xpath("//ns:div[@type='book']", namespaces=namespace)
|
|
|
|
for book in bible_books:
|
2012-02-29 12:00:05 +00:00
|
|
|
if self.stop_import_flag:
|
|
|
|
break
|
2014-08-24 14:40:45 +00:00
|
|
|
# Remove div-tags in the book
|
|
|
|
etree.strip_tags(book, ('{http://www.bibletechnologies.net/2003/OSIS/namespace}div'))
|
2015-03-09 20:42:03 +00:00
|
|
|
book_ref_id = self.get_book_ref_id_by_name(book.get('osisID'), num_books, language_id)
|
2014-08-24 14:40:45 +00:00
|
|
|
if not book_ref_id:
|
2016-05-21 08:31:24 +00:00
|
|
|
log.error('Importing books from "{name}" failed'.format(name=self.filename))
|
2014-08-24 14:40:45 +00:00
|
|
|
return False
|
|
|
|
book_details = BiblesResourcesDB.get_book_by_id(book_ref_id)
|
|
|
|
db_book = self.create_book(book_details['name'], book_ref_id, book_details['testament_id'])
|
|
|
|
# Find out if chapter-tags contains the verses, or if it is used as milestone/anchor
|
|
|
|
if int(verse_in_chapter(book)) > 0:
|
|
|
|
# The chapter tags contains the verses
|
|
|
|
for chapter in book:
|
|
|
|
chapter_number = chapter.get("osisID").split('.')[1]
|
|
|
|
# Find out if verse-tags contains the text, or if it is used as milestone/anchor
|
|
|
|
if int(text_in_verse(chapter)) == 0:
|
|
|
|
# verse-tags are used as milestone
|
|
|
|
for verse in chapter:
|
|
|
|
# If this tag marks the start of a verse, the verse text is between this tag and
|
|
|
|
# the next tag, which the "tail" attribute gives us.
|
|
|
|
if verse.get('sID'):
|
|
|
|
verse_number = verse.get("osisID").split('.')[2]
|
|
|
|
verse_text = verse.tail
|
|
|
|
if verse_text:
|
|
|
|
self.create_verse(db_book.id, chapter_number, verse_number, verse_text.strip())
|
|
|
|
else:
|
|
|
|
# Verse-tags contains the text
|
|
|
|
for verse in chapter:
|
|
|
|
verse_number = verse.get("osisID").split('.')[2]
|
2015-07-04 22:19:13 +00:00
|
|
|
if verse.text:
|
|
|
|
self.create_verse(db_book.id, chapter_number, verse_number, verse.text.strip())
|
2014-03-09 10:26:28 +00:00
|
|
|
self.wizard.increment_progress_bar(
|
2015-02-27 21:14:08 +00:00
|
|
|
translate('BiblesPlugin.OsisImport', 'Importing %(bookname)s %(chapter)s...') %
|
2015-03-09 20:57:39 +00:00
|
|
|
{'bookname': db_book.name, 'chapter': chapter_number})
|
2014-08-24 14:40:45 +00:00
|
|
|
else:
|
|
|
|
# The chapter tags is used as milestones. For now we assume verses is also milestones
|
|
|
|
chapter_number = 0
|
|
|
|
for element in book:
|
|
|
|
if element.tag == '{http://www.bibletechnologies.net/2003/OSIS/namespace}chapter' \
|
|
|
|
and element.get('sID'):
|
|
|
|
chapter_number = element.get("osisID").split('.')[1]
|
|
|
|
self.wizard.increment_progress_bar(
|
2015-02-27 21:14:08 +00:00
|
|
|
translate('BiblesPlugin.OsisImport', 'Importing %(bookname)s %(chapter)s...') %
|
2015-03-09 20:57:39 +00:00
|
|
|
{'bookname': db_book.name, 'chapter': chapter_number})
|
2014-08-24 14:40:45 +00:00
|
|
|
elif element.tag == '{http://www.bibletechnologies.net/2003/OSIS/namespace}verse' \
|
|
|
|
and element.get('sID'):
|
|
|
|
# If this tag marks the start of a verse, the verse text is between this tag and
|
|
|
|
# the next tag, which the "tail" attribute gives us.
|
|
|
|
verse_number = element.get("osisID").split('.')[2]
|
|
|
|
verse_text = element.tail
|
|
|
|
if verse_text:
|
|
|
|
self.create_verse(db_book.id, chapter_number, verse_number, verse_text.strip())
|
|
|
|
self.session.commit()
|
|
|
|
self.application.process_events()
|
2010-05-29 19:50:50 +00:00
|
|
|
except (ValueError, IOError):
|
2013-08-31 18:17:38 +00:00
|
|
|
log.exception('Loading bible from OSIS file failed')
|
2014-08-24 14:40:45 +00:00
|
|
|
trace_error_handler(log)
|
|
|
|
success = False
|
|
|
|
except etree.XMLSyntaxError as e:
|
|
|
|
log.exception('Loading bible from OSIS file failed')
|
|
|
|
trace_error_handler(log)
|
2009-12-27 22:19:39 +00:00
|
|
|
success = False
|
2014-08-24 14:40:45 +00:00
|
|
|
critical_error_message_box(message=translate('BiblesPlugin.OsisImport',
|
2016-05-21 08:31:24 +00:00
|
|
|
'The file is not a valid OSIS-XML file:'
|
|
|
|
'\n{text}').format(text=e.msg))
|
2010-02-06 15:33:23 +00:00
|
|
|
if self.stop_import_flag:
|
2009-12-27 22:19:39 +00:00
|
|
|
return False
|
|
|
|
else:
|
2010-12-28 11:18:56 +00:00
|
|
|
return success
|