forked from openlp/openlp
Various fixes:
- Started the conversion of SQL to SQLAlchemy - Found a bug in the generating of Bible slides - Some code cleanups
This commit is contained in:
commit
dc10f0e2a4
@ -1,6 +1,8 @@
|
|||||||
"""
|
"""
|
||||||
OpenLP - Open Source Lyrics Projection
|
OpenLP - Open Source Lyrics Projection
|
||||||
|
|
||||||
Copyright (c) 2008 Raoul Snyman
|
Copyright (c) 2008 Raoul Snyman
|
||||||
|
|
||||||
Portions copyright (c) 2008 - 2009 Martin Thompson, Tim Bentley
|
Portions copyright (c) 2008 - 2009 Martin Thompson, Tim Bentley
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it under
|
This program is free software; you can redistribute it and/or modify it under
|
||||||
@ -20,7 +22,7 @@ import os.path
|
|||||||
import logging
|
import logging
|
||||||
|
|
||||||
from sqlalchemy import *
|
from sqlalchemy import *
|
||||||
from sqlalchemy.sql import select
|
from sqlalchemy.sql import select, func
|
||||||
from sqlalchemy.orm import sessionmaker, mapper, scoped_session
|
from sqlalchemy.orm import sessionmaker, mapper, scoped_session
|
||||||
|
|
||||||
from common import BibleCommon
|
from common import BibleCommon
|
||||||
@ -91,7 +93,7 @@ class BibleDBImpl(BibleCommon):
|
|||||||
def create_book(self, bookname, bookabbrev, testament = 1):
|
def create_book(self, bookname, bookabbrev, testament = 1):
|
||||||
log.debug(u'create_book %s,%s', bookname, bookabbrev)
|
log.debug(u'create_book %s,%s', bookname, bookabbrev)
|
||||||
metadata.bind.echo = False
|
metadata.bind.echo = False
|
||||||
session = self.session()
|
session = self.session
|
||||||
book = Book()
|
book = Book()
|
||||||
book.testament_id = testament
|
book.testament_id = testament
|
||||||
book.name = bookname
|
book.name = bookname
|
||||||
@ -103,7 +105,7 @@ class BibleDBImpl(BibleCommon):
|
|||||||
def save_meta(self, key, value):
|
def save_meta(self, key, value):
|
||||||
log.debug(u'save_meta %s/%s', key, value)
|
log.debug(u'save_meta %s/%s', key, value)
|
||||||
metadata.bind.echo = False
|
metadata.bind.echo = False
|
||||||
session = self.session()
|
session = self.session
|
||||||
bmeta = BibleMeta()
|
bmeta = BibleMeta()
|
||||||
bmeta.key = key
|
bmeta.key = key
|
||||||
bmeta.value = value
|
bmeta.value = value
|
||||||
@ -126,7 +128,7 @@ class BibleDBImpl(BibleCommon):
|
|||||||
def _load_testament(self, testament):
|
def _load_testament(self, testament):
|
||||||
log.debug(u'load_testaments %s', testament)
|
log.debug(u'load_testaments %s', testament)
|
||||||
metadata.bind.echo = False
|
metadata.bind.echo = False
|
||||||
session = self.session()
|
session = self.session
|
||||||
test = ONTestament()
|
test = ONTestament()
|
||||||
test.name = testament
|
test.name = testament
|
||||||
session.add(test)
|
session.add(test)
|
||||||
@ -139,14 +141,18 @@ class BibleDBImpl(BibleCommon):
|
|||||||
def get_max_bible_book_verses(self, bookname, chapter):
|
def get_max_bible_book_verses(self, bookname, chapter):
|
||||||
log.debug(u'get_max_bible_book_verses %s, %s', bookname, chapter)
|
log.debug(u'get_max_bible_book_verses %s, %s', bookname, chapter)
|
||||||
metadata.bind.echo = False
|
metadata.bind.echo = False
|
||||||
s = text (u'select max(verse.verse) from verse,book where chapter = :c and book_id = book.id and book.name = :b ')
|
#s = text (u'select max(verse.verse) from verse,book where chapter = :c and book_id = book.id and book.name = :b ')
|
||||||
return self.db.execute(s, c=chapter, b=bookname).fetchone()
|
#return self.db.execute(s, c=chapter, b=bookname).fetchone()
|
||||||
|
verse = self.session.query(Verse).join(Book).filter(Book.name==bookname).filter(Verse.chapter==chapter).order_by(Verse.verse.desc()).first()
|
||||||
|
return verse.verse
|
||||||
|
|
||||||
def get_max_bible_book_chapter(self, bookname):
|
def get_max_bible_book_chapter(self, bookname):
|
||||||
log.debug(u'get_max_bible_book_chapter %s', bookname)
|
log.debug(u'get_max_bible_book_chapter %s', bookname)
|
||||||
metadata.bind.echo = False
|
metadata.bind.echo = False
|
||||||
s = text (u'select max(verse.chapter) from verse,book where book_id = book.id and book.name = :b')
|
#s = text (u'select max(verse.chapter) from verse,book where book_id = book.id and book.name = :b')
|
||||||
return self.db.execute(s, b=bookname).fetchone()
|
#return self.db.execute(s, b=bookname).fetchone()
|
||||||
|
verse = self.session.query(Verse).join(Book).filter(Book.name==bookname).order_by(Verse.chapter.desc()).first()
|
||||||
|
return verse.chapter
|
||||||
|
|
||||||
def get_bible_book(self, bookname):
|
def get_bible_book(self, bookname):
|
||||||
log.debug(u'get_bible_book %s', bookname)
|
log.debug(u'get_bible_book %s', bookname)
|
||||||
@ -163,9 +169,11 @@ class BibleDBImpl(BibleCommon):
|
|||||||
def get_bible_text(self, bookname, chapter, sverse, everse):
|
def get_bible_text(self, bookname, chapter, sverse, everse):
|
||||||
log.debug(u'get_bible_text %s, %s, %s, %s', bookname, chapter, sverse, everse)
|
log.debug(u'get_bible_text %s, %s, %s, %s', bookname, chapter, sverse, everse)
|
||||||
metadata.bind.echo = False
|
metadata.bind.echo = False
|
||||||
bookname = bookname + u"%"
|
#bookname = bookname + u"%"
|
||||||
s = text (u'select name,chapter,verse.verse, verse.text FROM verse , book where verse.book_id == book.id AND verse.chapter == :c AND (verse.verse between :v1 and :v2) and (book.name like :b)')
|
#s = text (u'select name,chapter,verse.verse, verse.text FROM verse , book where verse.book_id == book.id AND verse.chapter == :c AND (verse.verse between :v1 and :v2) and (book.name like :b)')
|
||||||
return self.db.execute(s, c=chapter, v1=sverse , v2=everse, b=bookname).fetchall()
|
#return self.db.execute(s, c=chapter, v1=sverse , v2=everse, b=bookname).fetchall()
|
||||||
|
verses = self.session.query(Verse).join(Book).filter(Book.name==bookname).filter(Verse.chapter==chapter).filter(Verse.verse>=sverse).filter(Verse.verse<=everse).order_by(Verse.verse).all()
|
||||||
|
return verses
|
||||||
|
|
||||||
def get_verses_from_text(self,versetext):
|
def get_verses_from_text(self,versetext):
|
||||||
log.debug(u'get_verses_from_text %s',versetext)
|
log.debug(u'get_verses_from_text %s',versetext)
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
"""
|
"""
|
||||||
OpenLP - Open Source Lyrics Projection
|
OpenLP - Open Source Lyrics Projection
|
||||||
|
|
||||||
Copyright (c) 2008 Raoul Snyman
|
Copyright (c) 2008 Raoul Snyman
|
||||||
|
|
||||||
Portions copyright (c) 2008 - 2009 Martin Thompson, Tim Bentley
|
Portions copyright (c) 2008 - 2009 Martin Thompson, Tim Bentley
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it under
|
This program is free software; you can redistribute it and/or modify it under
|
||||||
@ -20,37 +22,69 @@ import os.path
|
|||||||
import logging
|
import logging
|
||||||
import chardet
|
import chardet
|
||||||
import codecs
|
import codecs
|
||||||
from openlp.plugins.bibles.lib.bibleDBimpl import BibleDBImpl
|
|
||||||
from openlp.core.lib import Receiver
|
|
||||||
from PyQt4 import QtCore
|
from PyQt4 import QtCore
|
||||||
|
|
||||||
|
from openlp.plugins.bibles.lib.bibleDBimpl import BibleDBImpl
|
||||||
|
from openlp.core.lib import Receiver
|
||||||
|
|
||||||
class BibleOSISImpl():
|
class BibleOSISImpl():
|
||||||
|
"""
|
||||||
|
OSIS Bible format importer class.
|
||||||
|
"""
|
||||||
global log
|
global log
|
||||||
log = logging.getLogger(u'BibleOSISImpl')
|
log = logging.getLogger(u'BibleOSISImpl')
|
||||||
log.info(u'BibleOSISImpl loaded')
|
log.info(u'BibleOSISImpl loaded')
|
||||||
|
|
||||||
def __init__(self, biblepath, bibledb):
|
def __init__(self, biblepath, bibledb):
|
||||||
|
"""
|
||||||
|
Constructor to create and set up an instance of the
|
||||||
|
BibleOSISImpl class.
|
||||||
|
|
||||||
|
``biblepath``
|
||||||
|
This does not seem to be used.
|
||||||
|
|
||||||
|
``bibledb``
|
||||||
|
A reference to a Bible database object.
|
||||||
|
"""
|
||||||
self.bibledb = bibledb
|
self.bibledb = bibledb
|
||||||
# books of the bible linked to bibleid {osis , name}
|
# books of the bible linked to bibleid {osis , name}
|
||||||
self.booksOfBible = {}
|
self.booksOfBible = {}
|
||||||
# books of the bible linked to bibleid {osis ,Abbrev }
|
# books of the bible linked to bibleid {osis ,Abbrev }
|
||||||
self.abbrevOfBible = {}
|
self.abbrevOfBible = {}
|
||||||
|
|
||||||
filepath = os.path.split(os.path.abspath(__file__))[0]
|
filepath = os.path.split(os.path.abspath(__file__))[0]
|
||||||
filepath = os.path.abspath(os.path.join(filepath, u'..', u'resources',u'osisbooks.csv'))
|
filepath = os.path.abspath(os.path.join(
|
||||||
|
filepath, u'..', u'resources',u'osisbooks.csv'))
|
||||||
fbibles=open(filepath, u'r')
|
fbibles=open(filepath, u'r')
|
||||||
for line in fbibles:
|
for line in fbibles:
|
||||||
p = line.split(u',')
|
p = line.split(u',')
|
||||||
self.booksOfBible[p[0]] = p[1].replace(u'\n', u'')
|
self.booksOfBible[p[0]] = p[1].replace(u'\n', u'')
|
||||||
self.abbrevOfBible[p[0]] = p[2].replace(u'\n', u'')
|
self.abbrevOfBible[p[0]] = p[2].replace(u'\n', u'')
|
||||||
self.loadbible = True
|
self.loadbible = True
|
||||||
QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL(u'openlpstopimport'),self.stop_import)
|
QtCore.QObject.connect(Receiver().get_receiver(),
|
||||||
|
QtCore.SIGNAL(u'openlpstopimport'), self.stop_import)
|
||||||
|
|
||||||
def stop_import(self):
|
def stop_import(self):
|
||||||
|
"""
|
||||||
|
Stops the import of the Bible.
|
||||||
|
"""
|
||||||
self.loadbible = False
|
self.loadbible = False
|
||||||
|
|
||||||
def load_data(self, osisfile_record, dialogobject=None):
|
def load_data(self, osisfile_record, dialogobject=None):
|
||||||
osis = codecs.open(osisfile_record, u'r')
|
"""
|
||||||
|
Loads a Bible from file.
|
||||||
|
|
||||||
|
``osisfile_record``
|
||||||
|
The file to import from.
|
||||||
|
|
||||||
|
``dialogobject``
|
||||||
|
The Import dialog, so that we can increase the counter on
|
||||||
|
the progress bar.
|
||||||
|
"""
|
||||||
|
detect_file = open(osisfile_record, u'r')
|
||||||
|
details = chardet.detect(detect_file.read(2048))
|
||||||
|
detect_file.close()
|
||||||
|
osis = codecs.open(osisfile_record, u'r', details['encoding'])
|
||||||
book_ptr = None
|
book_ptr = None
|
||||||
id = 0
|
id = 0
|
||||||
count = 0
|
count = 0
|
||||||
@ -110,8 +144,11 @@ class BibleOSISImpl():
|
|||||||
if p[0] == u'Matt':
|
if p[0] == u'Matt':
|
||||||
testament += 1
|
testament += 1
|
||||||
book_ptr = p[0]
|
book_ptr = p[0]
|
||||||
book = self.bibledb.create_book(self.booksOfBible[p[0]] , self.abbrevOfBible[p[0]], testament)
|
book = self.bibledb.create_book(
|
||||||
dialogobject.incrementProgressBar(self.booksOfBible[p[0]] )
|
self.booksOfBible[p[0]],
|
||||||
|
self.abbrevOfBible[p[0]], testament)
|
||||||
|
dialogobject.incrementProgressBar(
|
||||||
|
self.booksOfBible[p[0]])
|
||||||
Receiver().send_message(u'openlpprocessevents')
|
Receiver().send_message(u'openlpprocessevents')
|
||||||
count = 0
|
count = 0
|
||||||
self.bibledb.add_verse(book.id, p[1], p[2], text)
|
self.bibledb.add_verse(book.id, p[1], p[2], text)
|
||||||
@ -123,8 +160,18 @@ class BibleOSISImpl():
|
|||||||
|
|
||||||
def remove_block(self, start_tag, end_tag, text):
|
def remove_block(self, start_tag, end_tag, text):
|
||||||
"""
|
"""
|
||||||
removes a block of text between two tags
|
Removes a block of text between two tags::
|
||||||
<tag attrib=xvf > Some not wanted text </tag>
|
|
||||||
|
<tag attrib="xvf">Some not wanted text</tag>
|
||||||
|
|
||||||
|
``start_tag``
|
||||||
|
The XML tag to look for.
|
||||||
|
|
||||||
|
``end_tag``
|
||||||
|
The ending XML tag.
|
||||||
|
|
||||||
|
``text``
|
||||||
|
The string of XML to search.
|
||||||
"""
|
"""
|
||||||
pos = text.find(start_tag)
|
pos = text.find(start_tag)
|
||||||
while pos > -1:
|
while pos > -1:
|
||||||
@ -138,8 +185,15 @@ class BibleOSISImpl():
|
|||||||
|
|
||||||
def remove_tag(self, start_tag, text):
|
def remove_tag(self, start_tag, text):
|
||||||
"""
|
"""
|
||||||
removes a single tag
|
Removes a single tag::
|
||||||
<tag attrib1=fajkdf attrib2=fajkdf attrib2=fajkdf />
|
|
||||||
|
<tag attrib1="fajkdf" attrib2="fajkdf" attrib3="fajkdf" />
|
||||||
|
|
||||||
|
``start_tag``
|
||||||
|
The XML tag to remove.
|
||||||
|
|
||||||
|
``text``
|
||||||
|
The string of XML to search.
|
||||||
"""
|
"""
|
||||||
pos = text.find(start_tag)
|
pos = text.find(start_tag)
|
||||||
while pos > -1:
|
while pos > -1:
|
||||||
|
@ -2,7 +2,9 @@
|
|||||||
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
|
||||||
"""
|
"""
|
||||||
OpenLP - Open Source Lyrics Projection
|
OpenLP - Open Source Lyrics Projection
|
||||||
|
|
||||||
Copyright (c) 2008 Raoul Snyman
|
Copyright (c) 2008 Raoul Snyman
|
||||||
|
|
||||||
Portions copyright (c) 2008 - 2009 Martin Thompson, Tim Bentley
|
Portions copyright (c) 2008 - 2009 Martin Thompson, Tim Bentley
|
||||||
|
|
||||||
This program is free software; you can redistribute it and/or modify it under
|
This program is free software; you can redistribute it and/or modify it under
|
||||||
@ -18,7 +20,7 @@ this program; if not, write to the Free Software Foundation, Inc., 59 Temple
|
|||||||
Place, Suite 330, Boston, MA 02111-1307 USA
|
Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
"""
|
"""
|
||||||
import logging
|
import logging
|
||||||
import os, os.path
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
from common import SearchResults
|
from common import SearchResults
|
||||||
@ -26,72 +28,93 @@ from bibleOSISimpl import BibleOSISImpl
|
|||||||
from bibleCSVimpl import BibleCSVImpl
|
from bibleCSVimpl import BibleCSVImpl
|
||||||
from bibleDBimpl import BibleDBImpl
|
from bibleDBimpl import BibleDBImpl
|
||||||
from bibleHTTPimpl import BibleHTTPImpl
|
from bibleHTTPimpl import BibleHTTPImpl
|
||||||
|
|
||||||
from openlp.plugins.bibles.lib.tables import *
|
from openlp.plugins.bibles.lib.tables import *
|
||||||
from openlp.plugins.bibles.lib.classes import *
|
from openlp.plugins.bibles.lib.classes import *
|
||||||
|
|
||||||
class BibleManager():
|
class BibleMode(object):
|
||||||
|
Full = 1
|
||||||
|
Partial = 2
|
||||||
|
|
||||||
|
class BibleManager(object):
|
||||||
|
"""
|
||||||
|
The Bible manager which holds and manages all the Bibles.
|
||||||
|
"""
|
||||||
global log
|
global log
|
||||||
log=logging.getLogger(u'BibleManager')
|
log=logging.getLogger(u'BibleManager')
|
||||||
log.info(u'Bible manager loaded')
|
log.info(u'Bible manager loaded')
|
||||||
|
|
||||||
def __init__(self, config):
|
def __init__(self, config):
|
||||||
"""
|
"""
|
||||||
Finds all the bibles defined for the system
|
Finds all the bibles defined for the system and creates an
|
||||||
Creates an Interface Object for each bible containing connection information
|
interface object for each bible containing connection
|
||||||
Throws Exception if no Bibles are found.
|
information. Throws Exception if no Bibles are found.
|
||||||
|
|
||||||
Init confirms the bible exists and stores the database path.
|
Init confirms the bible exists and stores the database path.
|
||||||
|
|
||||||
|
``config``
|
||||||
|
The plugin's configuration object.
|
||||||
"""
|
"""
|
||||||
self.config = config
|
self.config = config
|
||||||
log.debug(u'Bible Initialising')
|
log.debug(u'Bible Initialising')
|
||||||
self.bible_db_cache = None # dict of bible database classes
|
# dict of bible database objects
|
||||||
self.bible_http_cache = None # dict of bible http readers
|
self.bible_db_cache = None
|
||||||
|
# dict of bible http readers
|
||||||
|
self.bible_http_cache = None
|
||||||
self.biblePath = self.config.get_data_path()
|
self.biblePath = self.config.get_data_path()
|
||||||
self.proxyname = self.config.get_config(u'proxy name') #get proxy name for screen
|
#get proxy name for screen
|
||||||
|
self.proxyname = self.config.get_config(u'proxy name')
|
||||||
self.bibleSuffix = u'sqlite'
|
self.bibleSuffix = u'sqlite'
|
||||||
self.dialogobject = None
|
self.dialogobject = None
|
||||||
self.reload_bibles()
|
self.reload_bibles()
|
||||||
|
|
||||||
def reload_bibles(self):
|
def reload_bibles(self):
|
||||||
log.debug(u'Reload bibles')
|
log.debug(u'Reload bibles')
|
||||||
|
|
||||||
files = self.config.get_files(self.bibleSuffix)
|
files = self.config.get_files(self.bibleSuffix)
|
||||||
log.debug(u'Bible Files %s', files )
|
log.debug(u'Bible Files %s', files )
|
||||||
|
|
||||||
self.bible_db_cache = {}
|
self.bible_db_cache = {}
|
||||||
self.bible_http_cache = {}
|
self.bible_http_cache = {}
|
||||||
|
# books of the bible with testaments
|
||||||
self.book_testaments = {} # books of the bible with testaments
|
self.book_testaments = {}
|
||||||
self.book_abbreviations = {} # books of the bible with abbreviation
|
# books of the bible with abbreviation
|
||||||
|
self.book_abbreviations = {}
|
||||||
self.web_bibles_present = False
|
self.web_bibles_present = False
|
||||||
|
|
||||||
|
|
||||||
for f in files:
|
for f in files:
|
||||||
nme = f.split(u'.')
|
nme = f.split(u'.')
|
||||||
bname = nme[0]
|
bname = nme[0]
|
||||||
self.bible_db_cache[bname] = BibleDBImpl(self.biblePath, bname, self.config)
|
self.bible_db_cache[bname] = BibleDBImpl(self.biblePath,
|
||||||
biblesource = self.bible_db_cache[bname].get_meta(u'WEB') # look to see if lazy load bible exists and get create getter.
|
bname, self.config)
|
||||||
|
# look to see if lazy load bible exists and get create getter.
|
||||||
|
biblesource = self.bible_db_cache[bname].get_meta(u'WEB')
|
||||||
if biblesource:
|
if biblesource:
|
||||||
self.web_bibles_present = True
|
self.web_bibles_present = True
|
||||||
nhttp = BibleHTTPImpl()
|
nhttp = BibleHTTPImpl()
|
||||||
nhttp.set_bible_source(biblesource.value) # tell The Server where to get the verses from.
|
# tell The Server where to get the verses from.
|
||||||
|
nhttp.set_bible_source(biblesource.value)
|
||||||
self.bible_http_cache [bname] = nhttp
|
self.bible_http_cache [bname] = nhttp
|
||||||
meta = self.bible_db_cache[bname].get_meta(u'proxy') # look to see if lazy load bible exists and get create getter.
|
# look to see if lazy load bible exists and get create getter.
|
||||||
|
meta = self.bible_db_cache[bname].get_meta(u'proxy')
|
||||||
proxy = None
|
proxy = None
|
||||||
if meta != None:
|
if meta != None:
|
||||||
proxy = meta.value
|
proxy = meta.value
|
||||||
nhttp.set_proxy(proxy) # tell The Server where to get the verses from.
|
# tell The Server where to get the verses from.
|
||||||
bibleid = self.bible_db_cache[bname].get_meta(u'bibleid').value # look to see if lazy load bible exists and get create getter.
|
nhttp.set_proxy(proxy)
|
||||||
nhttp.set_bibleid(bibleid) # tell The Server where to get the verses from.
|
# look to see if lazy load bible exists and get create getter.
|
||||||
|
bibleid = self.bible_db_cache[bname].get_meta(u'bibleid').value
|
||||||
|
# tell The Server where to get the verses from.
|
||||||
|
nhttp.set_bibleid(bibleid)
|
||||||
else:
|
else:
|
||||||
self.bible_http_cache [bname] = None # makes the Full / partial code easier.
|
# makes the Full / partial code easier.
|
||||||
|
self.bible_http_cache [bname] = None
|
||||||
if self.web_bibles_present:
|
if self.web_bibles_present:
|
||||||
self.book_testaments = {} # books of the bible linked to bibleid {osis , name}
|
# books of the bible linked to bibleid {osis, name}
|
||||||
self.book_abbreviations = {} # books of the bible linked to bibleid {osis ,Abbrev }
|
self.book_testaments = {}
|
||||||
|
# books of the bible linked to bibleid {osis, abbrev}
|
||||||
|
self.book_abbreviations = {}
|
||||||
filepath = os.path.split(os.path.abspath(__file__))[0]
|
filepath = os.path.split(os.path.abspath(__file__))[0]
|
||||||
filepath = os.path.abspath(os.path.join(filepath, u'..', u'resources',u'httpbooks.csv'))
|
filepath = os.path.abspath(os.path.join(
|
||||||
fbibles=open(filepath, 'r')
|
filepath, u'..', u'resources',u'httpbooks.csv'))
|
||||||
|
fbibles = open(filepath, u'r')
|
||||||
for line in fbibles:
|
for line in fbibles:
|
||||||
p = line.split(u',')
|
p = line.split(u',')
|
||||||
self.book_abbreviations[p[0]] = p[1].replace(u'\n', '')
|
self.book_abbreviations[p[0]] = p[1].replace(u'\n', '')
|
||||||
@ -99,31 +122,64 @@ class BibleManager():
|
|||||||
log.debug(u'Bible Initialised')
|
log.debug(u'Bible Initialised')
|
||||||
|
|
||||||
def process_dialog(self, dialogobject):
|
def process_dialog(self, dialogobject):
|
||||||
|
"""
|
||||||
|
Sets the reference to the dialog with the progress bar on it.
|
||||||
|
|
||||||
|
``dialogobject``
|
||||||
|
The reference to the dialog.
|
||||||
|
"""
|
||||||
self.dialogobject = dialogobject
|
self.dialogobject = dialogobject
|
||||||
|
|
||||||
def register_http_bible(self, biblename, biblesource, bibleid, proxyurl=None, proxyid=None, proxypass=None):
|
def register_http_bible(self, biblename, biblesource, bibleid,
|
||||||
|
proxyurl=None, proxyid=None, proxypass=None):
|
||||||
"""
|
"""
|
||||||
Return a list of bibles from a given URL.
|
Return a list of bibles from a given URL. The selected Bible
|
||||||
The selected Bible can then be registered and LazyLoaded into a database
|
can then be registered and LazyLoaded into a database.
|
||||||
"""
|
|
||||||
log.debug(u'register_HTTP_bible %s,%s,%s,%s,%s,%s', biblename, biblesource, bibleid, proxyurl, proxyid, proxypass)
|
|
||||||
if self._is_new_bible(biblename):
|
|
||||||
nbible = BibleDBImpl(self.biblePath, biblename, self.config) # Create new Bible
|
|
||||||
nbible.create_tables() # Create Database
|
|
||||||
self.bible_db_cache[biblename] = nbible
|
|
||||||
|
|
||||||
|
``biblename``
|
||||||
|
The name of the bible to register.
|
||||||
|
|
||||||
|
``biblesource``
|
||||||
|
Where this Bible stores it's verses.
|
||||||
|
|
||||||
|
``bibleid``
|
||||||
|
The identifier for a Bible.
|
||||||
|
|
||||||
|
``proxyurl``
|
||||||
|
Defaults to *None*. An optional URL to a proxy server.
|
||||||
|
|
||||||
|
``proxyid``
|
||||||
|
Defaults to *None*. A username for logging into the proxy
|
||||||
|
server.
|
||||||
|
|
||||||
|
``proxypass``
|
||||||
|
Defaults to *None*. The password to accompany the username.
|
||||||
|
"""
|
||||||
|
log.debug(u'register_HTTP_bible %s, %s, %s, %s, %s, %s',
|
||||||
|
biblename, biblesource, bibleid, proxyurl, proxyid, proxypass)
|
||||||
|
if self._is_new_bible(biblename):
|
||||||
|
# Create new Bible
|
||||||
|
nbible = BibleDBImpl(self.biblePath, biblename, self.config)
|
||||||
|
# Create Database
|
||||||
|
nbible.create_tables()
|
||||||
|
self.bible_db_cache[biblename] = nbible
|
||||||
nhttp = BibleHTTPImpl()
|
nhttp = BibleHTTPImpl()
|
||||||
nhttp.set_bible_source(biblesource)
|
nhttp.set_bible_source(biblesource)
|
||||||
self.bible_http_cache [biblename] = nhttp
|
self.bible_http_cache [biblename] = nhttp
|
||||||
nbible.save_meta(u'WEB', biblesource) # register a lazy loading interest
|
# register a lazy loading interest
|
||||||
nbible.save_meta(u'bibleid', bibleid) # store the we id of the bible
|
nbible.save_meta(u'WEB', biblesource)
|
||||||
|
# store the web id of the bible
|
||||||
|
nbible.save_meta(u'bibleid', bibleid)
|
||||||
if proxyurl != None and proxyurl != "":
|
if proxyurl != None and proxyurl != "":
|
||||||
nbible.save_meta(u'proxy', proxyurl) # store the proxy URL
|
# store the proxy URL
|
||||||
|
nbible.save_meta(u'proxy', proxyurl)
|
||||||
nhttp.set_proxy(proxyurl)
|
nhttp.set_proxy(proxyurl)
|
||||||
if proxyid != None and proxyid != "":
|
if proxyid != None and proxyid != "":
|
||||||
nbible.save_meta(u'proxyid', proxyid) # store the proxy userid
|
# store the proxy userid
|
||||||
|
nbible.save_meta(u'proxyid', proxyid)
|
||||||
if proxypass != None and proxypass != "":
|
if proxypass != None and proxypass != "":
|
||||||
nbible.save_meta(u'proxypass', proxypass) # store the proxy password
|
# store the proxy password
|
||||||
|
nbible.save_meta(u'proxypass', proxypass)
|
||||||
return True
|
return True
|
||||||
else:
|
else:
|
||||||
log.debug(u'register_http_file_bible %s not created already exists', biblename)
|
log.debug(u'register_http_file_bible %s not created already exists', biblename)
|
||||||
@ -165,21 +221,26 @@ class BibleManager():
|
|||||||
log.debug(u'register_OSIS_file_bible %s , %s not created already exists', biblename, osisfile)
|
log.debug(u'register_OSIS_file_bible %s , %s not created already exists', biblename, osisfile)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def get_bibles(self, mode=u'full'):
|
def get_bibles(self, mode=BibleMode.Full):
|
||||||
|
"""
|
||||||
|
Returns a list of Books of the bible. When ``mode`` is set to
|
||||||
|
``BibleMode.Full`` this method returns all the Bibles for the
|
||||||
|
Advanced Search, and when the mode is ``BibleMode.Partial``
|
||||||
|
this method returns all the bibles for the Quick Search.
|
||||||
|
|
||||||
|
``mode``
|
||||||
|
Defaults to ``BibleMode.Full``. The Bible mode.
|
||||||
|
"""
|
||||||
log.debug(u'get_bibles')
|
log.debug(u'get_bibles')
|
||||||
"""
|
bible_list = []
|
||||||
Returns a list of Books of the bible
|
for bible_name, bible_object in self.bible_db_cache.iteritems():
|
||||||
Mode "Full" - Returns all the bibles for the Queck seearch
|
if mode == BibleMode.Full:
|
||||||
Mode "Partial" - Returns CSV and OSIS bbles for the Advanced Search
|
bible_list.append(bible_name)
|
||||||
"""
|
|
||||||
r=[]
|
|
||||||
for b , o in self.bible_db_cache.iteritems():
|
|
||||||
if mode == u'full':
|
|
||||||
r.append(b)
|
|
||||||
else:
|
else:
|
||||||
if self.bible_http_cache [b] == None: # we do not have an http bible
|
if self.bible_http_cache[bible_name] is None:
|
||||||
r.append(b)
|
# we do not have an http bible
|
||||||
return r
|
bible_list.append(bible_name)
|
||||||
|
return bible_list
|
||||||
|
|
||||||
def get_bible_books(self,bible):
|
def get_bible_books(self,bible):
|
||||||
"""
|
"""
|
||||||
|
@ -21,8 +21,10 @@ import logging
|
|||||||
|
|
||||||
from PyQt4 import QtCore, QtGui
|
from PyQt4 import QtCore, QtGui
|
||||||
|
|
||||||
from openlp.core.lib import ServiceItem, MediaManagerItem, Receiver, translate, contextMenuAction, contextMenuSeparator
|
from openlp.core.lib import translate, ServiceItem, MediaManagerItem, \
|
||||||
|
Receiver, contextMenuAction, contextMenuSeparator
|
||||||
from openlp.plugins.bibles.forms import BibleImportForm
|
from openlp.plugins.bibles.forms import BibleImportForm
|
||||||
|
from openlp.plugins.bibles.lib.manager import BibleMode
|
||||||
|
|
||||||
class BibleList(QtGui.QListWidget):
|
class BibleList(QtGui.QListWidget):
|
||||||
|
|
||||||
@ -255,12 +257,12 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
log.debug(u'Loading Bibles')
|
log.debug(u'Loading Bibles')
|
||||||
self.QuickVersionComboBox.clear()
|
self.QuickVersionComboBox.clear()
|
||||||
self.AdvancedVersionComboBox.clear()
|
self.AdvancedVersionComboBox.clear()
|
||||||
bibles = self.parent.biblemanager.get_bibles(u'full')
|
bibles = self.parent.biblemanager.get_bibles(BibleMode.Full)
|
||||||
# load bibles into the combo boxes
|
# load bibles into the combo boxes
|
||||||
for bible in bibles:
|
for bible in bibles:
|
||||||
self.QuickVersionComboBox.addItem(bible)
|
self.QuickVersionComboBox.addItem(bible)
|
||||||
# Without HTT
|
# Without HTTP
|
||||||
bibles = self.parent.biblemanager.get_bibles(u'partial')
|
bibles = self.parent.biblemanager.get_bibles(BibleMode.Partial)
|
||||||
first = True
|
first = True
|
||||||
# load bibles into the combo boxes
|
# load bibles into the combo boxes
|
||||||
for bible in bibles:
|
for bible in bibles:
|
||||||
@ -344,13 +346,14 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
bitem = self.ListView.item(item.row())
|
bitem = self.ListView.item(item.row())
|
||||||
text = unicode((bitem.data(QtCore.Qt.UserRole)).toString())
|
text = unicode((bitem.data(QtCore.Qt.UserRole)).toString())
|
||||||
verse = text[:text.find(u'(')]
|
verse = text[:text.find(u'(')]
|
||||||
bible = text[text.find(u'(') + 1:text.find(u')')]
|
bible = text[text.find(u'(') + 1:-1]
|
||||||
self.searchByReference(bible, verse)
|
self.searchByReference(bible, verse)
|
||||||
book = self.search_results[0][0]
|
book = self.search_results[0].book.name
|
||||||
chapter = unicode(self.search_results[0][1])
|
chapter = unicode(self.search_results[0].chapter)
|
||||||
verse = unicode(self.search_results[0][2])
|
verse = unicode(self.search_results[0].verse)
|
||||||
text = self.search_results[0][3]
|
text = self.search_results[0].text
|
||||||
if self.parent.bibles_tab.paragraph_style: #Paragraph
|
# Paragraph
|
||||||
|
if self.parent.bibles_tab.paragraph_style:
|
||||||
text = text + u'\n\n'
|
text = text + u'\n\n'
|
||||||
if self.parent.bibles_tab.display_style == 1:
|
if self.parent.bibles_tab.display_style == 1:
|
||||||
loc = self.formatVerse(old_chapter, chapter, verse, u'(u', u')')
|
loc = self.formatVerse(old_chapter, chapter, verse, u'(u', u')')
|
||||||
@ -402,8 +405,8 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
|
|
||||||
def initialiseChapterVerse(self, bible, book):
|
def initialiseChapterVerse(self, bible, book):
|
||||||
log.debug(u'initialiseChapterVerse %s , %s', bible, book)
|
log.debug(u'initialiseChapterVerse %s , %s', bible, book)
|
||||||
self.chapters_from = self.parent.biblemanager.get_book_chapter_count(bible, book)[0]
|
self.chapters_from = self.parent.biblemanager.get_book_chapter_count(bible, book)
|
||||||
self.verses = self.parent.biblemanager.get_book_verse_count(bible, book, 1)[0]
|
self.verses = self.parent.biblemanager.get_book_verse_count(bible, book, 1)
|
||||||
self.adjustComboBox(1, self.chapters_from, self.AdvancedFromChapter)
|
self.adjustComboBox(1, self.chapters_from, self.AdvancedFromChapter)
|
||||||
self.adjustComboBox(1, self.chapters_from, self.AdvancedToChapter)
|
self.adjustComboBox(1, self.chapters_from, self.AdvancedToChapter)
|
||||||
self.adjustComboBox(1, self.verses, self.AdvancedFromVerse)
|
self.adjustComboBox(1, self.verses, self.AdvancedFromVerse)
|
||||||
@ -416,10 +419,16 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
combo.addItem(unicode(i))
|
combo.addItem(unicode(i))
|
||||||
|
|
||||||
def displayResults(self, bible):
|
def displayResults(self, bible):
|
||||||
for book, chap, vse , txt in self.search_results:
|
for verse in self.search_results:
|
||||||
bible_text = unicode(u' %s %d:%d (%s)'%(book , chap,vse, bible))
|
#bible_text = unicode(u' %s %d:%d (%s)'%(book , chap,vse, bible))
|
||||||
|
#bible_verse = QtGui.QListWidgetItem(bible_text)
|
||||||
|
#bible_verse.setData(QtCore.Qt.UserRole, QtCore.QVariant(bible_text))
|
||||||
|
#self.ListView.addItem(bible_verse)
|
||||||
|
bible_text = u' %s %d:%d (%s)' % (verse.book.name,
|
||||||
|
verse.chapter, verse.verse, bible)
|
||||||
bible_verse = QtGui.QListWidgetItem(bible_text)
|
bible_verse = QtGui.QListWidgetItem(bible_text)
|
||||||
bible_verse.setData(QtCore.Qt.UserRole, QtCore.QVariant(bible_text))
|
bible_verse.setData(QtCore.Qt.UserRole,
|
||||||
|
QtCore.QVariant(bible_text))
|
||||||
self.ListView.addItem(bible_verse)
|
self.ListView.addItem(bible_verse)
|
||||||
|
|
||||||
def searchByReference(self, bible, search):
|
def searchByReference(self, bible, search):
|
||||||
|
@ -29,13 +29,13 @@ meta_table = Table(u'metadata', metadata,
|
|||||||
|
|
||||||
testament_table = Table(u'testament', metadata,
|
testament_table = Table(u'testament', metadata,
|
||||||
Column(u'id', Integer, primary_key=True),
|
Column(u'id', Integer, primary_key=True),
|
||||||
Column(u'name', String(30)),
|
Column(u'name', String(50)),
|
||||||
)
|
)
|
||||||
|
|
||||||
book_table = Table(u'book', metadata,
|
book_table = Table(u'book', metadata,
|
||||||
Column(u'id', Integer, primary_key=True),
|
Column(u'id', Integer, primary_key=True),
|
||||||
Column(u'testament_id', Integer, schema.ForeignKey(u'testament.id')),
|
Column(u'testament_id', Integer, schema.ForeignKey(u'testament.id')),
|
||||||
Column(u'name', String(30)),
|
Column(u'name', String(50)),
|
||||||
Column(u'abbreviation', String(5)),
|
Column(u'abbreviation', String(5)),
|
||||||
)
|
)
|
||||||
Index(u'idx_name', book_table.c.name, book_table.c.id)
|
Index(u'idx_name', book_table.c.name, book_table.c.id)
|
||||||
|
Loading…
Reference in New Issue
Block a user