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:
Raoul Snyman 2009-07-13 22:08:43 +02:00
commit dc10f0e2a4
5 changed files with 264 additions and 132 deletions

View File

@ -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)

View File

@ -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:

View File

@ -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):
""" """

View File

@ -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):

View File

@ -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)