← Back to team overview

openlp-core team mailing list archive

[Merge] lp:~trb143/openlp/songs into lp:openlp

 

Tim Bentley has proposed merging lp:~trb143/openlp/songs into lp:openlp.

Requested reviews:
    openlp.org Core (openlp-core)

Small merge this time.
Tidy ups from last one.
Clean up Bible and Custom plugins removing extra files.
Fix 2.6 deprication message. 
-- 
https://code.launchpad.net/~trb143/openlp/songs/+merge/7533
Your team openlp.org Core is subscribed to branch lp:openlp.
=== modified file 'demo.py'
--- demo.py	2008-10-23 19:50:52 +0000
+++ demo.py	2009-06-16 18:21:24 +0000
@@ -40,7 +40,7 @@
         self.size=(1024,768)
 
         self.v=0
-        self._font=QtGui.QFont('Decorative', 32)
+        self._font=QtGui.QFont(u'Decorative', 32)
         self.framecount=0
         self.totaltime = 0
         self.dir=1
@@ -49,7 +49,7 @@
         self.frame=QtGui.QFrame()
         self.setCentralWidget(self.frame)
         self.r=Renderer()
-        self.r.set_theme(Theme('demo_theme.xml'))
+        self.r.set_theme(Theme(u'demo_theme.xml'))
 
         self.r.set_text_rectangle(self.frame.frameRect())
         self.r.set_paint_dest(self)
@@ -79,4 +79,3 @@
 
 if __name__=="__main__":
     t=Demo()
-

=== modified file 'openlp/core/lib/__init__.py'
--- openlp/core/lib/__init__.py	2009-05-22 18:30:25 +0000
+++ openlp/core/lib/__init__.py	2009-06-16 18:21:24 +0000
@@ -49,7 +49,7 @@
     """
     action = QtGui.QAction(text, base)
     action .setIcon(buildIcon(icon))
-    QtCore.QObject.connect(action, QtCore.SIGNAL("triggered()"), slot)
+    QtCore.QObject.connect(action, QtCore.SIGNAL(u'triggered()'), slot)
     return action
 
 def contextMenuSeparator(base):
@@ -75,11 +75,4 @@
 from renderer import Renderer
 from rendermanager import RenderManager
 
-#__all__ = ['Renderer','PluginConfig', 'Plugin', 'SettingsTab', 'MediaManagerItem', 'Event', 'EventType'
-#           'XmlRootClass', 'ServiceItem', 'Receiver', 'OpenLPToolbar', 'SongXMLBuilder',
-#           'SongXMLParser', 'EventManager', 'ThemeXML', 'RenderManager']
-
 __all__ = [ 'translate', 'file_to_xml', 'str_to_bool', 'contextMenuAction', 'contextMenuSeparator']
-
-
-

=== modified file 'openlp/core/lib/eventmanager.py'
--- openlp/core/lib/eventmanager.py	2009-05-20 20:17:20 +0000
+++ openlp/core/lib/eventmanager.py	2009-06-17 05:11:16 +0000
@@ -43,4 +43,3 @@
         log.debug(u'post event called for event %s', event.event_type)
         for point in self.endpoints:
             point.handle_event(event)
-

=== modified file 'openlp/core/lib/eventreceiver.py'
--- openlp/core/lib/eventreceiver.py	2009-06-05 05:13:34 +0000
+++ openlp/core/lib/eventreceiver.py	2009-06-17 05:11:16 +0000
@@ -41,10 +41,10 @@
     As there is only one instance of it in the systems the QT signal/slot architecture
     can send messages across the system
     Send message
-       Receiver().send_message("messageid",data)
+       Receiver().send_message(u'messageid',data)
 
     Receive Message
-        QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL("openlprepaint"),<<ACTION>>)
+        QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL(u'openlprepaint'),<<ACTION>>)
     """
     eventreceiver = EventReceiver()
 

=== modified file 'openlp/core/lib/pluginconfig.py'
--- openlp/core/lib/pluginconfig.py	2009-06-05 18:53:50 +0000
+++ openlp/core/lib/pluginconfig.py	2009-06-17 05:11:16 +0000
@@ -64,7 +64,6 @@
         return self.set_config(u'data path', os.path.basename(path))
 
     def get_files(self, suffix=None):
-        #suffix = self.get_config("suffix name", default_suffixes)
         try:
             files = os.listdir(self.get_data_path())
         except:
@@ -97,7 +96,7 @@
         list = []
         if list_count > 0:
             for counter in range(0 , list_count):
-                item = str(self.get_config(u'%s %d' % (name, counter)))
+                item = unicode(self.get_config(u'%s %d' % (name, counter)))
                 list.append(item)
         return list
 

=== modified file 'openlp/core/lib/pluginmanager.py'
--- openlp/core/lib/pluginmanager.py	2009-05-20 20:17:20 +0000
+++ openlp/core/lib/pluginmanager.py	2009-06-17 05:11:16 +0000
@@ -39,7 +39,7 @@
         """
         log.info(u'Plugin manager initing')
         if not dir in sys.path:
-            log.debug("Inserting %s into sys.path", dir)
+            log.debug(u'Inserting %s into sys.path', dir)
             sys.path.insert(0, dir)
         self.basepath = os.path.abspath(dir)
         log.debug(u'Base path %s ', self.basepath)
@@ -53,7 +53,7 @@
         """
         self.plugin_helpers = plugin_helpers
         startdepth = len(os.path.abspath(dir).split(os.sep))
-        log.debug(u'find plugins %s at depth %d' %( str(dir), startdepth))
+        log.debug(u'find plugins %s at depth %d' %( unicode(dir), startdepth))
 
         for root, dirs, files in os.walk(dir):
             for name in files:
@@ -73,21 +73,21 @@
                     try:
                         __import__(modulename, globals(), locals(), [])
                     except ImportError, e:
-                        log.error(u'Failed to import module %s on path %s for reason %s', modulename, path, e.message)
+                        log.error(u'Failed to import module %s on path %s for reason %s', modulename, path,  sys.exc_info()[1])
         self.plugin_classes = Plugin.__subclasses__()
         self.plugins = []
         plugin_objects = []
         for p in self.plugin_classes:
             try:
                 plugin = p(self.plugin_helpers)
-                log.debug(u'loaded plugin %s with helpers'%str(p))
-                log.debug(u'Plugin: %s', str(p))
+                log.debug(u'loaded plugin %s with helpers'%unicode(p))
+                log.debug(u'Plugin: %s', unicode(p))
                 if plugin.check_pre_conditions():
-                    log.debug(u'Appending %s ',  str(p))
+                    log.debug(u'Appending %s ',  unicode(p))
                     plugin_objects.append(plugin)
                     eventmanager.register(plugin)
             except TypeError:
-                log.error(u'loaded plugin %s has no helpers'%str(p))
+                log.error(u'loaded plugin %s has no helpers'%unicode(p))
         self.plugins = sorted(plugin_objects, self.order_by_weight)
 
     def order_by_weight(self, x, y):

=== modified file 'openlp/core/lib/renderer.py'
--- openlp/core/lib/renderer.py	2009-06-10 16:20:57 +0000
+++ openlp/core/lib/renderer.py	2009-06-16 18:21:24 +0000
@@ -67,7 +67,7 @@
 
     def set_bg_image(self, filename):
         log.debug(u'set bg image %s', filename)
-        self._bg_image_filename = str(filename)
+        self._bg_image_filename = unicode(filename)
         if self._frame is not None:
             self.scale_bg_image()
 
@@ -447,4 +447,4 @@
         im.save(u'renderer.png', u'png')
         if image2 is not None:
             im = image2.toImage()
-            im.save(u'renderer2.png', u'png')
+            im.save(u'renderer2.png', u'png')
\ No newline at end of file

=== modified file 'openlp/core/lib/rendermanager.py'
--- openlp/core/lib/rendermanager.py	2009-06-10 15:54:46 +0000
+++ openlp/core/lib/rendermanager.py	2009-06-17 05:11:16 +0000
@@ -28,22 +28,6 @@
 import sys
 import linecache
 
-def traceit(frame, event, arg):
-    """
-    Code to allow calls to be traced by python runtime
-    """
-    if event == "line":
-        lineno = frame.f_lineno
-        filename = frame.f_globals["__file__"]
-        if (filename.endswith(".pyc") or
-            filename.endswith(".pyo")):
-            filename = filename[:-1]
-        name = frame.f_globals["__name__"]
-        line = linecache.getline(filename, lineno)
-        if name.startswith("openlp"):
-            print "%s:%s: %s" % (name, lineno, line.rstrip())
-    return traceit
-
 class RenderManager:
     """
     Class to pull all Renderer interactions into one place.
@@ -61,7 +45,7 @@
         self.displays = len(screen_list)
         self.current_display = screen_number
         self.renderer = Renderer()
-        self.calculate_default(self.screen_list[self.current_display]['size'])
+        self.calculate_default(self.screen_list[self.current_display][u'size'])
         self.theme = u''
         self.service_theme = u''
         self.global_style = u''
@@ -73,7 +57,7 @@
         log.debug(u'Update Display')
         if self.current_display != screen_number:
             self.current_display = screen_number
-            self.calculate_default(self.screen_list[self.current_display]['size'])
+            self.calculate_default(self.screen_list[self.current_display][u'size'])
 
     def set_global_theme(self, global_theme, global_style = u'Global'):
         self.global_theme = global_theme
@@ -160,7 +144,6 @@
         log.debug(u'calculate default %s' , screen)
         self.width = screen.width()
         self.height = screen.height()
-        self.width = 1024
-        self.height = 768
         log.debug(u'calculate default %d,%d' , self.width, self.height)
-        self.footer_start = int(self.height*0.90) # 90% is start of footer
+        # 90% is start of footer
+        self.footer_start = int(self.height*0.90)

=== modified file 'openlp/core/lib/songxmlhandler.py'
--- openlp/core/lib/songxmlhandler.py	2009-04-30 21:02:28 +0000
+++ openlp/core/lib/songxmlhandler.py	2009-06-16 18:21:24 +0000
@@ -66,7 +66,7 @@
 
     def dump_xml(self):
         # Debugging aid to see what we have
-        print self.song_xml.toprettyxml(indent="  ")
+        print self.song_xml.toprettyxml(indent=u'  ')
 
     def extract_xml(self):
         # Print our newly created XML

=== modified file 'openlp/core/lib/toolbar.py'
--- openlp/core/lib/toolbar.py	2009-05-01 22:26:43 +0000
+++ openlp/core/lib/toolbar.py	2009-06-16 18:21:24 +0000
@@ -54,12 +54,12 @@
             if tooltip is not None:
                 ToolbarButton.setToolTip(tooltip)
             if slot is not None:
-                QtCore.QObject.connect(ToolbarButton, QtCore.SIGNAL('triggered()'), slot)
+                QtCore.QObject.connect(ToolbarButton, QtCore.SIGNAL(u'triggered()'), slot)
             self.icons[title] = ButtonIcon
 
     def getIconFromTitle(self, title):
         if self.icons.has_key(title):
             return self.icons[title]
         else:
-            self.log.error("getIconFromTitle - no icon for %s" % title)
+            self.log.error(u'getIconFromTitle - no icon for %s' % title)
             return QtGui.QIcon()

=== modified file 'openlp/core/test/test_mediamanageritem.py'
--- openlp/core/test/test_mediamanageritem.py	2009-03-12 20:19:24 +0000
+++ openlp/core/test/test_mediamanageritem.py	2009-06-16 18:21:24 +0000
@@ -8,13 +8,13 @@
 
 console=logging.StreamHandler()
 # set a format which is simpler for console use
-formatter = logging.Formatter('%(name)24s: %(levelname)-8s %(message)s')
+formatter = logging.Formatter(u'%(name)24s: %(levelname)-8s %(message)s')
 # tell the handler to use this format
 console.setFormatter(formatter)
-logging.getLogger('').addHandler(console)
-log=logging.getLogger('')
+logging.getLogger(u'').addHandler(console)
+log=logging.getLogger(u'')
 
-logging.info("Logging started")
+logging.info(u'Logging started')
 import os, sys
 mypath=os.path.split(os.path.abspath(__file__))[0]
 
@@ -23,7 +23,7 @@
 class TestMediaManager:
     def setup_class(self):
         self.app = QtGui.QApplication([])
-        logging.info ("App is " + str(self.app))
+        logging.info (u'App is " + unicode(self.app))
         self.main_window = QtGui.QMainWindow()
         self.main_window.resize(200, 600)
         self.MediaManagerDock = QtGui.QDockWidget(self.main_window)
@@ -33,7 +33,7 @@
         sizePolicy.setHeightForWidth(self.MediaManagerDock.sizePolicy().hasHeightForWidth())
         self.MediaManagerDock.setSizePolicy(sizePolicy)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/system/system_mediamanager.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/system/system_mediamanager.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.MediaManagerDock.setWindowIcon(icon)
         self.MediaManagerDock.setFloating(False)
         self.MediaManagerContents = QtGui.QWidget()
@@ -49,26 +49,26 @@
         self.main_window.addDockWidget(QtCore.Qt.DockWidgetArea(1), self.MediaManagerDock)
         self.MediaManagerLayout.addWidget(self.MediaToolBox)
     def test1(self):
-        log=logging.getLogger("test1")
-        log.info("Start")
+        log=logging.getLogger(u'test1')
+        log.info(u'Start')
         i1=MediaManagerItem(self.MediaToolBox)
         i2=MediaManagerItem(self.MediaToolBox)
-        log.info("i1"+str(i1))
-        log.info("i2"+str(i2))
+        log.info(u'i1"+unicode(i1))
+        log.info(u'i2"+unicode(i2))
         i1.addToolbar()
-        i1.addToolbarButton("Test1", "Test1", None)
+        i1.addToolbarButton(u'Test1", u'Test1", None)
         i2.addToolbar()
-        i2.addToolbarButton("Test2", "Test2", None)
-        self.MediaToolBox.setItemText(self.MediaToolBox.indexOf(i1), QtGui.QApplication.translate("main_window", "Item1", None, QtGui.QApplication.UnicodeUTF8))
-        self.MediaToolBox.setItemText(self.MediaToolBox.indexOf(i2), QtGui.QApplication.translate("main_window", "Item2", None, QtGui.QApplication.UnicodeUTF8))
-        log.info("Show window")
+        i2.addToolbarButton(u'Test2", u'Test2", None)
+        self.MediaToolBox.setItemText(self.MediaToolBox.indexOf(i1), translate(u'main_window", u'Item1"))
+        self.MediaToolBox.setItemText(self.MediaToolBox.indexOf(i2), translate(u'main_window", u'Item2"))
+        log.info(u'Show window')
         self.main_window.show()
-        log.info("End")
+        log.info(u'End')
         return 1
 
 if __name__=="__main__":
     t=TestMediaManager()
     t.setup_class()
     t.test1()
-    log.info("exec")
-    sys.exit(t.app.exec_())
+    log.info(u'exec')
+    sys.exit(t.app.exec_())
\ No newline at end of file

=== modified file 'openlp/core/test/test_plugin_manager.py'
--- openlp/core/test/test_plugin_manager.py	2009-04-20 18:22:42 +0000
+++ openlp/core/test/test_plugin_manager.py	2009-06-16 18:21:24 +0000
@@ -10,13 +10,13 @@
 
 console=logging.StreamHandler()
 # set a format which is simpler for console use
-formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
+formatter = logging.Formatter(u'%(name)-12s: %(levelname)-8s %(message)s')
 # tell the handler to use this format
 console.setFormatter(formatter)
-logging.getLogger('').addHandler(console)
-log=logging.getLogger('')
+logging.getLogger(u'').addHandler(console)
+log=logging.getLogger(u'')
 
-logging.info("Logging started")
+logging.info(u'Logging started')
 mypath=os.path.split(os.path.abspath(__file__))[0]
 
 sys.path.insert(0,(os.path.join(mypath, '..' ,'..', '..')))
@@ -24,24 +24,24 @@
 # test the plugin manager with some plugins in the test_plugins directory
 class TestPluginManager:
     def test_init(self):
-        self.p=PluginManager("./testplugins")
+        self.p=PluginManager(u'./testplugins')
         p=self.p
-        p.find_plugins('./testplugins', None, None)
+        p.find_plugins(u'./testplugins', None, None)
         assert (len(p.plugins)==2);
         # get list of the names of the plugins
         names=[plugin.name for plugin in p.plugins]
         # see which ones we've got
-        assert ("testplugin1" in names)
-        assert ("testplugin2" in names)
+        assert (u'testplugin1" in names)
+        assert (u'testplugin2" in names)
         # and not got - it's too deep in the hierarchy!
-        assert ("testplugin3" not in names)
+        assert (u'testplugin3" not in names)
         # test that the weighting is done right
         assert p.plugins[0].name=="testplugin2"
         assert p.plugins[1].name=="testplugin1"
 if __name__=="__main__":
-    log.debug("Starting")
+    log.debug(u'Starting')
     t=TestPluginManager()
     t.test_init()
-    log.debug("List of plugins found:")
+    log.debug(u'List of plugins found:')
     for plugin in t.p.plugins:
-        log.debug("Plugin %s, name=%s (version=%d)"%(str(plugin), plugin.name, plugin.version))
+        log.debug(u'Plugin %s, name=%s (version=%d)"%(unicode(plugin), plugin.name, plugin.version))
\ No newline at end of file

=== modified file 'openlp/core/test/test_render.py'
--- openlp/core/test/test_render.py	2009-03-29 14:38:23 +0000
+++ openlp/core/test/test_render.py	2009-06-16 18:21:24 +0000
@@ -45,15 +45,15 @@
 
 class TestRender_base:
     def __init__(self):
-        if not os.path.exists("test_results"):
-            os.mkdir("test_results")
+        if not os.path.exists(u'test_results'):
+            os.mkdir(u'test_results')
         self.app=None
     def write_to_file(self, pixmap, name):
         im=pixmap.toImage()
-        testpathname=os.path.join("test_results", name+".bmp")
+        testpathname=os.path.join(u'test_results", name+".bmp')
         if os.path.exists(testpathname):
             os.unlink(testpathname)
-        im.save(testpathname, "bmp")
+        im.save(testpathname, "bmp')
         return im
     # xxx quitting the app still leaves it hanging aroudn so we die
     # when trying to start another one.  Not quitting doesn't help
@@ -84,7 +84,7 @@
 
     def setup_method(self, method):
         print "SSsetup", method
-        if not hasattr(self, "app"):
+        if not hasattr(self, "app'):
             self.app=None
         try: # see if we already have an app for some reason.
             # have to try and so something, cant just test against None
@@ -109,7 +109,7 @@
         print "--------------- Setup Done -------------"
 
     def teardown_method(self, method):
-        self.write_to_file(self.frame.GetPixmap(), "test_render")
+        self.write_to_file(self.frame.GetPixmap(), "test_render')
 
 class TestRender(TestRender_base):
     def __init__(self):
@@ -118,29 +118,29 @@
     def setup_method(self, method):
         TestRender_base.setup_method(self, method)
         self.r.set_debug(1)
-        themefile=os.path.abspath("data_for_tests/render_theme.xml")
+        themefile=os.path.abspath(u'data_for_tests/render_theme.xml')
         self.r.set_theme(Theme(themefile)) # set default theme
         self.r._render_background()
         self.r.set_text_rectangle(QtCore.QRect(0,0, self.size.width()-1, self.size.height()-1))
         self.msg=None
 
     def test_easy(self):
-        answer=self.r._render_single_line("Test line", tlcorner=(0,100))
+        answer=self.r._render_single_line(u'Test line", tlcorner=(0,100))
         assert (answer==(219,163))
     def test_longer(self):
-        answer=self.r._render_single_line("Test line with more words than fit on one line",
+        answer=self.r._render_single_line(u'Test line with more words than fit on one line",
                                          tlcorner=(10,10))
         assert (answer==(753,136))
     def test_even_longer(self):
-        answer=self.r._render_single_line("Test line with more words than fit on either one or two lines",
+        answer=self.r._render_single_line(u'Test line with more words than fit on either one or two lines",
                                          tlcorner=(10,10))
         assert(answer==(753,199))
     def test_lines(self):
         lines=[]
-        lines.append("Line One")
-        lines.append("Line Two")
-        lines.append("Line Three and should be long enough to wrap")
-        lines.append("Line Four and should be long enough to wrap also")
+        lines.append(u'Line One')
+        lines.append(u'Line Two')
+        lines.append(u'Line Three and should be long enough to wrap')
+        lines.append(u'Line Four and should be long enough to wrap also')
         answer=self.r._render_lines(lines)
         assert(answer==QtCore.QRect(0,0,741,378))
 
@@ -187,7 +187,7 @@
             extra=""
             if i == 51: # make an extra long line on line 51 to test wrapping
                 extra="Some more words to make it wrap around don't you know until it wraps so many times we don't know what to do"
-            lines.append("Line %d %s" % (i, extra))
+            lines.append(u'Line %d %s" % (i, extra))
         result=self.r.split_set_of_lines(lines)
         print "results---------------__", result
         for i in range(len(result)):
@@ -218,5 +218,4 @@
     t.setup_method(None)
     t.test_easy()
     t.test_splits()
-    t.teardown_method(None)
-
+    t.teardown_method(None)
\ No newline at end of file

=== modified file 'openlp/core/test/test_render_theme.py'
--- openlp/core/test/test_render_theme.py	2009-03-12 20:19:24 +0000
+++ openlp/core/test/test_render_theme.py	2009-06-16 18:21:24 +0000
@@ -57,7 +57,7 @@
         TestRender_base.setup_method(self, method)
         print "Theme setup", method
 #         print "setup theme"
-        self.r.set_theme(Theme('blank_theme.xml')) # set "blank" theme
+        self.r.set_theme(Theme(u'blank_theme.xml')) # set "blank" theme
         self.r.set_text_rectangle(QtCore.QRect(0,0, self.size.width(), self.size.height()))
         words="""How sweet the name of Jesus sounds
 In a believer's ear!
@@ -87,7 +87,7 @@
         p=self.frame.GetPixmap()
         im=self.write_to_file(p, name)
         print "Compare"
-        goldenfilename=os.path.join("golden_bitmaps",name+".bmp")
+        goldenfilename=os.path.join(u'golden_bitmaps",name+".bmp')
         if os.path.exists(goldenfilename):
             goldenim=QtGui.QImage(goldenfilename)
         else:
@@ -129,9 +129,9 @@
     # }}}
     # {{{ backgrounds
     def test_bg_stretch_y(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 2
-        t.BackgroundParameter1 = os.path.join('data_for_tests', "snowsmall.jpg");
+        t.BackgroundParameter1 = os.path.join(u'data_for_tests', "snowsmall.jpg');
         t.BackgroundParameter2 = QtGui.QColor(0,0,64);
         t.BackgroundParameter3 = 0
         t.Name="stretch y"
@@ -142,9 +142,9 @@
         self.bmpname=whoami()
         print "fone"
     def test_bg_shrink_y(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 2
-        t.BackgroundParameter1 = os.path.join('data_for_tests', "snowbig.jpg");
+        t.BackgroundParameter1 = os.path.join(u'data_for_tests', "snowbig.jpg');
         t.BackgroundParameter2 = QtGui.QColor(0,0,64);
         t.BackgroundParameter3 = 0
         t.Name="shrink y"
@@ -153,9 +153,9 @@
         self.bmpname=whoami()
 
     def test_bg_stretch_x(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 2
-        t.BackgroundParameter1 = os.path.join('data_for_tests', "treessmall.jpg");
+        t.BackgroundParameter1 = os.path.join(u'data_for_tests', "treessmall.jpg');
         t.BackgroundParameter2 = QtGui.QColor(0,0,64);
         t.BackgroundParameter3 = 0
         t.VerticalAlign = 2
@@ -166,9 +166,9 @@
         self.bmpname=whoami()
 
     def test_bg_shrink_x(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 2
-        t.BackgroundParameter1 = os.path.join('data_for_tests', "treesbig.jpg");
+        t.BackgroundParameter1 = os.path.join(u'data_for_tests', "treesbig.jpg');
         t.BackgroundParameter2 = QtGui.QColor(0,0,64);
         t.BackgroundParameter3 = 0
         t.VerticalAlign = 2
@@ -180,7 +180,7 @@
     # }}}
     # {{{ Vertical alignment
     def test_theme_vertical_align_top(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 0
@@ -190,7 +190,7 @@
         self.bmpname=whoami()
 
     def test_theme_vertical_align_bot(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 1
@@ -201,7 +201,7 @@
         self.bmpname=whoami()
 
     def test_theme_vertical_align_cen(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 2
@@ -213,7 +213,7 @@
     # }}}
     # {{{ Horzontal alignment
     def test_theme_horizontal_align_left(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 0
@@ -224,7 +224,7 @@
         self.bmpname=whoami()
 
     def test_theme_horizontal_align_right(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 0
@@ -236,7 +236,7 @@
         self.bmpname=whoami()
 
     def test_theme_horizontal_align_centre(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 0
@@ -248,7 +248,7 @@
         self.bmpname=whoami()
 
     def test_theme_horizontal_align_left_lyric(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.VerticalAlign = 0
@@ -263,7 +263,7 @@
     # }}}
     # {{{ Shadows and outlines
     def test_theme_shadow_outline(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
 
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,0);
@@ -282,7 +282,7 @@
         self.bmpname=whoami()
     # }}}
     def test_theme_font(self):
-        t=Theme('blank_theme.xml')
+        t=Theme(u'blank_theme.xml')
         t.BackgroundType = 0
         t.BackgroundParameter1 = QtGui.QColor(0,0,64);
         t.Name="font"
@@ -298,4 +298,4 @@
     t.setup_class()
     t.setup_method(None)
     t.test_bg_stretch_y()
-    t.teardown_method(None)
+    t.teardown_method(None)
\ No newline at end of file

=== modified file 'openlp/core/test/testplugins/deeper/toodeep/plugin3toodeep.py'
--- openlp/core/test/testplugins/deeper/toodeep/plugin3toodeep.py	2009-01-20 21:20:05 +0000
+++ openlp/core/test/testplugins/deeper/toodeep/plugin3toodeep.py	2009-06-16 18:21:24 +0000
@@ -5,9 +5,9 @@
     name="testplugin3"
     version=0
     global log
-    log=logging.getLogger("testplugin1")
-    log.info("Started")
+    log=logging.getLogger(u'testplugin1')
+    log.info(u'Started')
     weight=10
     def __init__(self):
         pass
-        
+        
\ No newline at end of file

=== modified file 'openlp/core/test/testplugins/testplugin1.py'
--- openlp/core/test/testplugins/testplugin1.py	2009-01-20 21:20:05 +0000
+++ openlp/core/test/testplugins/testplugin1.py	2009-06-16 18:21:24 +0000
@@ -5,9 +5,9 @@
     name="testplugin1"
     version=0
     global log
-    log=logging.getLogger("testplugin1")
-    log.info("Started")
+    log=logging.getLogger(u'testplugin1')
+    log.info(u'Started')
     weight=10
     def __init__(self):
         pass
-        
+        
\ No newline at end of file

=== modified file 'openlp/core/theme/test/test_theme.py'
--- openlp/core/theme/test/test_theme.py	2009-03-12 20:19:24 +0000
+++ openlp/core/theme/test/test_theme.py	2009-06-16 18:21:24 +0000
@@ -11,18 +11,18 @@
 def test_read_theme():
     dir=os.path.split(__file__)[0]
     # test we can read a theme
-    t=Theme(os.path.join(dir, "test_theme.xml"))
+    t=Theme(os.path.join(dir, "test_theme.xml'))
     print t
-    assert(t.BackgroundParameter1 == "sunset1.jpg")
+    assert(t.BackgroundParameter1 == "sunset1.jpg')
     assert(t.BackgroundParameter2 == None)
     assert(t.BackgroundParameter3 == None)
     assert(t.BackgroundType == 2)
     assert(t.FontColor == QtGui.QColor(255,255,255))
-    assert(t.FontName == "Tahoma")
+    assert(t.FontName == "Tahoma')
     assert(t.FontProportion == 16)
-    assert(t.FontUnits == "pixels")
+    assert(t.FontUnits == "pixels')
     assert(t.HorizontalAlign == 2)
-    assert(t.Name == "openlp.org Packaged Theme")
+    assert(t.Name == "openlp.org Packaged Theme')
     assert(t.Outline == -1)
     assert(t.OutlineColor == QtGui.QColor(255,0,0))
     assert(t.Shadow == -1)
@@ -37,11 +37,11 @@
     assert(t.BackgroundParameter3 == None)
     assert(t.BackgroundType == 0)
     assert(t.FontColor == QtGui.QColor(255,255,255))
-    assert(t.FontName == "Arial")
+    assert(t.FontName == "Arial')
     assert(t.FontProportion == 30)
     assert(t.HorizontalAlign == 0)
-    assert(t.FontUnits == "pixels")
-    assert(t.Name == "BlankStyle")
+    assert(t.FontUnits == "pixels')
+    assert(t.Name == "BlankStyle')
     assert(t.Outline == 0)
     assert(t.Shadow == 0)
     assert(t.VerticalAlign == 0)
@@ -52,4 +52,4 @@
     
 if __name__=="__main__":
     test_read_theme()
-    test_theme()
+    test_theme()
\ No newline at end of file

=== modified file 'openlp/core/theme/theme.py'
--- openlp/core/theme/theme.py	2009-04-06 18:45:45 +0000
+++ openlp/core/theme/theme.py	2009-06-16 18:21:24 +0000
@@ -96,7 +96,7 @@
 #                 print element.tag, t, type(t)
                 if type(t) == type(None): # easy!
                     val=t
-                if type(t) == type(" "): # strings need special handling to sort the colours out
+                if type(t) == type(u' '): # strings need special handling to sort the colours out
 #                    print "str",
                     if t[0] == "$": # might be a hex number
 #                        print "hex",
@@ -113,8 +113,8 @@
                             val=int(t)
                         except ValueError:
                             val=t
-                if (element.tag.find("Color") > 0 or
-                    (element.tag.find("BackgroundParameter") == 0 and type(val) == type(0))):
+                if (element.tag.find(u'Color') > 0 or
+                    (element.tag.find(u'BackgroundParameter') == 0 and type(val) == type(0))):
                     # convert to a wx.Colour
                     val= QtGui.QColor((val>>16) & 0xFF, (val>>8)&0xFF, val&0xFF)
  #               print [val]
@@ -126,5 +126,4 @@
         for k in dir(self):
             if k[0:1] != "_":
                 s+= "%30s : %s\n" %(k,getattr(self,k))
-        return s
-
+        return s
\ No newline at end of file

=== modified file 'openlp/core/ui/alertform.py'
--- openlp/core/ui/alertform.py	2009-06-01 17:50:37 +0000
+++ openlp/core/ui/alertform.py	2009-06-16 18:21:24 +0000
@@ -18,7 +18,6 @@
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
 import logging
-
 from PyQt4 import QtCore, QtGui
 from openlp.core.lib import translate
 
@@ -33,22 +32,22 @@
         log.debug(u'Defined')
 
     def setupUi(self, AlertForm):
-        AlertForm.setObjectName("AlertForm")
+        AlertForm.setObjectName(u'AlertForm')
         AlertForm.resize(370, 110)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         AlertForm.setWindowIcon(icon)
         self.AlertFormLayout = QtGui.QVBoxLayout(AlertForm)
         self.AlertFormLayout.setSpacing(8)
         self.AlertFormLayout.setMargin(8)
-        self.AlertFormLayout.setObjectName("AlertFormLayout")
+        self.AlertFormLayout.setObjectName(u'AlertFormLayout')
         self.AlertEntryWidget = QtGui.QWidget(AlertForm)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Preferred)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.AlertEntryWidget.sizePolicy().hasHeightForWidth())
         self.AlertEntryWidget.setSizePolicy(sizePolicy)
-        self.AlertEntryWidget.setObjectName("AlertEntryWidget")
+        self.AlertEntryWidget.setObjectName(u'AlertEntryWidget')
         self.AlertEntryLabel = QtGui.QLabel(self.AlertEntryWidget)
         self.AlertEntryLabel.setGeometry(QtCore.QRect(0, 0, 353, 16))
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
@@ -56,10 +55,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.AlertEntryLabel.sizePolicy().hasHeightForWidth())
         self.AlertEntryLabel.setSizePolicy(sizePolicy)
-        self.AlertEntryLabel.setObjectName("AlertEntryLabel")
+        self.AlertEntryLabel.setObjectName(u'AlertEntryLabel')
         self.AlertEntryEditItem = QtGui.QLineEdit(self.AlertEntryWidget)
         self.AlertEntryEditItem.setGeometry(QtCore.QRect(0, 20, 353, 26))
-        self.AlertEntryEditItem.setObjectName("AlertEntryEditItem")
+        self.AlertEntryEditItem.setObjectName(u'AlertEntryEditItem')
         self.AlertFormLayout.addWidget(self.AlertEntryWidget)
         self.ButtonBoxWidget = QtGui.QWidget(AlertForm)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Preferred)
@@ -67,32 +66,32 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ButtonBoxWidget.sizePolicy().hasHeightForWidth())
         self.ButtonBoxWidget.setSizePolicy(sizePolicy)
-        self.ButtonBoxWidget.setObjectName("ButtonBoxWidget")
+        self.ButtonBoxWidget.setObjectName(u'ButtonBoxWidget')
         self.horizontalLayout = QtGui.QHBoxLayout(self.ButtonBoxWidget)
         self.horizontalLayout.setSpacing(8)
         self.horizontalLayout.setMargin(0)
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         spacerItem = QtGui.QSpacerItem(267, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout.addItem(spacerItem)
         self.DisplayButton = QtGui.QPushButton(self.ButtonBoxWidget)
-        self.DisplayButton.setObjectName("DisplayButton")
+        self.DisplayButton.setObjectName(u'DisplayButton')
         self.horizontalLayout.addWidget(self.DisplayButton)
         self.CancelButton = QtGui.QPushButton(self.ButtonBoxWidget)
-        self.CancelButton.setObjectName("CancelButton")
+        self.CancelButton.setObjectName(u'CancelButton')
         self.horizontalLayout.addWidget(self.CancelButton)
         self.AlertFormLayout.addWidget(self.ButtonBoxWidget)
 
         self.retranslateUi(AlertForm)
 
-        QtCore.QObject.connect(self.CancelButton, QtCore.SIGNAL("clicked()"), AlertForm.close)
-        QtCore.QObject.connect(self.DisplayButton, QtCore.SIGNAL("clicked()"), self.onDisplayClicked)
+        QtCore.QObject.connect(self.CancelButton, QtCore.SIGNAL(u'clicked()'), AlertForm.close)
+        QtCore.QObject.connect(self.DisplayButton, QtCore.SIGNAL(u'clicked()'), self.onDisplayClicked)
         QtCore.QMetaObject.connectSlotsByName(AlertForm)
 
     def retranslateUi(self, AlertForm):
-        AlertForm.setWindowTitle(translate("AlertForm", u'Alert Message'))
-        self.AlertEntryLabel.setText(translate("AlertForm", u'Alert Text:'))
-        self.DisplayButton.setText(translate("AlertForm", u'Display'))
-        self.CancelButton.setText(translate("AlertForm", u'Cancel'))
+        AlertForm.setWindowTitle(translate(u'AlertForm', u'Alert Message'))
+        self.AlertEntryLabel.setText(translate(u'AlertForm', u'Alert Text:'))
+        self.DisplayButton.setText(translate(u'AlertForm', u'Display'))
+        self.CancelButton.setText(translate(u'AlertForm', u'Cancel'))
 
     def load_settings(self):
         pass

=== modified file 'openlp/core/ui/alertstab.py'
--- openlp/core/ui/alertstab.py	2009-06-05 18:53:50 +0000
+++ openlp/core/ui/alertstab.py	2009-06-16 18:21:24 +0000
@@ -65,7 +65,7 @@
         self.FontColorLabel.setObjectName(u'FontColorLabel')
         self.ColorLayout.addWidget(self.FontColorLabel)
         self.FontColorButton = QtGui.QPushButton(self.ColorWidget)
-        self.FontColorButton.setObjectName("FontColorButton")
+        self.FontColorButton.setObjectName(u'FontColorButton')
         self.ColorLayout.addWidget(self.FontColorButton)
         self.ColorSpacerItem = QtGui.QSpacerItem(40, 20,
             QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
@@ -74,7 +74,7 @@
         self.BackgroundColorLabel.setObjectName(u'BackgroundColorLabel')
         self.ColorLayout.addWidget(self.BackgroundColorLabel)
         self.BackgroundColorButton = QtGui.QPushButton(self.ColorWidget)
-        self.BackgroundColorButton.setObjectName("BackgroundColorButton")
+        self.BackgroundColorButton.setObjectName(u'BackgroundColorButton')
         self.ColorLayout.addWidget(self.BackgroundColorButton)
         self.FontLayout.addWidget(self.ColorWidget)
         self.TimeoutWidget = QtGui.QWidget(self.FontGroupBox)
@@ -170,9 +170,9 @@
 
     def load(self):
         self.timeout = int(self.config.get_config(u'timeout', 5))
-        self.font_color = str(self.config.get_config(u'font color', u'#ffffff'))
-        self.bg_color = str(self.config.get_config(u'background color', u'#660000'))
-        self.font_face = str(self.config.get_config(u'font face', QtGui.QFont().family()))
+        self.font_color = unicode(self.config.get_config(u'font color', u'#ffffff'))
+        self.bg_color = unicode(self.config.get_config(u'background color', u'#660000'))
+        self.font_face = unicode(self.config.get_config(u'font face', QtGui.QFont().family()))
         self.TimeoutSpinBox.setValue(self.timeout)
         self.FontColorButton.setStyleSheet(u'background-color: %s' % self.font_color)
         self.BackgroundColorButton.setStyleSheet(u'background-color: %s' % self.bg_color)
@@ -183,10 +183,10 @@
 
     def save(self):
         self.font_face = self.FontComboBox.currentFont().family()
-        self.config.set_config(u'background color', str(self.bg_color))
-        self.config.set_config(u'font color', str(self.font_color))
-        self.config.set_config(u'font face', str(self.font_face))
-        self.config.set_config(u'timeout', str(self.timeout))
+        self.config.set_config(u'background color', unicode(self.bg_color))
+        self.config.set_config(u'font color', unicode(self.font_color))
+        self.config.set_config(u'font face', unicode(self.font_face))
+        self.config.set_config(u'timeout', unicode(self.timeout))
 
     def updateDisplay(self):
         font = QtGui.QFont()
@@ -195,4 +195,4 @@
         font.setPointSize(16)
         self.FontPreview.setFont(font)
         self.FontPreview.setStyleSheet(
-            u'background-color: %s; color: %s' % (self.bg_color, self.font_color))
+            u'background-color: %s; color: %s' % (self.bg_color, self.font_color))
\ No newline at end of file

=== modified file 'openlp/core/ui/amendthemedialog.py'
--- openlp/core/ui/amendthemedialog.py	2009-05-22 18:30:25 +0000
+++ openlp/core/ui/amendthemedialog.py	2009-06-16 18:21:24 +0000
@@ -1,147 +1,158 @@
 # -*- coding: utf-8 -*-
-
-# Form implementation generated from reading ui file 'amendthemedialog.ui'
-#
-# Created: Tue Apr 21 06:06:56 2009
-#      by: PyQt4 UI code generator 4.4.4
-#
-# WARNING! All changes made in this file will be lost!
-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008-2009 Martin Thompson, Tim Bentley,
+
+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
+"""
 from PyQt4 import QtCore, QtGui
+from openlp.core.lib import translate
 
 class Ui_AmendThemeDialog(object):
     def setupUi(self, AmendThemeDialog):
-        AmendThemeDialog.setObjectName("AmendThemeDialog")
+        AmendThemeDialog.setObjectName(u'AmendThemeDialog')
         AmendThemeDialog.setWindowModality(QtCore.Qt.ApplicationModal)
         AmendThemeDialog.resize(586, 651)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         AmendThemeDialog.setWindowIcon(icon)
         AmendThemeDialog.setModal(True)
         self.AmendThemeLayout = QtGui.QVBoxLayout(AmendThemeDialog)
         self.AmendThemeLayout.setSpacing(8)
         self.AmendThemeLayout.setMargin(8)
-        self.AmendThemeLayout.setObjectName("AmendThemeLayout")
+        self.AmendThemeLayout.setObjectName(u'AmendThemeLayout')
         self.ThemeNameWidget = QtGui.QWidget(AmendThemeDialog)
-        self.ThemeNameWidget.setObjectName("ThemeNameWidget")
+        self.ThemeNameWidget.setObjectName(u'ThemeNameWidget')
         self.ThemeNameLayout = QtGui.QHBoxLayout(self.ThemeNameWidget)
         self.ThemeNameLayout.setSpacing(8)
         self.ThemeNameLayout.setMargin(0)
-        self.ThemeNameLayout.setObjectName("ThemeNameLayout")
+        self.ThemeNameLayout.setObjectName(u'ThemeNameLayout')
         self.ThemeNameLabel = QtGui.QLabel(self.ThemeNameWidget)
-        self.ThemeNameLabel.setObjectName("ThemeNameLabel")
+        self.ThemeNameLabel.setObjectName(u'ThemeNameLabel')
         self.ThemeNameLayout.addWidget(self.ThemeNameLabel)
         self.ThemeNameEdit = QtGui.QLineEdit(self.ThemeNameWidget)
-        self.ThemeNameEdit.setObjectName("ThemeNameEdit")
+        self.ThemeNameEdit.setObjectName(u'ThemeNameEdit')
         self.ThemeNameLayout.addWidget(self.ThemeNameEdit)
         self.AmendThemeLayout.addWidget(self.ThemeNameWidget)
         self.ContentWidget = QtGui.QWidget(AmendThemeDialog)
-        self.ContentWidget.setObjectName("ContentWidget")
+        self.ContentWidget.setObjectName(u'ContentWidget')
         self.ContentLayout = QtGui.QHBoxLayout(self.ContentWidget)
         self.ContentLayout.setSpacing(8)
         self.ContentLayout.setMargin(0)
-        self.ContentLayout.setObjectName("ContentLayout")
+        self.ContentLayout.setObjectName(u'ContentLayout')
         self.ThemeTabWidget = QtGui.QTabWidget(self.ContentWidget)
-        self.ThemeTabWidget.setObjectName("ThemeTabWidget")
+        self.ThemeTabWidget.setObjectName(u'ThemeTabWidget')
         self.BackgroundTab = QtGui.QWidget()
-        self.BackgroundTab.setObjectName("BackgroundTab")
+        self.BackgroundTab.setObjectName(u'BackgroundTab')
         self.BackgroundLayout = QtGui.QFormLayout(self.BackgroundTab)
         self.BackgroundLayout.setMargin(8)
         self.BackgroundLayout.setSpacing(8)
-        self.BackgroundLayout.setObjectName("BackgroundLayout")
+        self.BackgroundLayout.setObjectName(u'BackgroundLayout')
         self.BackgroundLabel = QtGui.QLabel(self.BackgroundTab)
-        self.BackgroundLabel.setObjectName("BackgroundLabel")
+        self.BackgroundLabel.setObjectName(u'BackgroundLabel')
         self.BackgroundLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.BackgroundLabel)
         self.BackgroundComboBox = QtGui.QComboBox(self.BackgroundTab)
-        self.BackgroundComboBox.setObjectName("BackgroundComboBox")
+        self.BackgroundComboBox.setObjectName(u'BackgroundComboBox')
         self.BackgroundComboBox.addItem(QtCore.QString())
         self.BackgroundComboBox.addItem(QtCore.QString())
         self.BackgroundLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.BackgroundComboBox)
         self.BackgroundTypeLabel = QtGui.QLabel(self.BackgroundTab)
-        self.BackgroundTypeLabel.setObjectName("BackgroundTypeLabel")
+        self.BackgroundTypeLabel.setObjectName(u'BackgroundTypeLabel')
         self.BackgroundLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.BackgroundTypeLabel)
         self.BackgroundTypeComboBox = QtGui.QComboBox(self.BackgroundTab)
-        self.BackgroundTypeComboBox.setObjectName("BackgroundTypeComboBox")
+        self.BackgroundTypeComboBox.setObjectName(u'BackgroundTypeComboBox')
         self.BackgroundTypeComboBox.addItem(QtCore.QString())
         self.BackgroundTypeComboBox.addItem(QtCore.QString())
         self.BackgroundTypeComboBox.addItem(QtCore.QString())
         self.BackgroundLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.BackgroundTypeComboBox)
         self.Color1Label = QtGui.QLabel(self.BackgroundTab)
-        self.Color1Label.setObjectName("Color1Label")
+        self.Color1Label.setObjectName(u'Color1Label')
         self.BackgroundLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.Color1Label)
         self.Color1PushButton = QtGui.QPushButton(self.BackgroundTab)
-        self.Color1PushButton.setObjectName("Color1PushButton")
+        self.Color1PushButton.setObjectName(u'Color1PushButton')
         self.BackgroundLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.Color1PushButton)
         self.Color2Label = QtGui.QLabel(self.BackgroundTab)
-        self.Color2Label.setObjectName("Color2Label")
+        self.Color2Label.setObjectName(u'Color2Label')
         self.BackgroundLayout.setWidget(3, QtGui.QFormLayout.LabelRole, self.Color2Label)
         self.Color2PushButton = QtGui.QPushButton(self.BackgroundTab)
-        self.Color2PushButton.setObjectName("Color2PushButton")
+        self.Color2PushButton.setObjectName(u'Color2PushButton')
         self.BackgroundLayout.setWidget(3, QtGui.QFormLayout.FieldRole, self.Color2PushButton)
         self.ImageLabel = QtGui.QLabel(self.BackgroundTab)
-        self.ImageLabel.setObjectName("ImageLabel")
+        self.ImageLabel.setObjectName(u'ImageLabel')
         self.BackgroundLayout.setWidget(4, QtGui.QFormLayout.LabelRole, self.ImageLabel)
         self.GradientLabel = QtGui.QLabel(self.BackgroundTab)
-        self.GradientLabel.setObjectName("GradientLabel")
+        self.GradientLabel.setObjectName(u'GradientLabel')
         self.BackgroundLayout.setWidget(6, QtGui.QFormLayout.LabelRole, self.GradientLabel)
         self.GradientComboBox = QtGui.QComboBox(self.BackgroundTab)
-        self.GradientComboBox.setObjectName("GradientComboBox")
+        self.GradientComboBox.setObjectName(u'GradientComboBox')
         self.GradientComboBox.addItem(QtCore.QString())
         self.GradientComboBox.addItem(QtCore.QString())
         self.GradientComboBox.addItem(QtCore.QString())
         self.BackgroundLayout.setWidget(6, QtGui.QFormLayout.FieldRole, self.GradientComboBox)
         self.ImageFilenameWidget = QtGui.QWidget(self.BackgroundTab)
-        self.ImageFilenameWidget.setObjectName("ImageFilenameWidget")
+        self.ImageFilenameWidget.setObjectName(u'ImageFilenameWidget')
         self.horizontalLayout_2 = QtGui.QHBoxLayout(self.ImageFilenameWidget)
         self.horizontalLayout_2.setSpacing(0)
         self.horizontalLayout_2.setMargin(0)
-        self.horizontalLayout_2.setObjectName("horizontalLayout_2")
+        self.horizontalLayout_2.setObjectName(u'horizontalLayout_2')
         self.ImageLineEdit = QtGui.QLineEdit(self.ImageFilenameWidget)
-        self.ImageLineEdit.setObjectName("ImageLineEdit")
+        self.ImageLineEdit.setObjectName(u'ImageLineEdit')
         self.horizontalLayout_2.addWidget(self.ImageLineEdit)
         self.ImageToolButton = QtGui.QToolButton(self.ImageFilenameWidget)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/images/image_load.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/images/image_load.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ImageToolButton.setIcon(icon1)
-        self.ImageToolButton.setObjectName("ImageToolButton")
+        self.ImageToolButton.setObjectName(u'ImageToolButton')
         self.horizontalLayout_2.addWidget(self.ImageToolButton)
         self.BackgroundLayout.setWidget(4, QtGui.QFormLayout.FieldRole, self.ImageFilenameWidget)
         spacerItem = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         #self.BackgroundLayout.addItem(spacerItem, 7, 1, 1, 1)
-        self.ThemeTabWidget.addTab(self.BackgroundTab, "")
+        self.ThemeTabWidget.addTab(self.BackgroundTab, u'')
         self.FontMainTab = QtGui.QWidget()
-        self.FontMainTab.setObjectName("FontMainTab")
+        self.FontMainTab.setObjectName(u'FontMainTab')
         self.FontMainLayout = QtGui.QHBoxLayout(self.FontMainTab)
         self.FontMainLayout.setSpacing(8)
         self.FontMainLayout.setMargin(8)
-        self.FontMainLayout.setObjectName("FontMainLayout")
+        self.FontMainLayout.setObjectName(u'FontMainLayout')
         self.MainLeftWidget = QtGui.QWidget(self.FontMainTab)
-        self.MainLeftWidget.setObjectName("MainLeftWidget")
+        self.MainLeftWidget.setObjectName(u'MainLeftWidget')
         self.MainLeftLayout = QtGui.QVBoxLayout(self.MainLeftWidget)
         self.MainLeftLayout.setSpacing(8)
         self.MainLeftLayout.setMargin(0)
-        self.MainLeftLayout.setObjectName("MainLeftLayout")
+        self.MainLeftLayout.setObjectName(u'MainLeftLayout')
         self.FontMainGroupBox = QtGui.QGroupBox(self.MainLeftWidget)
-        self.FontMainGroupBox.setObjectName("FontMainGroupBox")
+        self.FontMainGroupBox.setObjectName(u'FontMainGroupBox')
         self.MainFontLayout = QtGui.QFormLayout(self.FontMainGroupBox)
         self.MainFontLayout.setFormAlignment(QtCore.Qt.AlignLeading|QtCore.Qt.AlignLeft|QtCore.Qt.AlignVCenter)
         self.MainFontLayout.setMargin(8)
         self.MainFontLayout.setSpacing(8)
-        self.MainFontLayout.setObjectName("MainFontLayout")
+        self.MainFontLayout.setObjectName(u'MainFontLayout')
         self.FontMainlabel = QtGui.QLabel(self.FontMainGroupBox)
-        self.FontMainlabel.setObjectName("FontMainlabel")
+        self.FontMainlabel.setObjectName(u'FontMainlabel')
         self.MainFontLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.FontMainlabel)
         self.FontMainComboBox = QtGui.QFontComboBox(self.FontMainGroupBox)
-        self.FontMainComboBox.setObjectName("FontMainComboBox")
+        self.FontMainComboBox.setObjectName(u'FontMainComboBox')
         self.MainFontLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.FontMainComboBox)
         self.FontMainColorLabel = QtGui.QLabel(self.FontMainGroupBox)
-        self.FontMainColorLabel.setObjectName("FontMainColorLabel")
+        self.FontMainColorLabel.setObjectName(u'FontMainColorLabel')
         self.MainFontLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.FontMainColorLabel)
         self.FontMainColorPushButton = QtGui.QPushButton(self.FontMainGroupBox)
-        self.FontMainColorPushButton.setObjectName("FontMainColorPushButton")
+        self.FontMainColorPushButton.setObjectName(u'FontMainColorPushButton')
         self.MainFontLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.FontMainColorPushButton)
         self.FontMainSize = QtGui.QLabel(self.FontMainGroupBox)
-        self.FontMainSize.setObjectName("FontMainSize")
+        self.FontMainSize.setObjectName(u'FontMainSize')
         self.MainFontLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.FontMainSize)
         self.FontMainSizeSpinBox = QtGui.QSpinBox(self.FontMainGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -150,44 +161,44 @@
         sizePolicy.setHeightForWidth(self.FontMainSizeSpinBox.sizePolicy().hasHeightForWidth())
         self.FontMainSizeSpinBox.setSizePolicy(sizePolicy)
         self.FontMainSizeSpinBox.setMinimumSize(QtCore.QSize(70, 0))
-        self.FontMainSizeSpinBox.setProperty("value", QtCore.QVariant(16))
+        self.FontMainSizeSpinBox.setProperty(u'value', QtCore.QVariant(16))
         self.FontMainSizeSpinBox.setMaximum(999)
-        self.FontMainSizeSpinBox.setObjectName("FontMainSizeSpinBox")
+        self.FontMainSizeSpinBox.setObjectName(u'FontMainSizeSpinBox')
         self.MainFontLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.FontMainSizeSpinBox)
         self.MainLeftLayout.addWidget(self.FontMainGroupBox)
         spacerItem1 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.MainLeftLayout.addItem(spacerItem1)
         self.FontMainLayout.addWidget(self.MainLeftWidget)
         self.MainRightWidget = QtGui.QWidget(self.FontMainTab)
-        self.MainRightWidget.setObjectName("MainRightWidget")
+        self.MainRightWidget.setObjectName(u'MainRightWidget')
         self.MainRightLayout = QtGui.QVBoxLayout(self.MainRightWidget)
         self.MainRightLayout.setSpacing(8)
         self.MainRightLayout.setMargin(0)
-        self.MainRightLayout.setObjectName("MainRightLayout")
+        self.MainRightLayout.setObjectName(u'MainRightLayout')
         self.MainLocationGroupBox = QtGui.QGroupBox(self.MainRightWidget)
-        self.MainLocationGroupBox.setObjectName("MainLocationGroupBox")
+        self.MainLocationGroupBox.setObjectName(u'MainLocationGroupBox')
         self.MainLocationLayout = QtGui.QFormLayout(self.MainLocationGroupBox)
         self.MainLocationLayout.setMargin(8)
         self.MainLocationLayout.setSpacing(8)
-        self.MainLocationLayout.setObjectName("MainLocationLayout")
+        self.MainLocationLayout.setObjectName(u'MainLocationLayout')
         self.DefaultLocationLabel = QtGui.QLabel(self.MainLocationGroupBox)
-        self.DefaultLocationLabel.setObjectName("DefaultLocationLabel")
+        self.DefaultLocationLabel.setObjectName(u'DefaultLocationLabel')
         self.MainLocationLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.DefaultLocationLabel)
         self.FontMainDefaultCheckBox = QtGui.QCheckBox(self.MainLocationGroupBox)
         self.FontMainDefaultCheckBox.setTristate(False)
-        self.FontMainDefaultCheckBox.setObjectName("FontMainDefaultCheckBox")
+        self.FontMainDefaultCheckBox.setObjectName(u'FontMainDefaultCheckBox')
         self.MainLocationLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.FontMainDefaultCheckBox)
         self.FontMainXLabel = QtGui.QLabel(self.MainLocationGroupBox)
-        self.FontMainXLabel.setObjectName("FontMainXLabel")
+        self.FontMainXLabel.setObjectName(u'FontMainXLabel')
         self.MainLocationLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.FontMainXLabel)
         self.FontMainYLabel = QtGui.QLabel(self.MainLocationGroupBox)
-        self.FontMainYLabel.setObjectName("FontMainYLabel")
+        self.FontMainYLabel.setObjectName(u'FontMainYLabel')
         self.MainLocationLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.FontMainYLabel)
         self.FontMainWidthLabel = QtGui.QLabel(self.MainLocationGroupBox)
-        self.FontMainWidthLabel.setObjectName("FontMainWidthLabel")
+        self.FontMainWidthLabel.setObjectName(u'FontMainWidthLabel')
         self.MainLocationLayout.setWidget(3, QtGui.QFormLayout.LabelRole, self.FontMainWidthLabel)
         self.FontMainHeightLabel = QtGui.QLabel(self.MainLocationGroupBox)
-        self.FontMainHeightLabel.setObjectName("FontMainHeightLabel")
+        self.FontMainHeightLabel.setObjectName(u'FontMainHeightLabel')
         self.MainLocationLayout.setWidget(4, QtGui.QFormLayout.LabelRole, self.FontMainHeightLabel)
         self.FontMainXSpinBox = QtGui.QSpinBox(self.MainLocationGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -196,9 +207,9 @@
         sizePolicy.setHeightForWidth(self.FontMainXSpinBox.sizePolicy().hasHeightForWidth())
         self.FontMainXSpinBox.setSizePolicy(sizePolicy)
         self.FontMainXSpinBox.setMinimumSize(QtCore.QSize(78, 0))
-        self.FontMainXSpinBox.setProperty("value", QtCore.QVariant(0))
+        self.FontMainXSpinBox.setProperty(u'value', QtCore.QVariant(0))
         self.FontMainXSpinBox.setMaximum(9999)
-        self.FontMainXSpinBox.setObjectName("FontMainXSpinBox")
+        self.FontMainXSpinBox.setObjectName(u'FontMainXSpinBox')
         self.MainLocationLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.FontMainXSpinBox)
         self.FontMainYSpinBox = QtGui.QSpinBox(self.MainLocationGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -208,7 +219,7 @@
         self.FontMainYSpinBox.setSizePolicy(sizePolicy)
         self.FontMainYSpinBox.setMinimumSize(QtCore.QSize(78, 0))
         self.FontMainYSpinBox.setMaximum(9999)
-        self.FontMainYSpinBox.setObjectName("FontMainYSpinBox")
+        self.FontMainYSpinBox.setObjectName(u'FontMainYSpinBox')
         self.MainLocationLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.FontMainYSpinBox)
         self.FontMainWidthSpinBox = QtGui.QSpinBox(self.MainLocationGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -218,7 +229,7 @@
         self.FontMainWidthSpinBox.setSizePolicy(sizePolicy)
         self.FontMainWidthSpinBox.setMinimumSize(QtCore.QSize(78, 0))
         self.FontMainWidthSpinBox.setMaximum(9999)
-        self.FontMainWidthSpinBox.setObjectName("FontMainWidthSpinBox")
+        self.FontMainWidthSpinBox.setObjectName(u'FontMainWidthSpinBox')
         self.MainLocationLayout.setWidget(3, QtGui.QFormLayout.FieldRole, self.FontMainWidthSpinBox)
         self.FontMainHeightSpinBox = QtGui.QSpinBox(self.MainLocationGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -228,47 +239,47 @@
         self.FontMainHeightSpinBox.setSizePolicy(sizePolicy)
         self.FontMainHeightSpinBox.setMinimumSize(QtCore.QSize(78, 0))
         self.FontMainHeightSpinBox.setMaximum(9999)
-        self.FontMainHeightSpinBox.setObjectName("FontMainHeightSpinBox")
+        self.FontMainHeightSpinBox.setObjectName(u'FontMainHeightSpinBox')
         self.MainLocationLayout.setWidget(4, QtGui.QFormLayout.FieldRole, self.FontMainHeightSpinBox)
         self.MainRightLayout.addWidget(self.MainLocationGroupBox)
         spacerItem2 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.MainRightLayout.addItem(spacerItem2)
         self.FontMainLayout.addWidget(self.MainRightWidget)
-        self.ThemeTabWidget.addTab(self.FontMainTab, "")
+        self.ThemeTabWidget.addTab(self.FontMainTab, u'')
         self.FontFooterTab = QtGui.QWidget()
-        self.FontFooterTab.setObjectName("FontFooterTab")
+        self.FontFooterTab.setObjectName(u'FontFooterTab')
         self.FontFooterLayout = QtGui.QHBoxLayout(self.FontFooterTab)
         self.FontFooterLayout.setSpacing(8)
         self.FontFooterLayout.setMargin(8)
-        self.FontFooterLayout.setObjectName("FontFooterLayout")
+        self.FontFooterLayout.setObjectName(u'FontFooterLayout')
         self.FooterLeftWidget = QtGui.QWidget(self.FontFooterTab)
-        self.FooterLeftWidget.setObjectName("FooterLeftWidget")
+        self.FooterLeftWidget.setObjectName(u'FooterLeftWidget')
         self.FooterLeftLayout = QtGui.QVBoxLayout(self.FooterLeftWidget)
         self.FooterLeftLayout.setSpacing(8)
         self.FooterLeftLayout.setMargin(0)
-        self.FooterLeftLayout.setObjectName("FooterLeftLayout")
+        self.FooterLeftLayout.setObjectName(u'FooterLeftLayout')
         self.FooterFontGroupBox = QtGui.QGroupBox(self.FooterLeftWidget)
-        self.FooterFontGroupBox.setObjectName("FooterFontGroupBox")
+        self.FooterFontGroupBox.setObjectName(u'FooterFontGroupBox')
         self.FooterFontLayout = QtGui.QFormLayout(self.FooterFontGroupBox)
         self.FooterFontLayout.setFieldGrowthPolicy(QtGui.QFormLayout.ExpandingFieldsGrow)
         self.FooterFontLayout.setFormAlignment(QtCore.Qt.AlignLeading|QtCore.Qt.AlignLeft|QtCore.Qt.AlignVCenter)
         self.FooterFontLayout.setMargin(8)
         self.FooterFontLayout.setSpacing(8)
-        self.FooterFontLayout.setObjectName("FooterFontLayout")
+        self.FooterFontLayout.setObjectName(u'FooterFontLayout')
         self.FontFooterLabel = QtGui.QLabel(self.FooterFontGroupBox)
-        self.FontFooterLabel.setObjectName("FontFooterLabel")
+        self.FontFooterLabel.setObjectName(u'FontFooterLabel')
         self.FooterFontLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.FontFooterLabel)
         self.FontFooterComboBox = QtGui.QFontComboBox(self.FooterFontGroupBox)
-        self.FontFooterComboBox.setObjectName("FontFooterComboBox")
+        self.FontFooterComboBox.setObjectName(u'FontFooterComboBox')
         self.FooterFontLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.FontFooterComboBox)
         self.FontFooterColorLabel = QtGui.QLabel(self.FooterFontGroupBox)
-        self.FontFooterColorLabel.setObjectName("FontFooterColorLabel")
+        self.FontFooterColorLabel.setObjectName(u'FontFooterColorLabel')
         self.FooterFontLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.FontFooterColorLabel)
         self.FontFooterColorPushButton = QtGui.QPushButton(self.FooterFontGroupBox)
-        self.FontFooterColorPushButton.setObjectName("FontFooterColorPushButton")
+        self.FontFooterColorPushButton.setObjectName(u'FontFooterColorPushButton')
         self.FooterFontLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.FontFooterColorPushButton)
         self.FontFooterSizeLabel = QtGui.QLabel(self.FooterFontGroupBox)
-        self.FontFooterSizeLabel.setObjectName("FontFooterSizeLabel")
+        self.FontFooterSizeLabel.setObjectName(u'FontFooterSizeLabel')
         self.FooterFontLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.FontFooterSizeLabel)
         self.FontFooterSizeSpinBox = QtGui.QSpinBox(self.FooterFontGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -277,46 +288,46 @@
         sizePolicy.setHeightForWidth(self.FontFooterSizeSpinBox.sizePolicy().hasHeightForWidth())
         self.FontFooterSizeSpinBox.setSizePolicy(sizePolicy)
         self.FontFooterSizeSpinBox.setMinimumSize(QtCore.QSize(70, 0))
-        self.FontFooterSizeSpinBox.setProperty("value", QtCore.QVariant(10))
+        self.FontFooterSizeSpinBox.setProperty(u'value', QtCore.QVariant(10))
         self.FontFooterSizeSpinBox.setMaximum(999)
-        self.FontFooterSizeSpinBox.setObjectName("FontFooterSizeSpinBox")
+        self.FontFooterSizeSpinBox.setObjectName(u'FontFooterSizeSpinBox')
         self.FooterFontLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.FontFooterSizeSpinBox)
         self.FooterLeftLayout.addWidget(self.FooterFontGroupBox)
         spacerItem3 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.FooterLeftLayout.addItem(spacerItem3)
         self.FontFooterLayout.addWidget(self.FooterLeftWidget)
         self.FooterRightWidget = QtGui.QWidget(self.FontFooterTab)
-        self.FooterRightWidget.setObjectName("FooterRightWidget")
+        self.FooterRightWidget.setObjectName(u'FooterRightWidget')
         self.FooterRightLayout = QtGui.QVBoxLayout(self.FooterRightWidget)
         self.FooterRightLayout.setSpacing(8)
         self.FooterRightLayout.setMargin(0)
-        self.FooterRightLayout.setObjectName("FooterRightLayout")
+        self.FooterRightLayout.setObjectName(u'FooterRightLayout')
         self.LocationFooterGroupBox = QtGui.QGroupBox(self.FooterRightWidget)
-        self.LocationFooterGroupBox.setObjectName("LocationFooterGroupBox")
+        self.LocationFooterGroupBox.setObjectName(u'LocationFooterGroupBox')
         self.LocationFooterLayout = QtGui.QFormLayout(self.LocationFooterGroupBox)
         self.LocationFooterLayout.setFieldGrowthPolicy(QtGui.QFormLayout.ExpandingFieldsGrow)
         self.LocationFooterLayout.setFormAlignment(QtCore.Qt.AlignLeading|QtCore.Qt.AlignLeft|QtCore.Qt.AlignVCenter)
         self.LocationFooterLayout.setMargin(8)
         self.LocationFooterLayout.setSpacing(8)
-        self.LocationFooterLayout.setObjectName("LocationFooterLayout")
+        self.LocationFooterLayout.setObjectName(u'LocationFooterLayout')
         self.FontFooterDefaultLabel = QtGui.QLabel(self.LocationFooterGroupBox)
-        self.FontFooterDefaultLabel.setObjectName("FontFooterDefaultLabel")
+        self.FontFooterDefaultLabel.setObjectName(u'FontFooterDefaultLabel')
         self.LocationFooterLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.FontFooterDefaultLabel)
         self.FontFooterDefaultCheckBox = QtGui.QCheckBox(self.LocationFooterGroupBox)
         self.FontFooterDefaultCheckBox.setTristate(False)
-        self.FontFooterDefaultCheckBox.setObjectName("FontFooterDefaultCheckBox")
+        self.FontFooterDefaultCheckBox.setObjectName(u'FontFooterDefaultCheckBox')
         self.LocationFooterLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.FontFooterDefaultCheckBox)
         self.FontFooterXLabel = QtGui.QLabel(self.LocationFooterGroupBox)
-        self.FontFooterXLabel.setObjectName("FontFooterXLabel")
+        self.FontFooterXLabel.setObjectName(u'FontFooterXLabel')
         self.LocationFooterLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.FontFooterXLabel)
         self.FontFooterYLabel = QtGui.QLabel(self.LocationFooterGroupBox)
-        self.FontFooterYLabel.setObjectName("FontFooterYLabel")
+        self.FontFooterYLabel.setObjectName(u'FontFooterYLabel')
         self.LocationFooterLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.FontFooterYLabel)
         self.FontFooterWidthLabel = QtGui.QLabel(self.LocationFooterGroupBox)
-        self.FontFooterWidthLabel.setObjectName("FontFooterWidthLabel")
+        self.FontFooterWidthLabel.setObjectName(u'FontFooterWidthLabel')
         self.LocationFooterLayout.setWidget(3, QtGui.QFormLayout.LabelRole, self.FontFooterWidthLabel)
         self.FontFooterHeightLabel = QtGui.QLabel(self.LocationFooterGroupBox)
-        self.FontFooterHeightLabel.setObjectName("FontFooterHeightLabel")
+        self.FontFooterHeightLabel.setObjectName(u'FontFooterHeightLabel')
         self.LocationFooterLayout.setWidget(4, QtGui.QFormLayout.LabelRole, self.FontFooterHeightLabel)
         self.FontFooterXSpinBox = QtGui.QSpinBox(self.LocationFooterGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -325,9 +336,9 @@
         sizePolicy.setHeightForWidth(self.FontFooterXSpinBox.sizePolicy().hasHeightForWidth())
         self.FontFooterXSpinBox.setSizePolicy(sizePolicy)
         self.FontFooterXSpinBox.setMinimumSize(QtCore.QSize(78, 0))
-        self.FontFooterXSpinBox.setProperty("value", QtCore.QVariant(0))
+        self.FontFooterXSpinBox.setProperty(u'value', QtCore.QVariant(0))
         self.FontFooterXSpinBox.setMaximum(9999)
-        self.FontFooterXSpinBox.setObjectName("FontFooterXSpinBox")
+        self.FontFooterXSpinBox.setObjectName(u'FontFooterXSpinBox')
         self.LocationFooterLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.FontFooterXSpinBox)
         self.FontFooterYSpinBox = QtGui.QSpinBox(self.LocationFooterGroupBox)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
@@ -336,79 +347,79 @@
         sizePolicy.setHeightForWidth(self.FontFooterYSpinBox.sizePolicy().hasHeightForWidth())
         self.FontFooterYSpinBox.setSizePolicy(sizePolicy)
         self.FontFooterYSpinBox.setMinimumSize(QtCore.QSize(78, 0))
-        self.FontFooterYSpinBox.setProperty("value", QtCore.QVariant(0))
+        self.FontFooterYSpinBox.setProperty(u'value', QtCore.QVariant(0))
         self.FontFooterYSpinBox.setMaximum(9999)
-        self.FontFooterYSpinBox.setObjectName("FontFooterYSpinBox")
+        self.FontFooterYSpinBox.setObjectName(u'FontFooterYSpinBox')
         self.LocationFooterLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.FontFooterYSpinBox)
         self.FontFooterWidthSpinBox = QtGui.QSpinBox(self.LocationFooterGroupBox)
         self.FontFooterWidthSpinBox.setMinimumSize(QtCore.QSize(78, 0))
         self.FontFooterWidthSpinBox.setMaximum(9999)
-        self.FontFooterWidthSpinBox.setObjectName("FontFooterWidthSpinBox")
+        self.FontFooterWidthSpinBox.setObjectName(u'FontFooterWidthSpinBox')
         self.LocationFooterLayout.setWidget(3, QtGui.QFormLayout.FieldRole, self.FontFooterWidthSpinBox)
         self.FontFooterHeightSpinBox = QtGui.QSpinBox(self.LocationFooterGroupBox)
         self.FontFooterHeightSpinBox.setMinimumSize(QtCore.QSize(78, 0))
         self.FontFooterHeightSpinBox.setMaximum(9999)
-        self.FontFooterHeightSpinBox.setObjectName("FontFooterHeightSpinBox")
+        self.FontFooterHeightSpinBox.setObjectName(u'FontFooterHeightSpinBox')
         self.LocationFooterLayout.setWidget(4, QtGui.QFormLayout.FieldRole, self.FontFooterHeightSpinBox)
         self.FooterRightLayout.addWidget(self.LocationFooterGroupBox)
         spacerItem4 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.FooterRightLayout.addItem(spacerItem4)
         self.FontFooterLayout.addWidget(self.FooterRightWidget)
-        self.ThemeTabWidget.addTab(self.FontFooterTab, "")
+        self.ThemeTabWidget.addTab(self.FontFooterTab, u'')
         self.OtherOptionsTab = QtGui.QWidget()
-        self.OtherOptionsTab.setObjectName("OtherOptionsTab")
+        self.OtherOptionsTab.setObjectName(u'OtherOptionsTab')
         self.OtherOptionsLayout = QtGui.QHBoxLayout(self.OtherOptionsTab)
         self.OtherOptionsLayout.setSpacing(8)
         self.OtherOptionsLayout.setMargin(8)
-        self.OtherOptionsLayout.setObjectName("OtherOptionsLayout")
+        self.OtherOptionsLayout.setObjectName(u'OtherOptionsLayout')
         self.OptionsLeftWidget = QtGui.QWidget(self.OtherOptionsTab)
-        self.OptionsLeftWidget.setObjectName("OptionsLeftWidget")
+        self.OptionsLeftWidget.setObjectName(u'OptionsLeftWidget')
         self.OptionsLeftLayout = QtGui.QVBoxLayout(self.OptionsLeftWidget)
         self.OptionsLeftLayout.setSpacing(8)
         self.OptionsLeftLayout.setMargin(0)
-        self.OptionsLeftLayout.setObjectName("OptionsLeftLayout")
+        self.OptionsLeftLayout.setObjectName(u'OptionsLeftLayout')
         self.ShadowGroupBox = QtGui.QGroupBox(self.OptionsLeftWidget)
-        self.ShadowGroupBox.setObjectName("ShadowGroupBox")
+        self.ShadowGroupBox.setObjectName(u'ShadowGroupBox')
         self.verticalLayout = QtGui.QVBoxLayout(self.ShadowGroupBox)
         self.verticalLayout.setSpacing(8)
         self.verticalLayout.setMargin(8)
-        self.verticalLayout.setObjectName("verticalLayout")
+        self.verticalLayout.setObjectName(u'verticalLayout')
         self.OutlineWidget = QtGui.QWidget(self.ShadowGroupBox)
-        self.OutlineWidget.setObjectName("OutlineWidget")
+        self.OutlineWidget.setObjectName(u'OutlineWidget')
         self.OutlineLayout = QtGui.QFormLayout(self.OutlineWidget)
         self.OutlineLayout.setMargin(0)
         self.OutlineLayout.setSpacing(8)
-        self.OutlineLayout.setObjectName("OutlineLayout")
+        self.OutlineLayout.setObjectName(u'OutlineLayout')
         self.OutlineCheckBox = QtGui.QCheckBox(self.OutlineWidget)
-        self.OutlineCheckBox.setObjectName("OutlineCheckBox")
+        self.OutlineCheckBox.setObjectName(u'OutlineCheckBox')
         self.OutlineLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.OutlineCheckBox)
         self.OutlineColorLabel = QtGui.QLabel(self.OutlineWidget)
-        self.OutlineColorLabel.setObjectName("OutlineColorLabel")
+        self.OutlineColorLabel.setObjectName(u'OutlineColorLabel')
         self.OutlineLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.OutlineColorLabel)
         self.OutlineColorPushButton = QtGui.QPushButton(self.OutlineWidget)
-        self.OutlineColorPushButton.setObjectName("OutlineColorPushButton")
+        self.OutlineColorPushButton.setObjectName(u'OutlineColorPushButton')
         self.OutlineLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.OutlineColorPushButton)
         self.OutlineEnabledLabel = QtGui.QLabel(self.OutlineWidget)
-        self.OutlineEnabledLabel.setObjectName("OutlineEnabledLabel")
+        self.OutlineEnabledLabel.setObjectName(u'OutlineEnabledLabel')
         self.OutlineLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.OutlineEnabledLabel)
         self.verticalLayout.addWidget(self.OutlineWidget)
         self.ShadowWidget = QtGui.QWidget(self.ShadowGroupBox)
-        self.ShadowWidget.setObjectName("ShadowWidget")
+        self.ShadowWidget.setObjectName(u'ShadowWidget')
         self.ShadowLayout = QtGui.QFormLayout(self.ShadowWidget)
         self.ShadowLayout.setMargin(0)
         self.ShadowLayout.setSpacing(8)
-        self.ShadowLayout.setObjectName("ShadowLayout")
+        self.ShadowLayout.setObjectName(u'ShadowLayout')
         self.ShadowCheckBox = QtGui.QCheckBox(self.ShadowWidget)
-        self.ShadowCheckBox.setObjectName("ShadowCheckBox")
+        self.ShadowCheckBox.setObjectName(u'ShadowCheckBox')
         self.ShadowLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.ShadowCheckBox)
         self.ShadowColorLabel = QtGui.QLabel(self.ShadowWidget)
-        self.ShadowColorLabel.setObjectName("ShadowColorLabel")
+        self.ShadowColorLabel.setObjectName(u'ShadowColorLabel')
         self.ShadowLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.ShadowColorLabel)
         self.ShadowColorPushButton = QtGui.QPushButton(self.ShadowWidget)
-        self.ShadowColorPushButton.setObjectName("ShadowColorPushButton")
+        self.ShadowColorPushButton.setObjectName(u'ShadowColorPushButton')
         self.ShadowLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.ShadowColorPushButton)
         self.ShadowEnabledLabel = QtGui.QLabel(self.ShadowWidget)
-        self.ShadowEnabledLabel.setObjectName("ShadowEnabledLabel")
+        self.ShadowEnabledLabel.setObjectName(u'ShadowEnabledLabel')
         self.ShadowLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.ShadowEnabledLabel)
         self.verticalLayout.addWidget(self.ShadowWidget)
         self.OptionsLeftLayout.addWidget(self.ShadowGroupBox)
@@ -416,29 +427,29 @@
         self.OptionsLeftLayout.addItem(spacerItem5)
         self.OtherOptionsLayout.addWidget(self.OptionsLeftWidget)
         self.OptionsRightWidget = QtGui.QWidget(self.OtherOptionsTab)
-        self.OptionsRightWidget.setObjectName("OptionsRightWidget")
+        self.OptionsRightWidget.setObjectName(u'OptionsRightWidget')
         self.OptionsRightLayout = QtGui.QVBoxLayout(self.OptionsRightWidget)
         self.OptionsRightLayout.setSpacing(8)
         self.OptionsRightLayout.setMargin(0)
-        self.OptionsRightLayout.setObjectName("OptionsRightLayout")
+        self.OptionsRightLayout.setObjectName(u'OptionsRightLayout')
         self.AlignmentGroupBox = QtGui.QGroupBox(self.OptionsRightWidget)
-        self.AlignmentGroupBox.setObjectName("AlignmentGroupBox")
+        self.AlignmentGroupBox.setObjectName(u'AlignmentGroupBox')
         self.gridLayout_4 = QtGui.QGridLayout(self.AlignmentGroupBox)
-        self.gridLayout_4.setObjectName("gridLayout_4")
+        self.gridLayout_4.setObjectName(u'gridLayout_4')
         self.HorizontalLabel = QtGui.QLabel(self.AlignmentGroupBox)
-        self.HorizontalLabel.setObjectName("HorizontalLabel")
+        self.HorizontalLabel.setObjectName(u'HorizontalLabel')
         self.gridLayout_4.addWidget(self.HorizontalLabel, 0, 0, 1, 1)
         self.HorizontalComboBox = QtGui.QComboBox(self.AlignmentGroupBox)
-        self.HorizontalComboBox.setObjectName("HorizontalComboBox")
+        self.HorizontalComboBox.setObjectName(u'HorizontalComboBox')
         self.HorizontalComboBox.addItem(QtCore.QString())
         self.HorizontalComboBox.addItem(QtCore.QString())
         self.HorizontalComboBox.addItem(QtCore.QString())
         self.gridLayout_4.addWidget(self.HorizontalComboBox, 0, 1, 1, 1)
         self.VerticalLabel = QtGui.QLabel(self.AlignmentGroupBox)
-        self.VerticalLabel.setObjectName("VerticalLabel")
+        self.VerticalLabel.setObjectName(u'VerticalLabel')
         self.gridLayout_4.addWidget(self.VerticalLabel, 1, 0, 1, 1)
         self.VerticalComboBox = QtGui.QComboBox(self.AlignmentGroupBox)
-        self.VerticalComboBox.setObjectName("VerticalComboBox")
+        self.VerticalComboBox.setObjectName(u'VerticalComboBox')
         self.VerticalComboBox.addItem(QtCore.QString())
         self.VerticalComboBox.addItem(QtCore.QString())
         self.VerticalComboBox.addItem(QtCore.QString())
@@ -447,15 +458,15 @@
         spacerItem6 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.OptionsRightLayout.addItem(spacerItem6)
         self.OtherOptionsLayout.addWidget(self.OptionsRightWidget)
-        self.ThemeTabWidget.addTab(self.OtherOptionsTab, "")
+        self.ThemeTabWidget.addTab(self.OtherOptionsTab, u'')
         self.ContentLayout.addWidget(self.ThemeTabWidget)
         self.AmendThemeLayout.addWidget(self.ContentWidget)
         self.PreviewGroupBox = QtGui.QGroupBox(AmendThemeDialog)
-        self.PreviewGroupBox.setObjectName("PreviewGroupBox")
+        self.PreviewGroupBox.setObjectName(u'PreviewGroupBox')
         self.ThemePreviewLayout = QtGui.QHBoxLayout(self.PreviewGroupBox)
         self.ThemePreviewLayout.setSpacing(8)
         self.ThemePreviewLayout.setMargin(8)
-        self.ThemePreviewLayout.setObjectName("ThemePreviewLayout")
+        self.ThemePreviewLayout.setObjectName(u'ThemePreviewLayout')
         spacerItem7 = QtGui.QSpacerItem(40, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Expanding)
         self.ThemePreviewLayout.addItem(spacerItem7)
         self.ThemePreview = QtGui.QLabel(self.PreviewGroupBox)
@@ -469,20 +480,20 @@
         self.ThemePreview.setFrameShadow(QtGui.QFrame.Sunken)
         self.ThemePreview.setLineWidth(1)
         self.ThemePreview.setScaledContents(True)
-        self.ThemePreview.setObjectName("ThemePreview")
+        self.ThemePreview.setObjectName(u'ThemePreview')
         self.ThemePreviewLayout.addWidget(self.ThemePreview)
         spacerItem8 = QtGui.QSpacerItem(40, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Expanding)
         self.ThemePreviewLayout.addItem(spacerItem8)
         self.AmendThemeLayout.addWidget(self.PreviewGroupBox)
         self.ThemeButtonBox = QtGui.QDialogButtonBox(AmendThemeDialog)
         self.ThemeButtonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
-        self.ThemeButtonBox.setObjectName("ThemeButtonBox")
+        self.ThemeButtonBox.setObjectName(u'ThemeButtonBox')
         self.AmendThemeLayout.addWidget(self.ThemeButtonBox)
 
         self.retranslateUi(AmendThemeDialog)
         self.ThemeTabWidget.setCurrentIndex(0)
-        QtCore.QObject.connect(self.ThemeButtonBox, QtCore.SIGNAL("accepted()"), AmendThemeDialog.accept)
-        QtCore.QObject.connect(self.ThemeButtonBox, QtCore.SIGNAL("rejected()"), AmendThemeDialog.reject)
+        QtCore.QObject.connect(self.ThemeButtonBox, QtCore.SIGNAL(u'accepted()'), AmendThemeDialog.accept)
+        QtCore.QObject.connect(self.ThemeButtonBox, QtCore.SIGNAL(u'rejected()'), AmendThemeDialog.reject)
         QtCore.QMetaObject.connectSlotsByName(AmendThemeDialog)
         AmendThemeDialog.setTabOrder(self.ThemeButtonBox, self.ThemeNameEdit)
         AmendThemeDialog.setTabOrder(self.ThemeNameEdit, self.ThemeTabWidget)
@@ -517,69 +528,68 @@
         AmendThemeDialog.setTabOrder(self.HorizontalComboBox, self.VerticalComboBox)
 
     def retranslateUi(self, AmendThemeDialog):
-        AmendThemeDialog.setWindowTitle(QtGui.QApplication.translate("AmendThemeDialog", "Theme Maintenance", None, QtGui.QApplication.UnicodeUTF8))
-        self.ThemeNameLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Theme Name:", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Background:", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundComboBox.setItemText(0, QtGui.QApplication.translate("AmendThemeDialog", "Opaque", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundComboBox.setItemText(1, QtGui.QApplication.translate("AmendThemeDialog", "Transparent", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundTypeLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Background Type:", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundTypeComboBox.setItemText(0, QtGui.QApplication.translate("AmendThemeDialog", "Solid Color", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundTypeComboBox.setItemText(1, QtGui.QApplication.translate("AmendThemeDialog", "Gradient", None, QtGui.QApplication.UnicodeUTF8))
-        self.BackgroundTypeComboBox.setItemText(2, QtGui.QApplication.translate("AmendThemeDialog", "Image", None, QtGui.QApplication.UnicodeUTF8))
-        self.Color1Label.setText(QtGui.QApplication.translate("AmendThemeDialog", "<Color1>", None, QtGui.QApplication.UnicodeUTF8))
-        self.Color2Label.setText(QtGui.QApplication.translate("AmendThemeDialog", "<Color2>", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImageLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Image:", None, QtGui.QApplication.UnicodeUTF8))
-        self.GradientLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Gradient :", None, QtGui.QApplication.UnicodeUTF8))
-        self.GradientComboBox.setItemText(0, QtGui.QApplication.translate("AmendThemeDialog", "Horizontal", None, QtGui.QApplication.UnicodeUTF8))
-        self.GradientComboBox.setItemText(1, QtGui.QApplication.translate("AmendThemeDialog", "Vertical", None, QtGui.QApplication.UnicodeUTF8))
-        self.GradientComboBox.setItemText(2, QtGui.QApplication.translate("AmendThemeDialog", "Circular", None, QtGui.QApplication.UnicodeUTF8))
-        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.BackgroundTab), QtGui.QApplication.translate("AmendThemeDialog", "Background", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Main Font", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainlabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Font:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainColorLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Font Color:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainSize.setText(QtGui.QApplication.translate("AmendThemeDialog", "Size:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainSizeSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "pt", None, QtGui.QApplication.UnicodeUTF8))
-        self.MainLocationGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Display Location", None, QtGui.QApplication.UnicodeUTF8))
-        self.DefaultLocationLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Use Default Location:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainXLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "X Position:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainYLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Y Position:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainWidthLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Width:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainHeightLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Height:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainXSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainYSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainWidthSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontMainHeightSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.FontMainTab), QtGui.QApplication.translate("AmendThemeDialog", "Font Main", None, QtGui.QApplication.UnicodeUTF8))
-        self.FooterFontGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Footer Font", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Font:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterColorLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Font Color:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterSizeLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Size:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterSizeSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "pt", None, QtGui.QApplication.UnicodeUTF8))
-        self.LocationFooterGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Display Location", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterDefaultLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Use Default Location:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterXLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "X Position:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterYLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Y Position:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterWidthLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Width:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterHeightLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Height:", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterXSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterYSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterWidthSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.FontFooterHeightSpinBox.setSuffix(QtGui.QApplication.translate("AmendThemeDialog", "px", None, QtGui.QApplication.UnicodeUTF8))
-        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.FontFooterTab), QtGui.QApplication.translate("AmendThemeDialog", "Font Footer", None, QtGui.QApplication.UnicodeUTF8))
-        self.ShadowGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Shadow && Outline", None, QtGui.QApplication.UnicodeUTF8))
-        self.OutlineColorLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Outline Color:", None, QtGui.QApplication.UnicodeUTF8))
-        self.OutlineEnabledLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Show Outline:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ShadowColorLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Shadow Color:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ShadowEnabledLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Show Shadow:", None, QtGui.QApplication.UnicodeUTF8))
-        self.AlignmentGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Alignment", None, QtGui.QApplication.UnicodeUTF8))
-        self.HorizontalLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Horizontal Align:", None, QtGui.QApplication.UnicodeUTF8))
-        self.HorizontalComboBox.setItemText(0, QtGui.QApplication.translate("AmendThemeDialog", "Left", None, QtGui.QApplication.UnicodeUTF8))
-        self.HorizontalComboBox.setItemText(1, QtGui.QApplication.translate("AmendThemeDialog", "Right", None, QtGui.QApplication.UnicodeUTF8))
-        self.HorizontalComboBox.setItemText(2, QtGui.QApplication.translate("AmendThemeDialog", "Center", None, QtGui.QApplication.UnicodeUTF8))
-        self.VerticalLabel.setText(QtGui.QApplication.translate("AmendThemeDialog", "Vertical Align:", None, QtGui.QApplication.UnicodeUTF8))
-        self.VerticalComboBox.setItemText(0, QtGui.QApplication.translate("AmendThemeDialog", "Top", None, QtGui.QApplication.UnicodeUTF8))
-        self.VerticalComboBox.setItemText(1, QtGui.QApplication.translate("AmendThemeDialog", "Middle", None, QtGui.QApplication.UnicodeUTF8))
-        self.VerticalComboBox.setItemText(2, QtGui.QApplication.translate("AmendThemeDialog", "Bottom", None, QtGui.QApplication.UnicodeUTF8))
-        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.OtherOptionsTab), QtGui.QApplication.translate("AmendThemeDialog", "Other Options", None, QtGui.QApplication.UnicodeUTF8))
-        self.PreviewGroupBox.setTitle(QtGui.QApplication.translate("AmendThemeDialog", "Preview", None, QtGui.QApplication.UnicodeUTF8))
-
+        AmendThemeDialog.setWindowTitle(translate(u'AmendThemeDialog', u'Theme Maintenance'))
+        self.ThemeNameLabel.setText(translate(u'AmendThemeDialog', u'Theme Name:'))
+        self.BackgroundLabel.setText(translate(u'AmendThemeDialog', u'Background:'))
+        self.BackgroundComboBox.setItemText(0, translate(u'AmendThemeDialog', u'Opaque'))
+        self.BackgroundComboBox.setItemText(1, translate(u'AmendThemeDialog', u'Transparent'))
+        self.BackgroundTypeLabel.setText(translate(u'AmendThemeDialog', u'Background Type:'))
+        self.BackgroundTypeComboBox.setItemText(0, translate(u'AmendThemeDialog', u'Solid Color'))
+        self.BackgroundTypeComboBox.setItemText(1, translate(u'AmendThemeDialog', u'Gradient'))
+        self.BackgroundTypeComboBox.setItemText(2, translate(u'AmendThemeDialog', u'Image'))
+        self.Color1Label.setText(translate(u'AmendThemeDialog', u'<Color1>'))
+        self.Color2Label.setText(translate(u'AmendThemeDialog', u'<Color2>'))
+        self.ImageLabel.setText(translate(u'AmendThemeDialog', u'Image:'))
+        self.GradientLabel.setText(translate(u'AmendThemeDialog', u'Gradient :'))
+        self.GradientComboBox.setItemText(0, translate(u'AmendThemeDialog', u'Horizontal'))
+        self.GradientComboBox.setItemText(1, translate(u'AmendThemeDialog', u'Vertical'))
+        self.GradientComboBox.setItemText(2, translate(u'AmendThemeDialog', u'Circular'))
+        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.BackgroundTab), translate(u'AmendThemeDialog', u'Background'))
+        self.FontMainGroupBox.setTitle(translate(u'AmendThemeDialog', u'Main Font'))
+        self.FontMainlabel.setText(translate(u'AmendThemeDialog', u'Font:'))
+        self.FontMainColorLabel.setText(translate(u'AmendThemeDialog', u'Font Color:'))
+        self.FontMainSize.setText(translate(u'AmendThemeDialog', u'Size:'))
+        self.FontMainSizeSpinBox.setSuffix(translate(u'AmendThemeDialog', u'pt'))
+        self.MainLocationGroupBox.setTitle(translate(u'AmendThemeDialog', u'Display Location'))
+        self.DefaultLocationLabel.setText(translate(u'AmendThemeDialog', u'Use Default Location:'))
+        self.FontMainXLabel.setText(translate(u'AmendThemeDialog', u'X Position:'))
+        self.FontMainYLabel.setText(translate(u'AmendThemeDialog', u'Y Position:'))
+        self.FontMainWidthLabel.setText(translate(u'AmendThemeDialog', u'Width:'))
+        self.FontMainHeightLabel.setText(translate(u'AmendThemeDialog', u'Height:'))
+        self.FontMainXSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.FontMainYSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.FontMainWidthSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.FontMainHeightSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.FontMainTab), translate(u'AmendThemeDialog', u'Font Main'))
+        self.FooterFontGroupBox.setTitle(translate(u'AmendThemeDialog', u'Footer Font'))
+        self.FontFooterLabel.setText(translate(u'AmendThemeDialog', u'Font:'))
+        self.FontFooterColorLabel.setText(translate(u'AmendThemeDialog', u'Font Color:'))
+        self.FontFooterSizeLabel.setText(translate(u'AmendThemeDialog', u'Size:'))
+        self.FontFooterSizeSpinBox.setSuffix(translate(u'AmendThemeDialog', u'pt'))
+        self.LocationFooterGroupBox.setTitle(translate(u'AmendThemeDialog', u'Display Location'))
+        self.FontFooterDefaultLabel.setText(translate(u'AmendThemeDialog', u'Use Default Location:'))
+        self.FontFooterXLabel.setText(translate(u'AmendThemeDialog', u'X Position:'))
+        self.FontFooterYLabel.setText(translate(u'AmendThemeDialog', u'Y Position:'))
+        self.FontFooterWidthLabel.setText(translate(u'AmendThemeDialog', u'Width:'))
+        self.FontFooterHeightLabel.setText(translate(u'AmendThemeDialog', u'Height:'))
+        self.FontFooterXSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.FontFooterYSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.FontFooterWidthSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.FontFooterHeightSpinBox.setSuffix(translate(u'AmendThemeDialog', u'px'))
+        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.FontFooterTab), translate(u'AmendThemeDialog', u'Font Footer'))
+        self.ShadowGroupBox.setTitle(translate(u'AmendThemeDialog', u'Shadow && Outline'))
+        self.OutlineColorLabel.setText(translate(u'AmendThemeDialog', u'Outline Color:'))
+        self.OutlineEnabledLabel.setText(translate(u'AmendThemeDialog', u'Show Outline:'))
+        self.ShadowColorLabel.setText(translate(u'AmendThemeDialog', u'Shadow Color:'))
+        self.ShadowEnabledLabel.setText(translate(u'AmendThemeDialog', u'Show Shadow:'))
+        self.AlignmentGroupBox.setTitle(translate(u'AmendThemeDialog', u'Alignment'))
+        self.HorizontalLabel.setText(translate(u'AmendThemeDialog', u'Horizontal Align:'))
+        self.HorizontalComboBox.setItemText(0, translate(u'AmendThemeDialog', u'Left'))
+        self.HorizontalComboBox.setItemText(1, translate(u'AmendThemeDialog', u'Right'))
+        self.HorizontalComboBox.setItemText(2, translate(u'AmendThemeDialog', u'Center'))
+        self.VerticalLabel.setText(translate(u'AmendThemeDialog', u'Vertical Align:'))
+        self.VerticalComboBox.setItemText(0, translate(u'AmendThemeDialog', u'Top'))
+        self.VerticalComboBox.setItemText(1, translate(u'AmendThemeDialog', u'Middle'))
+        self.VerticalComboBox.setItemText(2, translate(u'AmendThemeDialog', u'Bottom'))
+        self.ThemeTabWidget.setTabText(self.ThemeTabWidget.indexOf(self.OtherOptionsTab), translate(u'AmendThemeDialog', u'Other Options'))
+        self.PreviewGroupBox.setTitle(translate(u'AmendThemeDialog', u'Preview'))

=== modified file 'openlp/core/ui/amendthemeform.py'
--- openlp/core/ui/amendthemeform.py	2009-06-10 15:37:33 +0000
+++ openlp/core/ui/amendthemeform.py	2009-06-16 18:21:24 +0000
@@ -40,94 +40,94 @@
         #define signals
         #Buttons
         QtCore.QObject.connect(self.Color1PushButton ,
-            QtCore.SIGNAL("pressed()"), self.onColor1PushButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onColor1PushButtonClicked)
         QtCore.QObject.connect(self.Color2PushButton ,
-            QtCore.SIGNAL("pressed()"), self.onColor2PushButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onColor2PushButtonClicked)
         QtCore.QObject.connect(self.FontMainColorPushButton,
-            QtCore.SIGNAL("pressed()"), self.onFontMainColorPushButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onFontMainColorPushButtonClicked)
         QtCore.QObject.connect(self.FontFooterColorPushButton,
-            QtCore.SIGNAL("pressed()"), self.onFontFooterColorPushButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onFontFooterColorPushButtonClicked)
         QtCore.QObject.connect(self.OutlineColorPushButton,
-            QtCore.SIGNAL("pressed()"), self.onOutlineColorPushButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onOutlineColorPushButtonClicked)
         QtCore.QObject.connect(self.ShadowColorPushButton,
-            QtCore.SIGNAL("pressed()"), self.onShadowColorPushButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onShadowColorPushButtonClicked)
         QtCore.QObject.connect(self.ImageToolButton,
-            QtCore.SIGNAL("pressed()"), self.onImageToolButtonClicked)
+            QtCore.SIGNAL(u'pressed()'), self.onImageToolButtonClicked)
 
         #Combo boxes
         QtCore.QObject.connect(self.BackgroundComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onBackgroundComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onBackgroundComboBoxSelected)
         QtCore.QObject.connect(self.BackgroundTypeComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onBackgroundTypeComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onBackgroundTypeComboBoxSelected)
         QtCore.QObject.connect(self.GradientComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onGradientComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onGradientComboBoxSelected)
         QtCore.QObject.connect(self.FontMainComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onFontMainComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onFontMainComboBoxSelected)
         QtCore.QObject.connect(self.FontFooterComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onFontFooterComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onFontFooterComboBoxSelected)
         QtCore.QObject.connect(self.HorizontalComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onHorizontalComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onHorizontalComboBoxSelected)
         QtCore.QObject.connect(self.VerticalComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onVerticalComboBoxSelected)
+            QtCore.SIGNAL(u'activated(int)'), self.onVerticalComboBoxSelected)
 
         QtCore.QObject.connect(self.FontMainSizeSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontMainSizeSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainSizeSpinBoxChanged)
         QtCore.QObject.connect(self.FontFooterSizeSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontFooterSizeSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterSizeSpinBoxChanged)
         QtCore.QObject.connect(self.FontMainDefaultCheckBox,
-            QtCore.SIGNAL("stateChanged(int)"), self.onFontMainDefaultCheckBoxChanged)
+            QtCore.SIGNAL(u'stateChanged(int)'), self.onFontMainDefaultCheckBoxChanged)
         QtCore.QObject.connect(self.FontMainXSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontMainXSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainXSpinBoxChanged)
         QtCore.QObject.connect(self.FontMainYSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontMainYSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainYSpinBoxChanged)
         QtCore.QObject.connect(self.FontMainWidthSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontMainWidthSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainWidthSpinBoxChanged)
         QtCore.QObject.connect(self.FontMainHeightSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontMainHeightSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainHeightSpinBoxChanged)
         QtCore.QObject.connect(self.FontFooterDefaultCheckBox,
-            QtCore.SIGNAL("stateChanged(int)"), self.onFontFooterDefaultCheckBoxChanged)
+            QtCore.SIGNAL(u'stateChanged(int)'), self.onFontFooterDefaultCheckBoxChanged)
         QtCore.QObject.connect(self.FontFooterXSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontFooterXSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterXSpinBoxChanged)
         QtCore.QObject.connect(self.FontFooterYSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontFooterYSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterYSpinBoxChanged)
         QtCore.QObject.connect(self.FontFooterWidthSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontFooterWidthSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterWidthSpinBoxChanged)
         QtCore.QObject.connect(self.FontFooterHeightSpinBox,
-            QtCore.SIGNAL("valueChanged(int)"), self.onFontFooterHeightSpinBoxChanged)
+            QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterHeightSpinBoxChanged)
         QtCore.QObject.connect(self.OutlineCheckBox,
-            QtCore.SIGNAL("stateChanged(int)"), self.onOutlineCheckBoxChanged)
+            QtCore.SIGNAL(u'stateChanged(int)'), self.onOutlineCheckBoxChanged)
         QtCore.QObject.connect(self.ShadowCheckBox,
-            QtCore.SIGNAL("stateChanged(int)"), self.onShadowCheckBoxChanged)
+            QtCore.SIGNAL(u'stateChanged(int)'), self.onShadowCheckBoxChanged)
 
     def accept(self):
         new_theme = ThemeXML()
-        theme_name = str(self.ThemeNameEdit.displayText())
+        theme_name = unicode(self.ThemeNameEdit.displayText())
         new_theme.new_document(theme_name)
         save_from = None
         save_to = None
         if self.theme.background_type == u'solid':
-            new_theme.add_background_solid(str(self.theme.background_color))
+            new_theme.add_background_solid(unicode(self.theme.background_color))
         elif self.theme.background_type == u'gradient':
-            new_theme.add_background_gradient(str(self.theme.background_startColor),
-                    str(self.theme.background_endColor), self.theme.background_direction)
+            new_theme.add_background_gradient(unicode(self.theme.background_startColor),
+                    unicode(self.theme.background_endColor), self.theme.background_direction)
         else:
-            (path, filename) =os.path.split(str(self.theme.background_filename))
+            (path, filename) =os.path.split(unicode(self.theme.background_filename))
             new_theme.add_background_image(filename)
             save_to= os.path.join(self.path, theme_name, filename )
             save_from = self.theme.background_filename
 
-        new_theme.add_font(str(self.theme.font_main_name), str(self.theme.font_main_color),
-                str(self.theme.font_main_proportion), str(self.theme.font_main_override), u'main',
-                str(self.theme.font_main_x), str(self.theme.font_main_y), str(self.theme.font_main_width),
-                str(self.theme.font_main_height))
-        new_theme.add_font(str(self.theme.font_footer_name), str(self.theme.font_footer_color),
-                str(self.theme.font_footer_proportion), str(self.theme.font_footer_override), u'footer',
-                str(self.theme.font_footer_x), str(self.theme.font_footer_y), str(self.theme.font_footer_width),
-                str(self.theme.font_footer_height) )
-        new_theme.add_display(str(self.theme.display_shadow), str(self.theme.display_shadow_color),
-                str(self.theme.display_outline), str(self.theme.display_outline_color),
-                str(self.theme.display_horizontalAlign), str(self.theme.display_verticalAlign),
-                str(self.theme.display_wrapStyle))
+        new_theme.add_font(unicode(self.theme.font_main_name), unicode(self.theme.font_main_color),
+                unicode(self.theme.font_main_proportion), unicode(self.theme.font_main_override), u'main',
+                unicode(self.theme.font_main_x), unicode(self.theme.font_main_y), unicode(self.theme.font_main_width),
+                unicode(self.theme.font_main_height))
+        new_theme.add_font(unicode(self.theme.font_footer_name), unicode(self.theme.font_footer_color),
+                unicode(self.theme.font_footer_proportion), unicode(self.theme.font_footer_override), u'footer',
+                unicode(self.theme.font_footer_x), unicode(self.theme.font_footer_y), unicode(self.theme.font_footer_width),
+                unicode(self.theme.font_footer_height) )
+        new_theme.add_display(unicode(self.theme.display_shadow), unicode(self.theme.display_shadow_color),
+                unicode(self.theme.display_outline), unicode(self.theme.display_outline_color),
+                unicode(self.theme.display_horizontalAlign), unicode(self.theme.display_verticalAlign),
+                unicode(self.theme.display_wrapStyle))
 
         theme = new_theme.extract_xml()
 
@@ -166,7 +166,7 @@
             QtGui.QColor(self.theme.font_main_color), self).name()
 
         self.FontMainColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(self.theme.font_main_color))
+            u'background-color: %s' % unicode(self.theme.font_main_color))
         self.previewTheme(self.theme)
 
     def onFontMainSizeSpinBoxChanged(self, value):
@@ -219,7 +219,7 @@
             QtGui.QColor(self.theme.font_footer_color), self).name()
 
         self.FontFooterColorPushButton.setStyleSheet(
-            'background-color: %s' % str(self.theme.font_footer_color))
+            'background-color: %s' % unicode(self.theme.font_footer_color))
         self.previewTheme(self.theme)
 
     def onFontFooterSizeSpinBoxChanged(self, value):
@@ -307,12 +307,12 @@
             self.theme.background_color = QtGui.QColorDialog.getColor(
                 QtGui.QColor(self.theme.background_color), self).name()
             self.Color1PushButton.setStyleSheet(
-                u'background-color: %s' % str(self.theme.background_color))
+                u'background-color: %s' % unicode(self.theme.background_color))
         else:
             self.theme.background_startColor = QtGui.QColorDialog.getColor(
                 QtGui.QColor(self.theme.background_startColor), self).name()
             self.Color1PushButton.setStyleSheet(
-                u'background-color: %s' % str(self.theme.background_startColor))
+                u'background-color: %s' % unicode(self.theme.background_startColor))
 
         self.previewTheme(self.theme)
 
@@ -320,7 +320,7 @@
         self.theme.background_endColor = QtGui.QColorDialog.getColor(
             QtGui.QColor(self.theme.background_endColor), self).name()
         self.Color2PushButton.setStyleSheet(
-            u'background-color: %s' % str(self.theme.background_endColor))
+            u'background-color: %s' % unicode(self.theme.background_endColor))
 
         self.previewTheme(self.theme)
     #
@@ -338,7 +338,7 @@
         self.theme.display_outline_color = QtGui.QColorDialog.getColor(
             QtGui.QColor(self.theme.display_outline_color), self).name()
         self.OutlineColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(self.theme.display_outline_color))
+            u'background-color: %s' % unicode(self.theme.display_outline_color))
         self.previewTheme(self.theme)
 
     def onShadowCheckBoxChanged(self, value):
@@ -353,7 +353,7 @@
         self.theme.display_shadow_color = QtGui.QColorDialog.getColor(
             QtGui.QColor(self.theme.display_shadow_color), self).name()
         self.ShadowColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(self.theme.display_shadow_color))
+            u'background-color: %s' % unicode(self.theme.display_shadow_color))
         self.previewTheme(self.theme)
 
     def onHorizontalComboBoxSelected(self, currentIndex):
@@ -372,11 +372,11 @@
         log.debug(u'base theme created')
         newtheme = ThemeXML()
         newtheme.new_document(u'New Theme')
-        newtheme.add_background_solid(str(u'#000000'))
-        newtheme.add_font(str(QtGui.QFont().family()), str(u'#FFFFFF'), str(30), u'False')
-        newtheme.add_font(str(QtGui.QFont().family()), str(u'#FFFFFF'), str(12), u'False', u'footer')
-        newtheme.add_display(u'False', str(u'#FFFFFF'), u'False', str(u'#FFFFFF'),
-            str(0), str(0), str(0))
+        newtheme.add_background_solid(unicode(u'#000000'))
+        newtheme.add_font(unicode(QtGui.QFont().family()), unicode(u'#FFFFFF'), unicode(30), u'False')
+        newtheme.add_font(unicode(QtGui.QFont().family()), unicode(u'#FFFFFF'), unicode(12), u'False', u'footer')
+        newtheme.add_display(u'False', unicode(u'#FFFFFF'), u'False', unicode(u'#FFFFFF'),
+            unicode(0), unicode(0), unicode(0))
 
         return newtheme.extract_xml()
 
@@ -413,9 +413,9 @@
         self.FontFooterWidthSpinBox.setValue(int(self.theme.font_footer_width))
         self.FontFooterHeightSpinBox.setValue(int(self.theme.font_footer_height))
         self.FontMainColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(theme.font_main_color))
+            u'background-color: %s' % unicode(theme.font_main_color))
         self.FontFooterColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(theme.font_footer_color))
+            u'background-color: %s' % unicode(theme.font_footer_color))
 
         if self.theme.font_main_override == False:
             self.FontMainDefaultCheckBox.setChecked(True)
@@ -428,9 +428,9 @@
             self.FontFooterDefaultCheckBox.setChecked(False)
 
         self.OutlineColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(theme.display_outline_color))
+            u'background-color: %s' % unicode(theme.display_outline_color))
         self.ShadowColorPushButton.setStyleSheet(
-            u'background-color: %s' % str(theme.display_shadow_color))
+            u'background-color: %s' % unicode(theme.display_shadow_color))
 
         if self.theme.display_outline:
             self.OutlineCheckBox.setChecked(True)
@@ -452,7 +452,7 @@
     def stateChanging(self, theme):
         if theme.background_type == u'solid':
             self.Color1PushButton.setStyleSheet(
-                u'background-color: %s' % str(theme.background_color))
+                u'background-color: %s' % unicode(theme.background_color))
             self.Color1Label.setText(translate(u'ThemeManager', u'Background Color:'))
             self.Color1Label.setVisible(True)
             self.Color1PushButton.setVisible(True)
@@ -465,9 +465,9 @@
             self.GradientComboBox.setVisible(False)
         elif theme.background_type == u'gradient':
             self.Color1PushButton.setStyleSheet(
-                u'background-color: %s' % str(theme.background_startColor))
+                u'background-color: %s' % unicode(theme.background_startColor))
             self.Color2PushButton.setStyleSheet(
-                u'background-color: %s' % str(theme.background_endColor))
+                u'background-color: %s' % unicode(theme.background_endColor))
             self.Color1Label.setText(translate(u'ThemeManager', u'First  Color:'))
             self.Color2Label.setText(translate(u'ThemeManager', u'Second Color:'))
             self.Color1Label.setVisible(True)
@@ -526,4 +526,4 @@
     def previewTheme(self, theme):
         if self.allowPreview:
             frame = self.thememanager.generateImage(theme)
-            self.ThemePreview.setPixmap(QtGui.QPixmap.fromImage(frame))
+            self.ThemePreview.setPixmap(QtGui.QPixmap.fromImage(frame))
\ No newline at end of file

=== modified file 'openlp/core/ui/maindisplay.py'
--- openlp/core/ui/maindisplay.py	2009-06-10 15:37:33 +0000
+++ openlp/core/ui/maindisplay.py	2009-06-17 05:11:16 +0000
@@ -98,7 +98,7 @@
             self.alertactive = False
 
     def displayAlert(self):
-        alertframe = QtGui.QPixmap(self.frame)
+        alertframe = QtGui.QPixmap.fromImage(self.frame)
         painter = QtGui.QPainter(alertframe)
         top = alertframe.rect().height() * 0.9
         painter.fillRect(QtCore.QRect(0, top , alertframe.rect().width(), alertframe.rect().height() - top), QtGui.QColor(self.alertTab.bg_color))
@@ -114,4 +114,4 @@
         painter.end()
         self.display.setPixmap(alertframe)
         QtTest.QTest.qWait(self.alertTab.timeout*1000)
-        self.display.setPixmap(self.frame)
+        self.display.setPixmap(QtGui.QPixmap.fromImage(self.frame))

=== modified file 'openlp/core/ui/servicemanager.py'
--- openlp/core/ui/servicemanager.py	2009-06-13 06:46:13 +0000
+++ openlp/core/ui/servicemanager.py	2009-06-16 18:21:24 +0000
@@ -68,7 +68,7 @@
         self.ServiceManagerList.setDragDropMode(QtGui.QAbstractItemView.DragDrop)
         self.ServiceManagerList.setAlternatingRowColors(True)
         self.ServiceManagerList.setHeaderHidden(True)
-        self.ServiceManagerList.setObjectName("ServiceManagerList")
+        self.ServiceManagerList.setObjectName(u'ServiceManagerList')
         # enable drop
         self.ServiceManagerList.__class__.dragEnterEvent = self.dragEnterEvent
         self.ServiceManagerList.__class__.dragMoveEvent = self.dragEnterEvent
@@ -268,10 +268,10 @@
         self.ThemeComboBox.addItem(u'')
         for theme in theme_list:
             self.ThemeComboBox.addItem(theme)
-        id = self.ThemeComboBox.findText(str(self.service_theme), QtCore.Qt.MatchExactly)
+        id = self.ThemeComboBox.findText(unicode(self.service_theme), QtCore.Qt.MatchExactly)
         # Not Found
         if id == -1:
             id = 0
             self.service_theme = u''
         self.ThemeComboBox.setCurrentIndex(id)
-        self.parent.RenderManager.set_service_theme(self.service_theme)
+        self.parent.RenderManager.set_service_theme(self.service_theme)
\ No newline at end of file

=== modified file 'openlp/core/ui/settingsdialog.py'
--- openlp/core/ui/settingsdialog.py	2009-02-28 23:19:45 +0000
+++ openlp/core/ui/settingsdialog.py	2009-06-16 18:21:24 +0000
@@ -1,21 +1,29 @@
 # -*- coding: utf-8 -*-
-
-# Form implementation generated from reading ui file '/home/raoul/Projects/openlp-2/resources/forms/settings.ui'
-#
-# Created: Sat Feb 28 23:59:58 2009
-#      by: PyQt4 UI code generator 4.4.4
-#
-# WARNING! All changes made in this file will be lost!
-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008-2009 Martin Thompson, Tim Bentley,
+
+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
+"""
 from PyQt4 import QtCore, QtGui
+from openlp.core.lib import translate
 
 class Ui_SettingsDialog(object):
     def setupUi(self, SettingsDialog):
         SettingsDialog.setObjectName(u'SettingsDialog')
         SettingsDialog.resize(724, 502)
-        #icon = QtGui.QIcon()
-        #icon.addPixmap(QtGui.QPixmap(":/icon/openlp.org-icon-32.bmp"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
-        #SettingsDialog.setWindowIcon(icon)
         self.SettingsLayout = QtGui.QVBoxLayout(SettingsDialog)
         self.SettingsLayout.setSpacing(8)
         self.SettingsLayout.setMargin(8)
@@ -32,14 +40,13 @@
         self.ButtonsBox.setMaximumSize(QtCore.QSize(16777215, 16777215))
         self.ButtonsBox.setOrientation(QtCore.Qt.Horizontal)
         self.ButtonsBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
-        self.ButtonsBox.setObjectName("ButtonsBox")
+        self.ButtonsBox.setObjectName(u'ButtonsBox')
         self.SettingsLayout.addWidget(self.ButtonsBox)
-
         self.retranslateUi(SettingsDialog)
         self.SettingsTabWidget.setCurrentIndex(0)
-        QtCore.QObject.connect(self.ButtonsBox, QtCore.SIGNAL("accepted()"), SettingsDialog.accept)
-        QtCore.QObject.connect(self.ButtonsBox, QtCore.SIGNAL("rejected()"), SettingsDialog.reject)
+        QtCore.QObject.connect(self.ButtonsBox, QtCore.SIGNAL(u'accepted()'), SettingsDialog.accept)
+        QtCore.QObject.connect(self.ButtonsBox, QtCore.SIGNAL(u'rejected()'), SettingsDialog.reject)
         QtCore.QMetaObject.connectSlotsByName(SettingsDialog)
 
     def retranslateUi(self, SettingsDialog):
-        SettingsDialog.setWindowTitle(QtGui.QApplication.translate("SettingsDialog", "Settings", None, QtGui.QApplication.UnicodeUTF8))
+        SettingsDialog.setWindowTitle(translate(u'SettingsDialog', u'Settings'))

=== modified file 'openlp/core/ui/settingsform.py'
--- openlp/core/ui/settingsform.py	2009-05-18 19:04:25 +0000
+++ openlp/core/ui/settingsform.py	2009-06-16 18:21:24 +0000
@@ -27,7 +27,7 @@
 
 from settingsdialog import Ui_SettingsDialog
 
-log = logging.getLogger('SettingsForm')
+log = logging.getLogger(u'SettingsForm')
 
 class SettingsForm(QtGui.QDialog, Ui_SettingsDialog):
 
@@ -51,4 +51,4 @@
     def accept(self):
         for tab_index in range(0,  self.SettingsTabWidget.count()):
             self.SettingsTabWidget.widget(tab_index).save()
-        return QtGui.QDialog.accept(self)
+        return QtGui.QDialog.accept(self)
\ No newline at end of file

=== modified file 'openlp/core/ui/slidecontroller.py'
--- openlp/core/ui/slidecontroller.py	2009-06-10 16:20:57 +0000
+++ openlp/core/ui/slidecontroller.py	2009-06-16 18:21:24 +0000
@@ -91,7 +91,7 @@
         return self.items[row]
 
     def getItem(self, row):
-        log.info(u'Get Item:%d -> %s' %(row, str(self.items)))
+        log.info(u'Get Item:%d -> %s' %(row, unicode(self.items)))
         return self.items[row]
 
     def getList(self):
@@ -321,4 +321,4 @@
         if row.isValid():
             self.PreviewListView.selectionModel().setCurrentIndex(row,
                 QtGui.QItemSelectionModel.SelectCurrent)
-            self.onSlideSelected(row)
+            self.onSlideSelected(row)
\ No newline at end of file

=== modified file 'openlp/core/ui/splashscreen.py'
--- openlp/core/ui/splashscreen.py	2009-05-20 20:17:20 +0000
+++ openlp/core/ui/splashscreen.py	2009-06-16 18:21:24 +0000
@@ -17,20 +17,18 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
 from PyQt4 import QtCore, QtGui
-
 from openlp.core.lib import translate
 
 class SplashScreen(object):
     def __init__(self, version):
         self.splash_screen = QtGui.QSplashScreen()
         self.setupUi()
-        starting = translate('SplashScreen',u'Starting')
+        starting = translate(u'SplashScreen',u'Starting')
         self.message=starting+u'..... '+version
 
     def setupUi(self):
-        self.splash_screen.setObjectName("splash_screen")
+        self.splash_screen.setObjectName(u'splash_screen')
         self.splash_screen.setWindowModality(QtCore.Qt.NonModal)
         self.splash_screen.setEnabled(True)
         self.splash_screen.resize(370, 370)
@@ -41,8 +39,8 @@
         self.splash_screen.setSizePolicy(sizePolicy)
         self.splash_screen.setContextMenuPolicy(QtCore.Qt.PreventContextMenu)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
-        splash_image = QtGui.QPixmap(":/graphics/openlp-splash-screen.png")
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        splash_image = QtGui.QPixmap(u':/graphics/openlp-splash-screen.png')
         self.splash_screen.setWindowIcon(icon)
         self.splash_screen.setPixmap(splash_image)
         self.splash_screen.setMask(splash_image.mask())
@@ -51,7 +49,7 @@
         QtCore.QMetaObject.connectSlotsByName(self.splash_screen)
 
     def retranslateUi(self):
-        self.splash_screen.setWindowTitle(QtGui.QApplication.translate("splash_screen", "Splash Screen", None, QtGui.QApplication.UnicodeUTF8))
+        self.splash_screen.setWindowTitle(translate(u'splash_screen', u'Splash Screen'))
 
     def show(self):
         self.splash_screen.show()

=== modified file 'openlp/core/ui/test/test_service_manager.py'
--- openlp/core/ui/test/test_service_manager.py	2009-05-09 07:01:33 +0000
+++ openlp/core/ui/test/test_service_manager.py	2009-06-16 18:21:24 +0000
@@ -28,20 +28,20 @@
 from openlp.plugins.images.lib import ImageServiceItem
 
 import logging
-logging.basicConfig(filename="test_service_manager.log",level=logging.INFO, filemode="w")
+logging.basicConfig(filename="test_service_manager.log",level=logging.INFO, filemode="w')
 
 # # from http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66062
 # def whoami(depth=1):
 #     return sys._getframe(depth).f_code.co_name
 global app
 global log
-log=logging.getLogger("TestServiceManager")
+log=logging.getLogger(u'TestServiceManager')
 class TestServiceManager_base:
     def __init__(self):
         pass
 
     def setup_class(self):
-        log.info( "class setup"+str(self))
+        log.info( "class setup"+unicode(self))
         try:
             if app is None:
                 app = QtGui.QApplication([])
@@ -53,11 +53,11 @@
         pass
 
     def setup_method(self, method):
-        log.info("Setup method:"+str(method))
+        log.info(u'Setup method:"+unicode(method))
         self.expected_answer="Don't know yet"
         self.answer=None
         self.s=ServiceManager(None)
-        log.info("--------------- Setup Done -------------")
+        log.info(u'--------------- Setup Done -------------')
 
     def teardown_method(self, method):
         self.s=None
@@ -69,64 +69,64 @@
         # make a selection of it
         self.sm=QItemSelectionModel(self.s.service_data)
         self.sm.select(i, QItemSelectionModel.ClearAndSelect)
-        log.info(str(self.sm.selectedIndexes()))
+        log.info(unicode(self.sm.selectedIndexes()))
         self.s.TreeView.setSelectionModel(self.sm)
-        log.info("Selected indexes = " + str(self.s.TreeView.selectedIndexes()))
+        log.info(u'Selected indexes = " + unicode(self.s.TreeView.selectedIndexes()))
     def test_easy(self):
-        log.info("test_easy")
+        log.info(u'test_easy')
         item=ImageServiceItem(None)
-        item.add("test.gif")
+        item.add(u'test.gif')
         self.s.addServiceItem(item)
         answer = self.s.oos_as_text()
-        log.info("Answer = " + str(answer))
-        lines=answer.split("\n")
-        log.info("lines = " + str(lines))
-        assert lines[0].startswith("# <openlp.plugins.images.imageserviceitem.ImageServiceItem object")
+        log.info(u'Answer = " + unicode(answer))
+        lines=answer.split(u'\n')
+        log.info(u'lines = " + unicode(lines))
+        assert lines[0].startswith(u'# <openlp.plugins.images.imageserviceitem.ImageServiceItem object')
         assert lines[1] == "test.gif"
-        log.info("done")
+        log.info(u'done')
 
     def test_2items_as_separate_items(self):
         # If nothing is selected when item is added, a new base service item is added
-        log.info("test_2items_as_separate_items")
+        log.info(u'test_2items_as_separate_items')
         item=ImageServiceItem(None)
-        item.add("test.gif")
+        item.add(u'test.gif')
         self.s.addServiceItem(item)
         item=ImageServiceItem(None)
-        item.add("test2.gif")
-        item.add("test3.gif")
+        item.add(u'test2.gif')
+        item.add(u'test3.gif')
         self.s.addServiceItem(item)
         answer = self.s.oos_as_text()
-        log.info("Answer = " + str(answer))
-        lines=answer.split("\n")
-        log.info("lines = " + str(lines))
-        assert lines[0].startswith("# <openlp.plugins.images.imageserviceitem.ImageServiceItem object")
+        log.info(u'Answer = " + unicode(answer))
+        lines=answer.split(u'\n')
+        log.info(u'lines = " + unicode(lines))
+        assert lines[0].startswith(u'# <openlp.plugins.images.imageserviceitem.ImageServiceItem object')
         assert lines[1] == "test.gif"
-        assert lines[2].startswith("# <openlp.plugins.images.imageserviceitem.ImageServiceItem object")
+        assert lines[2].startswith(u'# <openlp.plugins.images.imageserviceitem.ImageServiceItem object')
         assert lines[3] == "test2.gif"
         assert lines[4] == "test3.gif"
-        log.info("done")
+        log.info(u'done')
 
     def test_2items_merged(self):
         # If the first object is selected when item is added it should be extended
-        log.info("test_2items_merged")
+        log.info(u'test_2items_merged')
         item=ImageServiceItem(None)
-        item.add("test.gif")
+        item.add(u'test.gif')
         self.s.addServiceItem(item)
         self.select_row(0)
-        log.info("Selected indexes = " + str(self.s.TreeView.selectedIndexes()))
+        log.info(u'Selected indexes = " + unicode(self.s.TreeView.selectedIndexes()))
         item=ImageServiceItem(None)
-        item.add("test2.gif")
-        item.add("test3.gif")
+        item.add(u'test2.gif')
+        item.add(u'test3.gif')
         self.s.addServiceItem(item)
         answer = self.s.oos_as_text()
-        log.info("Answer = " + str(answer))
-        lines=answer.split("\n")
-        log.info("lines = " + str(lines))
-        assert lines[0].startswith("# <openlp.plugins.images.imageserviceitem.ImageServiceItem object")
+        log.info(u'Answer = " + unicode(answer))
+        lines=answer.split(u'\n')
+        log.info(u'lines = " + unicode(lines))
+        assert lines[0].startswith(u'# <openlp.plugins.images.imageserviceitem.ImageServiceItem object')
         assert lines[1] == "test.gif"
         assert lines[2] == "test2.gif"
         assert lines[3] == "test3.gif"
-        log.info("done")
+        log.info(u'done')
 
     # more tests to do:
     #  add different types of service item
@@ -143,4 +143,4 @@
     t.test_easy()
     t.teardown_method(None)
     print "Pass"
-    log.info("Pass")
+    log.info(u'Pass')
\ No newline at end of file

=== modified file 'openlp/core/ui/thememanager.py'
--- openlp/core/ui/thememanager.py	2009-06-10 15:37:33 +0000
+++ openlp/core/ui/thememanager.py	2009-06-16 18:21:24 +0000
@@ -58,12 +58,12 @@
     def insertRow(self, row, filename):
         self.beginInsertRows(QtCore.QModelIndex(), row, row)
         log.info(u'insert row %d:%s' % (row, filename))
-        (prefix, shortfilename) = os.path.split(str(filename))
+        (prefix, shortfilename) = os.path.split(unicode(filename))
         log.info(u'shortfilename = %s' % shortfilename)
         theme = shortfilename.split(u'.')
         # create a preview image
         if os.path.exists(filename):
-            preview = QtGui.QImage(str(filename))
+            preview = QtGui.QImage(unicode(filename))
             width = self.maximagewidth
             height = self.rowheight
             preview = preview.scaled(width, height, QtCore.Qt.KeepAspectRatio, QtCore.Qt.SmoothTransformation)
@@ -117,7 +117,7 @@
         return self.items[row]
 
     def getItem(self, row):
-        log.info(u'Get Item:%d -> %s' % (row, str(self.items)))
+        log.info(u'Get Item:%d -> %s' % (row, unicode(self.items)))
         return self.items[row]
 
     def getList(self):
@@ -202,7 +202,7 @@
         files = QtGui.QFileDialog.getOpenFileNames(None,
             translate(u'ThemeManager', u'Select Import File'),
             self.path, u'Theme (*.theme)')
-        log.info(u'New Themes %s', str(files))
+        log.info(u'New Themes %s', unicode(files))
         if len(files) > 0:
             for file in files:
                 self.unzipTheme(file, self.path)
@@ -224,17 +224,17 @@
 
     def getThemeData(self, themename):
         log.debug(u'getthemedata for theme %s', themename)
-        xml_file = os.path.join(self.path, str(themename), str(themename) + u'.xml')
+        xml_file = os.path.join(self.path, unicode(themename), unicode(themename) + u'.xml')
         try:
             xml = file_to_xml(xml_file)
         except:
             newtheme = ThemeXML()
             newtheme.new_document(u'New Theme')
-            newtheme.add_background_solid(str(u'#000000'))
-            newtheme.add_font(str(QtGui.QFont().family()), str(u'#FFFFFF'), str(30), u'False')
-            newtheme.add_font(str(QtGui.QFont().family()), str(u'#FFFFFF'), str(12), u'False', u'footer')
-            newtheme.add_display(u'False', str(u'#FFFFFF'), u'False', str(u'#FFFFFF'),
-                str(0), str(0), str(0))
+            newtheme.add_background_solid(unicode(u'#000000'))
+            newtheme.add_font(unicode(QtGui.QFont().family()), unicode(u'#FFFFFF'), unicode(30), u'False')
+            newtheme.add_font(unicode(QtGui.QFont().family()), unicode(u'#FFFFFF'), unicode(12), u'False', u'footer')
+            newtheme.add_display(u'False', unicode(u'#FFFFFF'), u'False', unicode(u'#FFFFFF'),
+                unicode(0), unicode(0), unicode(0))
             xml = newtheme.extract_xml()
         theme = ThemeXML()
         theme.parse(xml)
@@ -253,7 +253,7 @@
         necessary.
         """
         log.debug(u'Unzipping theme %s', filename)
-        zip = zipfile.ZipFile(str(filename))
+        zip = zipfile.ZipFile(unicode(filename))
         filexml = None
         themename = None
         for file in zip.namelist():
@@ -299,31 +299,31 @@
         newtheme = ThemeXML()
         newtheme.new_document(theme.Name)
         if theme.BackgroundType == 0:
-            newtheme.add_background_solid(str(theme.BackgroundParameter1.name()))
+            newtheme.add_background_solid(unicode(theme.BackgroundParameter1.name()))
         elif theme.BackgroundType == 1:
             direction = u'vertical'
             if theme.BackgroundParameter3.name() == 1:
                 direction = u'horizontal'
             newtheme.add_background_gradient(
-                str(theme.BackgroundParameter1.name()),
-                str(theme.BackgroundParameter2.name()), direction)
+                unicode(theme.BackgroundParameter1.name()),
+                unicode(theme.BackgroundParameter2.name()), direction)
         else:
-            newtheme.add_background_image(str(theme.BackgroundParameter1))
+            newtheme.add_background_image(unicode(theme.BackgroundParameter1))
 
-        newtheme.add_font(str(theme.FontName), str(theme.FontColor.name()),
-            str(theme.FontProportion * 2), u'False')
-        newtheme.add_font(str(theme.FontName), str(theme.FontColor.name()),
-            str(12), u'False', u'footer')
+        newtheme.add_font(unicode(theme.FontName), unicode(theme.FontColor.name()),
+            unicode(theme.FontProportion * 2), u'False')
+        newtheme.add_font(unicode(theme.FontName), unicode(theme.FontColor.name()),
+            unicode(12), u'False', u'footer')
         outline = False
         shadow = False
         if theme.Shadow == 1:
             shadow = True
         if theme.Outline == 1:
             outline = True
-        newtheme.add_display(str(shadow), str(theme.ShadowColor.name()),
-            str(outline), str(theme.OutlineColor.name()),
-            str(theme.HorizontalAlign), str(theme.VerticalAlign),
-            str(theme.WrapStyle))
+        newtheme.add_display(unicode(shadow), unicode(theme.ShadowColor.name()),
+            unicode(outline), unicode(theme.OutlineColor.name()),
+            unicode(theme.HorizontalAlign), unicode(theme.VerticalAlign),
+            unicode(theme.WrapStyle))
         return newtheme.extract_xml()
 
     def saveTheme(self, name, theme_xml, image_from, image_to) :
@@ -362,4 +362,4 @@
     def getPreviewImage(self, theme):
         log.debug(u'getPreviewImage %s ', theme)
         image = os.path.join(self.path, theme + u'.png')
-        return image
+        return image
\ No newline at end of file

=== modified file 'openlp/core/ui/themestab.py'
--- openlp/core/ui/themestab.py	2009-06-05 18:53:50 +0000
+++ openlp/core/ui/themestab.py	2009-06-16 18:21:24 +0000
@@ -97,7 +97,7 @@
             QtCore.SIGNAL(u'pressed()'), self.onGlobalLevelButtonPressed)
 
         QtCore.QObject.connect(self.DefaultComboBox,
-            QtCore.SIGNAL("activated(int)"), self.onDefaultComboBoxChanged)
+            QtCore.SIGNAL(u'activated(int)'), self.onDefaultComboBoxChanged)
 
         #self.DefaultListView.setScaledContents(True)
 
@@ -140,8 +140,8 @@
     def onDefaultComboBoxChanged(self, value):
         self.global_theme = self.DefaultComboBox.currentText()
         self.parent.RenderManager.set_global_theme(self.global_theme, self.global_style)
-        image = self.parent.ThemeManagerContents.getPreviewImage(str(self.global_theme))
-        preview = QtGui.QPixmap(str(image))
+        image = self.parent.ThemeManagerContents.getPreviewImage(unicode(self.global_theme))
+        preview = QtGui.QPixmap(unicode(image))
         display = preview.scaled(300, 255, QtCore.Qt.KeepAspectRatio, QtCore.Qt.SmoothTransformation)
         self.DefaultListView.setPixmap(display)
 
@@ -152,14 +152,14 @@
         self.DefaultComboBox.clear()
         for theme in theme_list:
             self.DefaultComboBox.addItem(theme)
-        id = self.DefaultComboBox.findText(str(self.global_theme), QtCore.Qt.MatchExactly)
+        id = self.DefaultComboBox.findText(unicode(self.global_theme), QtCore.Qt.MatchExactly)
         if id == -1:
             id = 0 # Not Found
             self.global_theme = u''
         self.DefaultComboBox.setCurrentIndex(id)
         self.parent.RenderManager.set_global_theme(self.global_theme, self.global_style)
         if self.global_theme is not u'':
-            image = self.parent.ThemeManagerContents.getPreviewImage(str(self.global_theme))
-            preview = QtGui.QPixmap(str(image))
+            image = self.parent.ThemeManagerContents.getPreviewImage(unicode(self.global_theme))
+            preview = QtGui.QPixmap(unicode(image))
             display = preview.scaled(300, 255, QtCore.Qt.KeepAspectRatio, QtCore.Qt.SmoothTransformation)
-            self.DefaultListView.setPixmap(display)
+            self.DefaultListView.setPixmap(display)
\ No newline at end of file

=== modified file 'openlp/core/utils/confighelper.py'
--- openlp/core/utils/confighelper.py	2009-06-04 16:53:49 +0000
+++ openlp/core/utils/confighelper.py	2009-06-16 18:21:24 +0000
@@ -42,7 +42,7 @@
             except ImportError:
                 path = os.path.join(os.getenv(u'HOME'), u'.openlp', u'data')
         reg = ConfigHelper.get_registry()
-        #path = ConfigHelper.get_config('main', 'data path', path)
+        #path = ConfigHelper.get_config(u'main', 'data path', path)
         if not os.path.exists(path):
             os.makedirs(path)
         return path
@@ -89,4 +89,4 @@
                 except ImportError:
                     config_path = os.path.join(os.getenv(u'HOME'), u'.openlp')
             ConfigHelper.__registry__ = Registry(config_path)
-        return ConfigHelper.__registry__
+        return ConfigHelper.__registry__
\ No newline at end of file

=== modified file 'openlp/core/utils/registry.py'
--- openlp/core/utils/registry.py	2009-06-05 18:53:50 +0000
+++ openlp/core/utils/registry.py	2009-06-16 18:21:24 +0000
@@ -54,7 +54,7 @@
         Set a single value in the registry.
         """
         try :
-            self.config.set(section, key, str(value))
+            self.config.set(section, key, unicode(value))
             return self._save()
         except:
             return False
@@ -115,4 +115,4 @@
             file_handle.close()
             return self._load()
         except:
-            return False
+            return False
\ No newline at end of file

=== modified file 'openlp/migration/display.py'
--- openlp/migration/display.py	2009-01-01 11:18:16 +0000
+++ openlp/migration/display.py	2009-06-16 18:21:24 +0000
@@ -20,8 +20,8 @@
 
 class Display():
     global log
-    log=logging.getLogger("Display Logger")
-    log.info("Display Class loaded")
+    log=logging.getLogger(u'Display Logger')
+    log.info(u'Display Class loaded')
     
     @staticmethod
     def output(string):
@@ -31,5 +31,5 @@
     @staticmethod
     def sub_output(string):
         if not string == None:
-            log.debug("   "+string);
-            print ("   "+string)        
+            log.debug(u'   "+string);
+            print (u'   "+string)        
\ No newline at end of file

=== modified file 'openlp/migration/migratebibles.py'
--- openlp/migration/migratebibles.py	2009-01-01 11:18:16 +0000
+++ openlp/migration/migratebibles.py	2009-06-16 18:21:24 +0000
@@ -23,5 +23,5 @@
         self.display = display
 
     def process(self):
-        self.display.output("Bible process started");
-        self.display.output("Bible process finished");   
+        self.display.output(u'Bible process started');
+        self.display.output(u'Bible process finished');   
\ No newline at end of file

=== modified file 'openlp/migration/migratefiles.py'
--- openlp/migration/migratefiles.py	2009-01-01 11:18:16 +0000
+++ openlp/migration/migratefiles.py	2009-06-16 18:21:24 +0000
@@ -22,20 +22,20 @@
         self.display = display
 
     def process(self):
-        self.display.output("Files process started");
+        self.display.output(u'Files process started');
         self._initial_setup()
-        self.display.output("Files process finished");        
+        self.display.output(u'Files process finished');        
         
     def _initial_setup(self):
-        self.display.output("Initial Setup started");
+        self.display.output(u'Initial Setup started');
         ConfigHelper.get_data_path()
-        self.display.sub_output("Config created");        
-        ConfigHelper.get_config("bible", "data path")
-        self.display.sub_output("Config created");        
-        ConfigHelper.get_config("videos", "data path") 
-        self.display.sub_output("videos created");                
-        ConfigHelper.get_config("images", "data path") 
-        self.display.sub_output("images created");                
-        ConfigHelper.get_config("presentations", "data path") 
-        self.display.sub_output("presentations created");                
-        self.display.output("Initial Setup finished");        
+        self.display.sub_output(u'Config created');        
+        ConfigHelper.get_config(u'bible", u'data path')
+        self.display.sub_output(u'Config created');        
+        ConfigHelper.get_config(u'videos", u'data path') 
+        self.display.sub_output(u'videos created');                
+        ConfigHelper.get_config(u'images", u'data path') 
+        self.display.sub_output(u'images created');                
+        ConfigHelper.get_config(u'presentations", u'data path') 
+        self.display.sub_output(u'presentations created');                
+        self.display.output(u'Initial Setup finished');        
\ No newline at end of file

=== modified file 'openlp/migration/migratesongs.py'
--- openlp/migration/migratesongs.py	2009-05-02 21:40:10 +0000
+++ openlp/migration/migratesongs.py	2009-06-16 18:21:24 +0000
@@ -42,9 +42,9 @@
 class MigrateSongs():
     def __init__(self, display):
         self.display = display
-        self.config = PluginConfig('Songs')
+        self.config = PluginConfig(u'Songs')
         self.data_path = self.config.get_data_path()
-        self.database_files = self.config.get_files('sqlite')
+        self.database_files = self.config.get_files(u'sqlite')
         print self.database_files
 
     def process(self):
@@ -66,49 +66,49 @@
     def _v1_9_0_authors(self, database):
         self.display.sub_output(u'Authors Started for ' + database)
         conn = sqlite3.connect(self.data_path + os.sep + database)
-        conn.execute("""alter table authors rename to authors_temp;""")
+        conn.execute(u'""alter table authors rename to authors_temp;""')
         conn.commit()
         self.display.sub_output(u'old author renamed to author_temp')
-        conn.execute("""create table authors (
+        conn.execute(u'""create table authors (
             id integer primary key ASC AUTOINCREMENT,
             first_name varchar(128),
             last_name varchar(128),
             display_name varchar(255)
-            );""")
+            );""')
         conn.commit()
         self.display.sub_output(u'authors table created')
-        conn.execute("""create index if not exists author1 on authors 
-            (display_name ASC,id ASC);""")
+        conn.execute(u'""create index if not exists author1 on authors 
+            (display_name ASC,id ASC);""')
         conn.commit()
         self.display.sub_output(u'index author1 created')
-        conn.execute("""create index if not exists author2 on authors 
-            (last_name ASC,id ASC);""")
+        conn.execute(u'""create index if not exists author2 on authors 
+            (last_name ASC,id ASC);""')
         conn.commit()
         self.display.sub_output(u'index author2 created')
-        conn.execute("""create index if not exists author3 on authors 
-            (first_name ASC,id ASC);""")
+        conn.execute(u'""create index if not exists author3 on authors 
+            (first_name ASC,id ASC);""')
         conn.commit()
         self.display.sub_output(u'index author3 created')
         self.display.sub_output(u'Author Data Migration started')
-        conn.execute("""insert into authors (id, display_name) 
-            select authorid, authorname from authors_temp;""")
+        conn.execute(u'""insert into authors (id, display_name) 
+            select authorid, authorname from authors_temp;""')
         conn.commit()
         self.display.sub_output(u'authors populated')
         c = conn.cursor()        
-        text = c.execute("""select * from authors""") .fetchall()
+        text = c.execute(u'""select * from authors""') .fetchall()
         for author in text:
             dispname = author[3]
-            dispname = dispname.replace("'", "") 
-            pos = dispname.rfind(" ")
+            dispname = dispname.replace(u''", u'') 
+            pos = dispname.rfind(u' ')
             authorfirstname = dispname[:pos]
             authorlastname = dispname[pos + 1:len(dispname)]
             s = "update authors set first_name = '" \
                 + authorfirstname + "', last_name = '" + authorlastname \
-                + "' where id = " + str(author[0])
+                + "' where id = " + unicode(author[0])
             c.execute(s)
         conn.commit()
         self.display.sub_output(u'Author Data Migration Completed')
-        conn.execute("""drop table authors_temp;""")
+        conn.execute(u'""drop table authors_temp;""')
         conn.commit()
         conn.close()
         self.display.sub_output(u'author_temp dropped')
@@ -117,17 +117,17 @@
     def _v1_9_0_songbook(self, database):
         self.display.sub_output(u'SongBook Started for ' + database)
         conn = sqlite3.connect(self.data_path + os.sep + database)
-        conn.execute("""create table if not exists song_books (
+        conn.execute(u'""create table if not exists song_books (
             id integer Primary Key ASC AUTOINCREMENT,
             name varchar(128),
             publisher varchar(128)
-            );""")
+            );""')
         conn.commit()
         self.display.sub_output(u'songbook table created')
-        conn.execute("""create index if not exists songbook1 on song_books (name ASC,id ASC);""")
+        conn.execute(u'""create index if not exists songbook1 on song_books (name ASC,id ASC);""')
         conn.commit()
         self.display.sub_output(u'index songbook1 created')
-        conn.execute("""create index if not exists songbook2 on song_books (publisher ASC,id ASC);""")
+        conn.execute(u'""create index if not exists songbook2 on song_books (publisher ASC,id ASC);""')
         conn.commit()
         conn.close()
         self.display.sub_output(u'index songbook2 created')
@@ -136,9 +136,9 @@
     def _v1_9_0_songs(self, database):
         self.display.sub_output(u'Songs Started for ' + database)
         conn = sqlite3.connect(self.data_path + os.sep + database)
-        conn.execute("""alter table songs rename to songs_temp;""")
+        conn.execute(u'""alter table songs rename to songs_temp;""')
         conn.commit()
-        conn.execute("""create table if not exists songs  (
+        conn.execute(u'""create table if not exists songs  (
             id integer Primary Key ASC AUTOINCREMENT,
             song_book_id integer,
             title varchar(255),
@@ -151,31 +151,31 @@
             theme_name varchar(128),
             search_title varchar(255),
             search_lyrics text
-            );""")
+            );""')
         conn.commit()
         self.display.sub_output(u'songs table created')
-        conn.execute("""create index if not exists songs1 on songs 
-            (search_lyrics ASC,id ASC);""")
+        conn.execute(u'""create index if not exists songs1 on songs 
+            (search_lyrics ASC,id ASC);""')
         conn.commit()
         self.display.sub_output(u'index songs1 created')
-        conn.execute("""create index if not exists songs2 on songs 
-            (search_title ASC,id ASC);""")
+        conn.execute(u'""create index if not exists songs2 on songs 
+            (search_title ASC,id ASC);""')
         conn.commit()
         self.display.sub_output(u'index songs2 created')
-        conn.execute("""insert into songs (id, title, lyrics, copyright,
+        conn.execute(u'""insert into songs (id, title, lyrics, copyright,
             search_title, search_lyrics, song_book_id) 
             select songid,  songtitle, lyrics, copyrightinfo, 
             replace(replace(replace(replace(replace(replace(replace(replace(
             replace(songtitle,  '&', 'and'), ',', ''), ';', ''), ':', ''), 
-            '(', ''), ')', ''), '{', ''), '}',''),'?',''), 
+            '(u', ''), ')', ''), '{', ''), '}',''),'?',''), 
             replace(replace(replace(replace(replace(replace(replace(replace(
             replace(lyrics,  '&', 'and'), ',', ''), ';', ''), ':', ''),
-            '(', ''), ')', ''), '{', ''), '}',''),'?',''),
+            '(u', ''), ')', ''), '{', ''), '}',''),'?',''),
             0
-            from songs_temp;""")
+            from songs_temp;""')
         conn.commit()
         self.display.sub_output(u'songs populated')
-        conn.execute("""drop table songs_temp;""")
+        conn.execute(u'""drop table songs_temp;""')
         conn.commit()
         conn.close()
         self.display.sub_output(u'songs_temp dropped')
@@ -185,12 +185,12 @@
         self.display.sub_output(u'Topics Started for ' + database)
         conn = sqlite3.connect(self.data_path+os.sep+database)
         conn.text_factory = str
-        conn.execute("""create table if not exists topics 
+        conn.execute(u'""create table if not exists topics 
             (id integer Primary Key ASC AUTOINCREMENT,
-            name varchar(128));""")
+            name varchar(128));""')
         conn.commit()
         self.display.sub_output(u'Topic table created')
-        conn.execute("""create index if not exists topic1 on topics (name ASC,id ASC);""")
+        conn.execute(u'""create index if not exists topic1 on topics (name ASC,id ASC);""')
         conn.commit()
         conn.close()
         self.display.sub_output(u'index topic1 created')
@@ -200,16 +200,16 @@
     def _v1_9_0_songauthors(self, database):
         self.display.sub_output(u'SongAuthors Started for ' + database);
         conn = sqlite3.connect(self.data_path + os.sep + database)
-        conn.execute("""create table if not exists authors_songs 
+        conn.execute(u'""create table if not exists authors_songs 
             (author_id integer,
-            song_id integer);""")
+            song_id integer);""')
         conn.commit()
         self.display.sub_output(u'authors_songs table created')
-        conn.execute("""insert into authors_songs (author_id, song_id) 
-            select authorid, songid from songauthors;""")
+        conn.execute(u'""insert into authors_songs (author_id, song_id) 
+            select authorid, songid from songauthors;""')
         conn.commit()
         self.display.sub_output(u'authors_songs populated')
-        conn.execute("""drop table songauthors;""")
+        conn.execute(u'""drop table songauthors;""')
         conn.commit()
         self.display.sub_output(u'songauthors dropped')
         conn.close()
@@ -218,15 +218,15 @@
     def _v1_9_0_songtopics(self, database):
         self.display.sub_output(u'Songtopics Started for ' + database);
         conn = sqlite3.connect(self.data_path+os.sep+database)
-        conn.execute("""create table if not exists song_topics 
+        conn.execute(u'""create table if not exists song_topics 
             (song_id integer,
-            topic_id integer);""")
+            topic_id integer);""')
         conn.commit()
         self.display.sub_output(u'songtopics table created')
-        conn.execute("""create index if not exists songtopic1 on song_topics (topic_id ASC,song_id ASC);""")
+        conn.execute(u'""create index if not exists songtopic1 on song_topics (topic_id ASC,song_id ASC);""')
         conn.commit()
         self.display.sub_output(u'index songtopic1 created')
-        conn.execute("""create index if not exists songtopic2 on song_topics (song_id ASC,topic_id ASC);""")
+        conn.execute(u'""create index if not exists songtopic2 on song_topics (song_id ASC,topic_id ASC);""')
         conn.commit()
         conn.close()
         self.display.sub_output(u'index songtopic2 created')
@@ -237,4 +237,4 @@
         out = fileout.readlines()
         if len(out) > 0:
             for o in range (0, len(out)):
-                self.display.sub_output(out[o])
+                self.display.sub_output(out[o])
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/bibleplugin.py'
--- openlp/plugins/bibles/bibleplugin.py	2009-05-21 05:15:51 +0000
+++ openlp/plugins/bibles/bibleplugin.py	2009-06-16 18:21:24 +0000
@@ -39,7 +39,7 @@
         self.weight = -9
         # Create the plugin icon
         self.icon = QtGui.QIcon()
-        self.icon.addPixmap(QtGui.QPixmap(':/media/media_verse.png'),
+        self.icon.addPixmap(QtGui.QPixmap(u':/media/media_verse.png'),
             QtGui.QIcon.Normal, QtGui.QIcon.Off)
         #Register the bible Manager
         self.biblemanager = BibleManager(self.config)
@@ -55,17 +55,17 @@
 
     def add_import_menu_item(self, import_menu):
         self.ImportBibleItem = QtGui.QAction(import_menu)
-        self.ImportBibleItem.setObjectName("ImportBibleItem")
+        self.ImportBibleItem.setObjectName(u'ImportBibleItem')
         import_menu.addAction(self.ImportBibleItem)
-        self.ImportBibleItem.setText(translate("BiblePlugin", "&Bible"))
+        self.ImportBibleItem.setText(translate(u'BiblePlugin', u'&Bible'))
         # Signals and slots
-        QtCore.QObject.connect(self.ImportBibleItem, QtCore.SIGNAL("triggered()"),  self.onBibleNewClick)
+        QtCore.QObject.connect(self.ImportBibleItem, QtCore.SIGNAL(u'triggered()'),  self.onBibleNewClick)
 
     def add_export_menu_item(self, export_menu):
         self.ExportBibleItem = QtGui.QAction(export_menu)
-        self.ExportBibleItem.setObjectName("ExportBibleItem")
+        self.ExportBibleItem.setObjectName(u'ExportBibleItem')
         export_menu.addAction(self.ExportBibleItem)
-        self.ExportBibleItem.setText(translate("BiblePlugin", u'&Bible'))
+        self.ExportBibleItem.setText(translate(u'BiblePlugin', u'&Bible'))
 
     def initialise(self):
         pass

=== modified file 'openlp/plugins/bibles/forms/bibleimportdialog.py'
--- openlp/plugins/bibles/forms/bibleimportdialog.py	2009-06-01 17:50:37 +0000
+++ openlp/plugins/bibles/forms/bibleimportdialog.py	2009-06-16 18:21:24 +0000
@@ -11,178 +11,178 @@
 
 class Ui_BibleImportDialog(object):
     def setupUi(self, BibleImportDialog):
-        BibleImportDialog.setObjectName("BibleImportDialog")
+        BibleImportDialog.setObjectName(u'BibleImportDialog')
         BibleImportDialog.resize(494, 725)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         BibleImportDialog.setWindowIcon(icon)
         self.ImportToolBox = QtGui.QToolBox(BibleImportDialog)
         self.ImportToolBox.setGeometry(QtCore.QRect(20, 20, 451, 401))
         self.ImportToolBox.setFrameShape(QtGui.QFrame.StyledPanel)
-        self.ImportToolBox.setObjectName("ImportToolBox")
+        self.ImportToolBox.setObjectName(u'ImportToolBox')
         self.FileImportPage = QtGui.QWidget()
         self.FileImportPage.setGeometry(QtCore.QRect(0, 0, 447, 337))
-        self.FileImportPage.setObjectName("FileImportPage")
+        self.FileImportPage.setObjectName(u'FileImportPage')
         self.OSISGroupBox = QtGui.QGroupBox(self.FileImportPage)
         self.OSISGroupBox.setGeometry(QtCore.QRect(18, 65, 411, 81))
-        self.OSISGroupBox.setObjectName("OSISGroupBox")
+        self.OSISGroupBox.setObjectName(u'OSISGroupBox')
         self.gridLayout_2 = QtGui.QGridLayout(self.OSISGroupBox)
         self.gridLayout_2.setMargin(8)
         self.gridLayout_2.setSpacing(8)
-        self.gridLayout_2.setObjectName("gridLayout_2")
+        self.gridLayout_2.setObjectName(u'gridLayout_2')
         self.LocatioLabel = QtGui.QLabel(self.OSISGroupBox)
-        self.LocatioLabel.setObjectName("LocatioLabel")
+        self.LocatioLabel.setObjectName(u'LocatioLabel')
         self.gridLayout_2.addWidget(self.LocatioLabel, 0, 0, 1, 1)
         self.OSISLocationEdit = QtGui.QLineEdit(self.OSISGroupBox)
-        self.OSISLocationEdit.setObjectName("OSISLocationEdit")
+        self.OSISLocationEdit.setObjectName(u'OSISLocationEdit')
         self.gridLayout_2.addWidget(self.OSISLocationEdit, 0, 1, 1, 1)
         self.OsisFileButton = QtGui.QPushButton(self.OSISGroupBox)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/imports/import_load.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/imports/import_load.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.OsisFileButton.setIcon(icon1)
-        self.OsisFileButton.setObjectName("OsisFileButton")
+        self.OsisFileButton.setObjectName(u'OsisFileButton')
         self.gridLayout_2.addWidget(self.OsisFileButton, 0, 2, 1, 1)
         self.CVSGroupBox = QtGui.QGroupBox(self.FileImportPage)
         self.CVSGroupBox.setGeometry(QtCore.QRect(20, 170, 411, 191))
-        self.CVSGroupBox.setObjectName("CVSGroupBox")
+        self.CVSGroupBox.setObjectName(u'CVSGroupBox')
         self.gridLayout = QtGui.QGridLayout(self.CVSGroupBox)
         self.gridLayout.setMargin(8)
         self.gridLayout.setSpacing(8)
-        self.gridLayout.setObjectName("gridLayout")
+        self.gridLayout.setObjectName(u'gridLayout')
         self.BooksLocationLabel = QtGui.QLabel(self.CVSGroupBox)
-        self.BooksLocationLabel.setObjectName("BooksLocationLabel")
+        self.BooksLocationLabel.setObjectName(u'BooksLocationLabel')
         self.gridLayout.addWidget(self.BooksLocationLabel, 0, 0, 1, 1)
         self.VerseLocationLabel = QtGui.QLabel(self.CVSGroupBox)
-        self.VerseLocationLabel.setObjectName("VerseLocationLabel")
+        self.VerseLocationLabel.setObjectName(u'VerseLocationLabel')
         self.gridLayout.addWidget(self.VerseLocationLabel, 4, 0, 1, 1)
         self.VerseLocationEdit = QtGui.QLineEdit(self.CVSGroupBox)
-        self.VerseLocationEdit.setObjectName("VerseLocationEdit")
+        self.VerseLocationEdit.setObjectName(u'VerseLocationEdit')
         self.gridLayout.addWidget(self.VerseLocationEdit, 4, 1, 1, 1)
         self.BooksLocationEdit = QtGui.QLineEdit(self.CVSGroupBox)
-        self.BooksLocationEdit.setObjectName("BooksLocationEdit")
+        self.BooksLocationEdit.setObjectName(u'BooksLocationEdit')
         self.gridLayout.addWidget(self.BooksLocationEdit, 0, 1, 1, 1)
         self.BooksFileButton = QtGui.QPushButton(self.CVSGroupBox)
         self.BooksFileButton.setIcon(icon1)
-        self.BooksFileButton.setObjectName("BooksFileButton")
+        self.BooksFileButton.setObjectName(u'BooksFileButton')
         self.gridLayout.addWidget(self.BooksFileButton, 0, 2, 1, 1)
         self.VersesFileButton = QtGui.QPushButton(self.CVSGroupBox)
         self.VersesFileButton.setIcon(icon1)
-        self.VersesFileButton.setObjectName("VersesFileButton")
+        self.VersesFileButton.setObjectName(u'VersesFileButton')
         self.gridLayout.addWidget(self.VersesFileButton, 4, 2, 1, 1)
         self.BibleNameEdit = QtGui.QLineEdit(self.FileImportPage)
         self.BibleNameEdit.setGeometry(QtCore.QRect(100, 20, 280, 28))
-        self.BibleNameEdit.setObjectName("BibleNameEdit")
+        self.BibleNameEdit.setObjectName(u'BibleNameEdit')
         self.BibleNameLabel = QtGui.QLabel(self.FileImportPage)
         self.BibleNameLabel.setGeometry(QtCore.QRect(18, 20, 98, 22))
-        self.BibleNameLabel.setObjectName("BibleNameLabel")
-        self.ImportToolBox.addItem(self.FileImportPage, "")
+        self.BibleNameLabel.setObjectName(u'BibleNameLabel')
+        self.ImportToolBox.addItem(self.FileImportPage, u'')
         self.WebBiblePage = QtGui.QWidget()
         self.WebBiblePage.setGeometry(QtCore.QRect(0, 0, 447, 337))
-        self.WebBiblePage.setObjectName("WebBiblePage")
+        self.WebBiblePage.setObjectName(u'WebBiblePage')
         self.WebBibleLayout = QtGui.QVBoxLayout(self.WebBiblePage)
         self.WebBibleLayout.setSpacing(8)
         self.WebBibleLayout.setMargin(8)
-        self.WebBibleLayout.setObjectName("WebBibleLayout")
+        self.WebBibleLayout.setObjectName(u'WebBibleLayout')
         self.OptionsGroupBox = QtGui.QGroupBox(self.WebBiblePage)
-        self.OptionsGroupBox.setObjectName("OptionsGroupBox")
+        self.OptionsGroupBox.setObjectName(u'OptionsGroupBox')
         self.formLayout_2 = QtGui.QFormLayout(self.OptionsGroupBox)
-        self.formLayout_2.setObjectName("formLayout_2")
+        self.formLayout_2.setObjectName(u'formLayout_2')
         self.LocationLabel = QtGui.QLabel(self.OptionsGroupBox)
-        self.LocationLabel.setObjectName("LocationLabel")
+        self.LocationLabel.setObjectName(u'LocationLabel')
         self.formLayout_2.setWidget(0, QtGui.QFormLayout.LabelRole, self.LocationLabel)
         self.LocationComboBox = QtGui.QComboBox(self.OptionsGroupBox)
-        self.LocationComboBox.setObjectName("LocationComboBox")
+        self.LocationComboBox.setObjectName(u'LocationComboBox')
         self.LocationComboBox.addItem(QtCore.QString())
         self.formLayout_2.setWidget(0, QtGui.QFormLayout.FieldRole, self.LocationComboBox)
         self.BibleLabel = QtGui.QLabel(self.OptionsGroupBox)
-        self.BibleLabel.setObjectName("BibleLabel")
+        self.BibleLabel.setObjectName(u'BibleLabel')
         self.formLayout_2.setWidget(1, QtGui.QFormLayout.LabelRole, self.BibleLabel)
         self.BibleComboBox = QtGui.QComboBox(self.OptionsGroupBox)
-        self.BibleComboBox.setObjectName("BibleComboBox")
+        self.BibleComboBox.setObjectName(u'BibleComboBox')
         self.BibleComboBox.addItem(QtCore.QString())
-        self.BibleComboBox.setItemText(0, "")
+        self.BibleComboBox.setItemText(0, u'')
         self.BibleComboBox.addItem(QtCore.QString())
         self.BibleComboBox.addItem(QtCore.QString())
         self.formLayout_2.setWidget(1, QtGui.QFormLayout.FieldRole, self.BibleComboBox)
         self.WebBibleLayout.addWidget(self.OptionsGroupBox)
         self.ProxyGroupBox = QtGui.QGroupBox(self.WebBiblePage)
-        self.ProxyGroupBox.setObjectName("ProxyGroupBox")
+        self.ProxyGroupBox.setObjectName(u'ProxyGroupBox')
         self.ProxySettingsLayout = QtGui.QFormLayout(self.ProxyGroupBox)
         self.ProxySettingsLayout.setFieldGrowthPolicy(QtGui.QFormLayout.AllNonFixedFieldsGrow)
         self.ProxySettingsLayout.setMargin(8)
         self.ProxySettingsLayout.setSpacing(8)
-        self.ProxySettingsLayout.setObjectName("ProxySettingsLayout")
+        self.ProxySettingsLayout.setObjectName(u'ProxySettingsLayout')
         self.AddressLabel = QtGui.QLabel(self.ProxyGroupBox)
-        self.AddressLabel.setObjectName("AddressLabel")
+        self.AddressLabel.setObjectName(u'AddressLabel')
         self.ProxySettingsLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.AddressLabel)
         self.AddressEdit = QtGui.QLineEdit(self.ProxyGroupBox)
-        self.AddressEdit.setObjectName("AddressEdit")
+        self.AddressEdit.setObjectName(u'AddressEdit')
         self.ProxySettingsLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.AddressEdit)
         self.UsernameLabel = QtGui.QLabel(self.ProxyGroupBox)
-        self.UsernameLabel.setObjectName("UsernameLabel")
+        self.UsernameLabel.setObjectName(u'UsernameLabel')
         self.ProxySettingsLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.UsernameLabel)
         self.UsernameEdit = QtGui.QLineEdit(self.ProxyGroupBox)
-        self.UsernameEdit.setObjectName("UsernameEdit")
+        self.UsernameEdit.setObjectName(u'UsernameEdit')
         self.ProxySettingsLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.UsernameEdit)
         self.PasswordLabel = QtGui.QLabel(self.ProxyGroupBox)
-        self.PasswordLabel.setObjectName("PasswordLabel")
+        self.PasswordLabel.setObjectName(u'PasswordLabel')
         self.ProxySettingsLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.PasswordLabel)
         self.PasswordEdit = QtGui.QLineEdit(self.ProxyGroupBox)
         self.PasswordEdit.setEchoMode(QtGui.QLineEdit.Password)
-        self.PasswordEdit.setObjectName("PasswordEdit")
+        self.PasswordEdit.setObjectName(u'PasswordEdit')
         self.ProxySettingsLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.PasswordEdit)
         self.WebBibleLayout.addWidget(self.ProxyGroupBox)
-        self.ImportToolBox.addItem(self.WebBiblePage, "")
+        self.ImportToolBox.addItem(self.WebBiblePage, u'')
         self.LicenceDetailsGroupBox = QtGui.QGroupBox(BibleImportDialog)
         self.LicenceDetailsGroupBox.setGeometry(QtCore.QRect(10, 435, 471, 151))
         self.LicenceDetailsGroupBox.setMinimumSize(QtCore.QSize(0, 123))
-        self.LicenceDetailsGroupBox.setObjectName("LicenceDetailsGroupBox")
+        self.LicenceDetailsGroupBox.setObjectName(u'LicenceDetailsGroupBox')
         self.formLayout = QtGui.QFormLayout(self.LicenceDetailsGroupBox)
         self.formLayout.setMargin(8)
         self.formLayout.setHorizontalSpacing(8)
-        self.formLayout.setObjectName("formLayout")
+        self.formLayout.setObjectName(u'formLayout')
         self.VersionNameLabel = QtGui.QLabel(self.LicenceDetailsGroupBox)
-        self.VersionNameLabel.setObjectName("VersionNameLabel")
+        self.VersionNameLabel.setObjectName(u'VersionNameLabel')
         self.formLayout.setWidget(0, QtGui.QFormLayout.LabelRole, self.VersionNameLabel)
         self.VersionNameEdit = QtGui.QLineEdit(self.LicenceDetailsGroupBox)
-        self.VersionNameEdit.setObjectName("VersionNameEdit")
+        self.VersionNameEdit.setObjectName(u'VersionNameEdit')
         self.formLayout.setWidget(0, QtGui.QFormLayout.FieldRole, self.VersionNameEdit)
         self.CopyrightLabel = QtGui.QLabel(self.LicenceDetailsGroupBox)
-        self.CopyrightLabel.setObjectName("CopyrightLabel")
+        self.CopyrightLabel.setObjectName(u'CopyrightLabel')
         self.formLayout.setWidget(1, QtGui.QFormLayout.LabelRole, self.CopyrightLabel)
         self.CopyrightEdit = QtGui.QLineEdit(self.LicenceDetailsGroupBox)
-        self.CopyrightEdit.setObjectName("CopyrightEdit")
+        self.CopyrightEdit.setObjectName(u'CopyrightEdit')
         self.formLayout.setWidget(1, QtGui.QFormLayout.FieldRole, self.CopyrightEdit)
         self.PermisionLabel = QtGui.QLabel(self.LicenceDetailsGroupBox)
-        self.PermisionLabel.setObjectName("PermisionLabel")
+        self.PermisionLabel.setObjectName(u'PermisionLabel')
         self.formLayout.setWidget(2, QtGui.QFormLayout.LabelRole, self.PermisionLabel)
         self.PermisionEdit = QtGui.QLineEdit(self.LicenceDetailsGroupBox)
-        self.PermisionEdit.setObjectName("PermisionEdit")
+        self.PermisionEdit.setObjectName(u'PermisionEdit')
         self.formLayout.setWidget(2, QtGui.QFormLayout.FieldRole, self.PermisionEdit)
         self.MessageLabel = QtGui.QLabel(BibleImportDialog)
         self.MessageLabel.setGeometry(QtCore.QRect(20, 670, 271, 17))
-        self.MessageLabel.setObjectName("MessageLabel")
+        self.MessageLabel.setObjectName(u'MessageLabel')
         self.ProgressGroupBox = QtGui.QGroupBox(BibleImportDialog)
         self.ProgressGroupBox.setGeometry(QtCore.QRect(10, 600, 471, 70))
-        self.ProgressGroupBox.setObjectName("ProgressGroupBox")
+        self.ProgressGroupBox.setObjectName(u'ProgressGroupBox')
         self.gridLayout_3 = QtGui.QGridLayout(self.ProgressGroupBox)
-        self.gridLayout_3.setObjectName("gridLayout_3")
+        self.gridLayout_3.setObjectName(u'gridLayout_3')
         self.ProgressBar = QtGui.QProgressBar(self.ProgressGroupBox)
-        self.ProgressBar.setProperty("value", QtCore.QVariant(0))
+        self.ProgressBar.setProperty(u'value', QtCore.QVariant(0))
         self.ProgressBar.setInvertedAppearance(False)
-        self.ProgressBar.setObjectName("ProgressBar")
+        self.ProgressBar.setObjectName(u'ProgressBar')
         self.gridLayout_3.addWidget(self.ProgressBar, 0, 0, 1, 1)
         self.layoutWidget = QtGui.QWidget(BibleImportDialog)
         self.layoutWidget.setGeometry(QtCore.QRect(300, 680, 180, 38))
-        self.layoutWidget.setObjectName("layoutWidget")
+        self.layoutWidget.setObjectName(u'layoutWidget')
         self.horizontalLayout = QtGui.QHBoxLayout(self.layoutWidget)
         self.horizontalLayout.setMargin(6)
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.ImportButton = QtGui.QPushButton(self.layoutWidget)
-        self.ImportButton.setObjectName("ImportButton")
+        self.ImportButton.setObjectName(u'ImportButton')
         self.horizontalLayout.addWidget(self.ImportButton)
         self.CancelButton = QtGui.QPushButton(self.layoutWidget)
-        self.CancelButton.setObjectName("CancelButton")
+        self.CancelButton.setObjectName(u'CancelButton')
         self.horizontalLayout.addWidget(self.CancelButton)
 
         self.retranslateUi(BibleImportDialog)
@@ -205,31 +205,30 @@
         BibleImportDialog.setTabOrder(self.CopyrightEdit, self.PermisionEdit)
 
     def retranslateUi(self, BibleImportDialog):
-        BibleImportDialog.setWindowTitle(QtGui.QApplication.translate("BibleImportDialog", "Bible Registration", None, QtGui.QApplication.UnicodeUTF8))
-        self.OSISGroupBox.setTitle(QtGui.QApplication.translate("BibleImportDialog", "OSIS Bible", None, QtGui.QApplication.UnicodeUTF8))
-        self.LocatioLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "File Location:", None, QtGui.QApplication.UnicodeUTF8))
-        self.CVSGroupBox.setTitle(QtGui.QApplication.translate("BibleImportDialog", "CVS Bible", None, QtGui.QApplication.UnicodeUTF8))
-        self.BooksLocationLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Books Location:", None, QtGui.QApplication.UnicodeUTF8))
-        self.VerseLocationLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Verse Location:", None, QtGui.QApplication.UnicodeUTF8))
-        self.BibleNameLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Bible Name:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportToolBox.setItemText(self.ImportToolBox.indexOf(self.FileImportPage), QtGui.QApplication.translate("BibleImportDialog", "File Import Page", None, QtGui.QApplication.UnicodeUTF8))
-        self.OptionsGroupBox.setTitle(QtGui.QApplication.translate("BibleImportDialog", "Download Options", None, QtGui.QApplication.UnicodeUTF8))
-        self.LocationLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Location:", None, QtGui.QApplication.UnicodeUTF8))
-        self.LocationComboBox.setItemText(0, QtGui.QApplication.translate("BibleImportDialog", "Crosswalk", None, QtGui.QApplication.UnicodeUTF8))
-        self.BibleLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Bible:", None, QtGui.QApplication.UnicodeUTF8))
-        self.BibleComboBox.setItemText(1, QtGui.QApplication.translate("BibleImportDialog", "NIV", None, QtGui.QApplication.UnicodeUTF8))
-        self.BibleComboBox.setItemText(2, QtGui.QApplication.translate("BibleImportDialog", "KJV", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProxyGroupBox.setTitle(QtGui.QApplication.translate("BibleImportDialog", "Proxy Settings (Optional)", None, QtGui.QApplication.UnicodeUTF8))
-        self.AddressLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Proxy Address:", None, QtGui.QApplication.UnicodeUTF8))
-        self.UsernameLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Username:", None, QtGui.QApplication.UnicodeUTF8))
-        self.PasswordLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Password:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportToolBox.setItemText(self.ImportToolBox.indexOf(self.WebBiblePage), QtGui.QApplication.translate("BibleImportDialog", "Web Bible Import page", None, QtGui.QApplication.UnicodeUTF8))
-        self.LicenceDetailsGroupBox.setTitle(QtGui.QApplication.translate("BibleImportDialog", "Licence Details", None, QtGui.QApplication.UnicodeUTF8))
-        self.VersionNameLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Version Name:", None, QtGui.QApplication.UnicodeUTF8))
-        self.CopyrightLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Copyright:", None, QtGui.QApplication.UnicodeUTF8))
-        self.PermisionLabel.setText(QtGui.QApplication.translate("BibleImportDialog", "Permission:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressGroupBox.setTitle(QtGui.QApplication.translate("BibleImportDialog", "Import Progress", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressBar.setFormat(QtGui.QApplication.translate("BibleImportDialog", "%p", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportButton.setText(QtGui.QApplication.translate("BibleImportDialog", "Import", None, QtGui.QApplication.UnicodeUTF8))
-        self.CancelButton.setText(QtGui.QApplication.translate("BibleImportDialog", "Cancel", None, QtGui.QApplication.UnicodeUTF8))
-
+        BibleImportDialog.setWindowTitle(translate(u'BibleImportDialog', u'Bible Registration'))
+        self.OSISGroupBox.setTitle(translate(u'BibleImportDialog', u'OSIS Bible'))
+        self.LocatioLabel.setText(translate(u'BibleImportDialog', u'File Location:'))
+        self.CVSGroupBox.setTitle(translate(u'BibleImportDialog', u'CVS Bible'))
+        self.BooksLocationLabel.setText(translate(u'BibleImportDialog', u'Books Location:'))
+        self.VerseLocationLabel.setText(translate(u'BibleImportDialog', u'Verse Location:'))
+        self.BibleNameLabel.setText(translate(u'BibleImportDialog', u'Bible Name:'))
+        self.ImportToolBox.setItemText(self.ImportToolBox.indexOf(self.FileImportPage), translate(u'BibleImportDialog', u'File Import Page'))
+        self.OptionsGroupBox.setTitle(translate(u'BibleImportDialog', u'Download Options'))
+        self.LocationLabel.setText(translate(u'BibleImportDialog', u'Location:'))
+        self.LocationComboBox.setItemText(0, translate(u'BibleImportDialog', u'Crosswalk'))
+        self.BibleLabel.setText(translate(u'BibleImportDialog', u'Bible:'))
+        self.BibleComboBox.setItemText(1, translate(u'BibleImportDialog', u'NIV'))
+        self.BibleComboBox.setItemText(2, translate(u'BibleImportDialog', u'KJV'))
+        self.ProxyGroupBox.setTitle(translate(u'BibleImportDialog', u'Proxy Settings (Optional)'))
+        self.AddressLabel.setText(translate(u'BibleImportDialog', u'Proxy Address:'))
+        self.UsernameLabel.setText(translate(u'BibleImportDialog', u'Username:'))
+        self.PasswordLabel.setText(translate(u'BibleImportDialog', u'Password:'))
+        self.ImportToolBox.setItemText(self.ImportToolBox.indexOf(self.WebBiblePage), translate(u'BibleImportDialog', u'Web Bible Import page'))
+        self.LicenceDetailsGroupBox.setTitle(translate(u'BibleImportDialog', u'Licence Details'))
+        self.VersionNameLabel.setText(translate(u'BibleImportDialog', u'Version Name:'))
+        self.CopyrightLabel.setText(translate(u'BibleImportDialog', u'Copyright:'))
+        self.PermisionLabel.setText(translate(u'BibleImportDialog', u'Permission:'))
+        self.ProgressGroupBox.setTitle(translate(u'BibleImportDialog', u'Import Progress'))
+        self.ProgressBar.setFormat(translate(u'BibleImportDialog', u'%p'))
+        self.ImportButton.setText(translate(u'BibleImportDialog', u'Import'))
+        self.CancelButton.setText(translate(u'BibleImportDialog', u'Cancel'))

=== modified file 'openlp/plugins/bibles/forms/bibleimportform.py'
--- openlp/plugins/bibles/forms/bibleimportform.py	2009-06-08 05:04:06 +0000
+++ openlp/plugins/bibles/forms/bibleimportform.py	2009-06-16 18:21:24 +0000
@@ -61,7 +61,7 @@
         for line in fbibles:
             p = line.split(u',')
             self.bible_versions[p[0]] = p[1].replace(u'\n', u'')
-            self.BibleComboBox.addItem(str(p[0]))
+            self.BibleComboBox.addItem(unicode(p[0]))
 
         #Combo Boxes
         QtCore.QObject.connect(self.LocationComboBox,
@@ -133,20 +133,20 @@
         self.checkOsis()
 
     def onProxyAddressEditLostFocus(self):
-        self.config.set_config(u'proxy_address', str(self.AddressEdit.displayText()))
+        self.config.set_config(u'proxy_address', unicode(self.AddressEdit.displayText()))
 
     def onProxyUsernameEditLostFocus(self):
-        self.config.set_config(u'proxy_username', str(self.UsernameEdit.displayText()))
+        self.config.set_config(u'proxy_username', unicode(self.UsernameEdit.displayText()))
 
     def onProxyPasswordEditLostFocus(self):
-        self.config.set_config(u'proxy_password', str(self.PasswordEdit.displayText()))
+        self.config.set_config(u'proxy_password', unicode(self.PasswordEdit.displayText()))
 
     def onLocationComboBoxSelected(self):
         self.checkHttp()
 
     def onBibleComboBoxSelected(self):
         self.checkHttp()
-        self.BibleNameEdit.setText(str(self.BibleComboBox.currentText()))
+        self.BibleNameEdit.setText(unicode(self.BibleComboBox.currentText()))
 
     def onCancelButtonClicked(self):
         # tell import to stop
@@ -187,26 +187,26 @@
     def importBible(self):
         log.debug(u'Import Bible ')
         if self.bible_type == u'OSIS':
-            loaded = self.biblemanager.register_osis_file_bible(str(self.BibleNameEdit.displayText()),
+            loaded = self.biblemanager.register_osis_file_bible(unicode(self.BibleNameEdit.displayText()),
                 self.OSISLocationEdit.displayText())
         elif self.bible_type == u'CSV':
-            loaded = self.biblemanager.register_csv_file_bible(str(self.BibleNameEdit.displayText()),
+            loaded = self.biblemanager.register_csv_file_bible(unicode(self.BibleNameEdit.displayText()),
                 self.BooksLocationEdit.displayText(), self.VerseLocationEdit.displayText())
         else:
             # set a value as it will not be needed
             self.setMax(1)
-            bible = self.bible_versions[str(self.BibleComboBox.currentText())]
-            loaded = self.biblemanager.register_http_bible(str(self.BibleComboBox.currentText()), \
-                                                                                     str(self.LocationComboBox.currentText()),  \
-                                                                                     str(bible), \
-                                                                                     str(self.AddressEdit.displayText()),  \
-                                                                                     str(self.UsernameEdit .displayText()),  \
-                                                                                     str(self.PasswordEdit.displayText()))
+            bible = self.bible_versions[unicode(self.BibleComboBox.currentText())]
+            loaded = self.biblemanager.register_http_bible(unicode(self.BibleComboBox.currentText()), \
+                                                                                     unicode(self.LocationComboBox.currentText()),  \
+                                                                                     unicode(bible), \
+                                                                                     unicode(self.AddressEdit.displayText()),  \
+                                                                                     unicode(self.UsernameEdit .displayText()),  \
+                                                                                     unicode(self.PasswordEdit.displayText()))
         if loaded:
-            self.biblemanager.save_meta_data(str(self.BibleNameEdit.displayText()),
-                str(self.VersionNameEdit.displayText()),
-                str(self.CopyrightEdit.displayText()),
-                str(self.PermisionEdit.displayText()))
+            self.biblemanager.save_meta_data(unicode(self.BibleNameEdit.displayText()),
+                unicode(self.VersionNameEdit.displayText()),
+                unicode(self.CopyrightEdit.displayText()),
+                unicode(self.PermisionEdit.displayText()))
         self.bible_type = None
         # free the screen state restrictions
         self.resetScreenFieldStates()
@@ -286,4 +286,4 @@
         self.OSISLocationEdit.setText(u'')
         self.BibleNameEdit.setText(u'')
         self.LocationComboBox.setCurrentIndex(0)
-        self.BibleComboBox.setCurrentIndex(0)
+        self.BibleComboBox.setCurrentIndex(0)
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/lib/__init__.py'
--- openlp/plugins/bibles/lib/__init__.py	2009-03-16 17:33:51 +0000
+++ openlp/plugins/bibles/lib/__init__.py	2009-06-17 05:11:16 +0000
@@ -17,10 +17,7 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-from textlistdata import TextListData
 from common import BibleCommon
 from manager import BibleManager
 from biblestab import BiblesTab
 from mediaitem import BibleMediaItem
-
-__all__ = ['BibleCommon', 'BibleManager', 'BiblesTab', 'BibleMediaItem', 'TextListData']

=== modified file 'openlp/plugins/bibles/lib/bibleCSVimpl.py'
--- openlp/plugins/bibles/lib/bibleCSVimpl.py	2009-03-16 17:33:51 +0000
+++ openlp/plugins/bibles/lib/bibleCSVimpl.py	2009-06-16 18:21:24 +0000
@@ -34,7 +34,7 @@
         """         
         self.bibledb = bibledb
         self.loadbible = True
-        QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL("openlpstopimport"),self.stop_import)
+        QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL(u'openlpstopimport'),self.stop_import)
         
     def stop_import(self):
         self.loadbible= False
@@ -56,7 +56,7 @@
             self.bibledb.create_book(p2, p3, int(p1))
             count += 1
             if count % 3 == 0:   #Every x verses repaint the screen
-                Receiver().send_message("openlpprocessevents")                    
+                Receiver().send_message(u'openlpprocessevents')                    
                 count = 0
         
         count = 0
@@ -75,5 +75,5 @@
             self.bibledb.add_verse(book.id, p[1], p[2], p3)
             count += 1
             if count % 3 == 0:   #Every x verses repaint the screen
-                Receiver().send_message("openlpprocessevents")                    
-                count = 0
+                Receiver().send_message(u'openlpprocessevents')                    
+                count = 0
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/lib/bibleDBimpl.py'
--- openlp/plugins/bibles/lib/bibleDBimpl.py	2009-06-05 05:00:26 +0000
+++ openlp/plugins/bibles/lib/bibleDBimpl.py	2009-06-16 18:21:24 +0000
@@ -37,10 +37,10 @@
         # Connect to database
         self.config = config
         self.biblefile = os.path.join(biblepath, biblename+u'.sqlite')
-        log.debug( "Load bible %s on path %s", biblename, self.biblefile)
+        log.debug(u'Load bible %s on path %s', biblename, self.biblefile)
         db_type = self.config.get_config(u'db type', u'sqlite')
         if db_type  == u'sqlite':
-            self.db = create_engine("sqlite:///" + self.biblefile)
+            self.db = create_engine(u'sqlite:///' + self.biblefile)
         else:
             self.db_url = u'%s://%s:%s@%s/%s' % \
                 (db_type, self.config.get_config(u'db username'),
@@ -57,12 +57,12 @@
     def create_tables(self):
         log.debug( u'createTables')
         self.save_meta(u'dbversion', u'2')
-        self._load_testament("Old Testament")
-        self._load_testament("New Testament")
-        self._load_testament("Apocrypha")
+        self._load_testament(u'Old Testament')
+        self._load_testament(u'New Testament')
+        self._load_testament(u'Apocrypha')
 
     def add_verse(self, bookid, chap,  vse, text):
-        #log.debug( "add_verse %s,%s,%s", bookid, chap, vse)
+        #log.debug(u'add_verse %s,%s,%s", bookid, chap, vse)
         metadata.bind.echo = False
         session = self.session()
         verse = Verse()
@@ -74,8 +74,8 @@
         session.commit()
 
     def create_chapter(self, bookid, chap, textlist):
-        log.debug( "create_chapter %s,%s", bookid, chap)
-        #log.debug("Text %s ", textlist)
+        log.debug(u'create_chapter %s,%s', bookid, chap)
+        #log.debug(u'Text %s ", textlist)
         metadata.bind.echo = False
         session = self.session()
         #text list has book and chapter as first to elements of the array
@@ -89,7 +89,7 @@
         session.commit()
 
     def create_book(self, bookname, bookabbrev, testament = 1):
-        log.debug( "create_book %s,%s", bookname, bookabbrev)
+        log.debug(u'create_book %s,%s', bookname, bookabbrev)
         metadata.bind.echo = False
         session = self.session()
         book = Book()
@@ -101,7 +101,7 @@
         return book
 
     def save_meta(self, key, value):
-        log.debug( "save_meta %s/%s", key, value)
+        log.debug(u'save_meta %s/%s', key, value)
         metadata.bind.echo = False
         session = self.session()
         bmeta= BibleMeta()
@@ -111,7 +111,7 @@
         session.commit()
 
     def get_meta(self, metakey):
-        log.debug( "get meta %s", metakey)
+        log.debug(u'get meta %s', metakey)
         return self.session.query(BibleMeta).filter_by(key = metakey).first()
 
     def delete_meta(self, metakey):
@@ -124,7 +124,7 @@
             return False
 
     def _load_testament(self, testament):
-        log.debug("load_testaments %s",  testament)
+        log.debug(u'load_testaments %s',  testament)
         metadata.bind.echo = False
         session = self.session()
         test = ONTestament()
@@ -133,52 +133,52 @@
         session.commit()
 
     def get_bible_books(self):
-        log.debug( "get_bible_books ")
+        log.debug(u'get_bible_books ')
         return self.session.query(Book).order_by(Book.id).all()
 
     def get_max_bible_book_verses(self, bookname, chapter):
-        log.debug( "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
-        s = text (""" 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()
 
     def get_max_bible_book_chapter(self, bookname):
-        log.debug( "get_max_bible_book_chapter %s ", bookname )
+        log.debug(u'get_max_bible_book_chapter %s', bookname )
         metadata.bind.echo = False
-        s = text (""" 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()
 
     def get_bible_book(self, bookname):
-        log.debug( "get_bible_book %s", bookname)
-        bk = self.session.query(Book).filter(Book.name.like(bookname+u"%")).first()
+        log.debug(u'get_bible_book %s', bookname)
+        bk = self.session.query(Book).filter(Book.name.like(bookname + u'%')).first()
         if bk == None:
-            bk = self.session.query(Book).filter(Book.abbreviation.like(bookname+u"%")).first()
+            bk = self.session.query(Book).filter(Book.abbreviation.like(bookname+u'%')).first()
         return bk
 
     def get_bible_chapter(self, id, chapter):
-        log.debug( "get_bible_chapter %s,%s", id, chapter )
+        log.debug(u'get_bible_chapter %s,%s', id, chapter )
         metadata.bind.echo = False
         return self.session.query(Verse).filter_by(chapter = chapter ).filter_by(book_id = id).first()
 
     def get_bible_text(self, bookname, chapter, sverse, everse):
-        log.debug( "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
         bookname = bookname + u"%"
-        s = text (""" 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()
 
     def get_verses_from_text(self,versetext):
-        log.debug( "get_verses_from_text %s",versetext)
+        log.debug(u'get_verses_from_text %s',versetext)
         metadata.bind.echo = False
         versetext = "%"+versetext+"%"
-        s = text (""" select book.name, verse.chapter, verse.verse, verse.text FROM verse , book where  verse.book_id == book.id  and verse.text like :t """)
+        s = text (u'select book.name, verse.chapter, verse.verse, verse.text FROM verse , book where  verse.book_id == book.id  and verse.text like :t')
         return self.db.execute(s, t=versetext).fetchall()
 
     def dump_bible(self):
         log.debug( u'.........Dumping Bible Database')
         log.debug( '...............................Books ')
-        s = text (""" select * FROM book """)
+        s = text (u'select * FROM book ')
         log.debug( self.db.execute(s).fetchall())
         log.debug( u'...............................Verses ')
-        s = text (""" select * FROM verse """)
+        s = text (u'select * FROM verse ')
         log.debug( self.db.execute(s).fetchall())

=== modified file 'openlp/plugins/bibles/lib/bibleHTTPimpl.py'
--- openlp/plugins/bibles/lib/bibleHTTPimpl.py	2009-03-16 17:33:51 +0000
+++ openlp/plugins/bibles/lib/bibleHTTPimpl.py	2009-06-16 18:21:24 +0000
@@ -23,31 +23,29 @@
 from common import BibleCommon, SearchResults
 
 import logging
-                
+
 class BGExtract(BibleCommon):
-    global log 
+    global log
     log=logging.getLogger(u'BibleHTTPMgr(BG_extract)')
-    log.info(u'BG_extract loaded') 
-    
+    log.info(u'BG_extract loaded')
+
     def __init__(self, proxyurl= None):
-        log.debug("init %s", proxyurl)  
+        log.debug(u'init %s', proxyurl)
         self.proxyurl = proxyurl
-        
+
     def get_bible_chapter(self, version, bookid, bookname,  chapter) :
         """
         Access and decode bibles via the BibleGateway website
             Version - the version of the bible like 31 for New International version
             bookid - Book id for the book of the bible - eg 1 for Genesis
             bookname - not used
-            chapter - chapter number 
-        
+            chapter - chapter number
         """
-        version = 49
-        log.debug( u"get_bible_chapter %s,%s,%s,%s", version, bookid, bookname,  chapter) 
-        urlstring = u"http://www.biblegateway.com/passage/?book_id="+str(bookid)+"&chapter"+str(chapter)+"&version="+str(version)
+        log.debug( u'get_bible_chapter %s,%s,%s,%s', version, bookid, bookname,  chapter)
+        urlstring = u'http://www.biblegateway.com/passage/?book_id='+unicode(bookid)+u'&chapter'+unicode(chapter)+u'&version='+unicode(version)
         xml_string = self._get_web_text(urlstring, self.proxyurl)
         print xml_string
-        VerseSearch = u'class='+'"'+u'sup'+'"'+u'>'
+        VerseSearch = u'class='+u'"'+u'sup'+u'"'+u'>'
         verse = 1
         i= xml_string.find(u'result-text-style-normal')
         xml_string = xml_string[i:len(xml_string)]
@@ -61,14 +59,14 @@
             #print i ,  versePos
             if i == -1:
                 i = xml_string.find(u'</div', versePos+1)
-                j = xml_string.find(u'<strong', versePos+1)                
+                j = xml_string.find(u'<strong', versePos+1)
                 #print i ,  j
                 if j > 0 and j < i:
                     i = j
-                verseText = xml_string[versePos + 7 : i ] 
+                verseText = xml_string[versePos + 7 : i ]
                 #print xml_string
-                #print 'VerseText = ' + str(verse) +' '+ verseText
-                bible[verse] = self._clean_text(verseText) # store the verse                
+                #print 'VerseText = ' + unicode(verse) +' '+ verseText
+                bible[verse] = self._clean_text(verseText) # store the verse
                 versePos = -1
             else:
                 i = xml_string[:i].rfind(u'<span')+1
@@ -77,43 +75,43 @@
                 versePos = xml_string.find(VerseSearch) #look for the next verse
                 bible[verse] = self._clean_text(verseText) # store the verse
                 verse += 1
-        return bible        
-        
+        return bible
+
 class CWExtract(BibleCommon):
-    global log 
+    global log
     log=logging.getLogger(u'BibleHTTPMgr(CWExtract)')
-    log.info(u'CWExtract loaded') 
-    
+    log.info(u'CWExtract loaded')
+
     def __init__(self, proxyurl=None):
-        log.debug(u"init %s", proxyurl)  
+        log.debug(u'init %s', proxyurl)
         self.proxyurl = proxyurl
-        
+
     def get_bible_chapter(self, version, bookid, bookname,  chapter) :
-        log.debug( u"getBibleChapter %s,%s,%s,%s", version, bookid, bookname,  chapter) 
+        log.debug( u'getBibleChapter %s,%s,%s,%s', version, bookid, bookname,  chapter)
         """
         Access and decode bibles via the Crosswalk website
             Version - the version of the bible like niv for New International version
             bookid - not used
             bookname - text name of in english eg 'gen' for Genesis
-            chapter - chapter number 
-        """        
-        log.debug( "get_bible_chapter %s,%s,%s,%s", version, bookid, bookname,  chapter)
-        bookname = bookname.replace(' ', '')
-        urlstring = "http://bible.crosswalk.com/OnlineStudyBible/bible.cgi?word="+bookname+"+"+str(chapter)+"&version="+version
+            chapter - chapter number
+        """
+        log.debug(u'get_bible_chapter %s,%s,%s,%s', version, bookid, bookname,  chapter)
+        bookname = bookname.replace(u' ', '')
+        urlstring = "http://bible.crosswalk.com/OnlineStudyBible/bible.cgi?word="+bookname+"+"+unicode(chapter)+"&version="+version
         xml_string = self._get_web_text(urlstring, self.proxyurl)
-        #log.debug('Return data %s', xml_string)
+        #log.debug(u'Return data %s', xml_string)
         ## Strip Book Title from Heading to return it to system
         ##
         i= xml_string.find(u'<title>')
         j= xml_string.find(u'-', i)
         book_title = xml_string[i + 7:j]
         book_title = book_title.rstrip()
-        log.debug(u"Book Title %s", book_title)
-        i = book_title.rfind(" ")
+        log.debug(u'Book Title %s', book_title)
+        i = book_title.rfind(u' ')
         book_chapter = book_title[i+1:len(book_title)].rstrip()
         book_title = book_title[:i].rstrip()
-        log.debug(u"Book Title %s", book_title)
-        log.debug(u"Book Chapter %s", book_chapter)
+        log.debug(u'Book Title %s', book_title)
+        log.debug(u'Book Chapter %s', book_chapter)
 
         ## Strip Verse Data from Page and build an array
         ##
@@ -125,17 +123,17 @@
         xml_string = xml_string[i + 3 :len(xml_string)] #remove the <B> at the front
         i= xml_string.find(u'<B>') # Remove the heading for the book
         xml_string = xml_string[i + 3 :len(xml_string)] #remove the <B> at the front
-        versePos = xml_string.find(u'<BLOCKQUOTE>') 
+        versePos = xml_string.find(u'<BLOCKQUOTE>')
         #log.debug( versePos)
         bible = {}
         while versePos > 0:
             verseText = '' # clear out string
             versePos = xml_string.find(u'<B><I>', versePos) + 6
-            i = xml_string.find(u'</I></B>', versePos) 
+            i = xml_string.find(u'</I></B>', versePos)
             #log.debug( versePos, i)
             verse= xml_string[versePos:i] # Got the Chapter
             #verse = int(temp)
-            #log.debug( 'Chapter = ' + str(temp))
+            #log.debug( 'Chapter = ' + unicode(temp))
             versePos = i + 8     # move the starting position to negining of the text
             i = xml_string.find(u'<B><I>', versePos) # fine the start of the next verse
             if i == -1:
@@ -148,14 +146,14 @@
                 versePos = i
             bible[verse] = self._clean_text(verseText)
             #bible[verse] = verseText
-            
+
         #log.debug( bible)
         return SearchResults(book_title, book_chapter, bible)
-        
+
 class BibleHTTPImpl():
-    global log 
+    global log
     log=logging.getLogger(u'BibleHTTPMgr')
-    log.info(u'BibleHTTP manager loaded') 
+    log.info(u'BibleHTTP manager loaded')
     def __init__(self):
         """
         Finds all the bibles defined for the system
@@ -168,43 +166,41 @@
         biblesource = ''
         proxyurl = None
         bibleid = None
-        
+
     def set_proxy(self,proxyurl):
         """
         Set the Proxy Url
         """
-        log.debug(u"set_proxy %s", proxyurl)        
-        self.proxyurl = proxyurl 
-        
+        log.debug(u'set_proxy %s', proxyurl)
+        self.proxyurl = proxyurl
+
     def set_bibleid(self,bibleid):
         """
         Set the bible id.
         The shore identifier of the the bible.
         """
-        log.debug(u"set_bibleid  %s", bibleid)        
-        self.bibleid = bibleid 
- 
+        log.debug(u'set_bibleid %s', bibleid)
+        self.bibleid = bibleid
+
     def set_bible_source(self,biblesource):
         """
         Set the source of where the bible text is coming from
         """
-        log.debug(u"set_bible_source %s", biblesource)        
+        log.debug(u'set_bible_source %s', biblesource)
         self.biblesource = biblesource
 
     def get_bible_chapter(self, version, bookid, bookname,  chapter):
         """
         Receive the request and call the relevant handler methods
         """
-        log.debug(u"get_bible_chapter %s,%s,%s,%s", version, bookid, bookname,  chapter) 
-        log.debug(u"biblesource = %s", self.biblesource)
+        log.debug(u'get_bible_chapter %s,%s,%s,%s', version, bookid, bookname,  chapter)
+        log.debug(u'biblesource = %s', self.biblesource)
         try:
             if self.biblesource.lower() == u'crosswalk':
                 ev = CWExtract(self.proxyurl)
             else:
                 ev = BGExtract(self.proxyurl)
-                
+
             return ev.get_bible_chapter(self.bibleid, bookid, bookname,  chapter)
         except:
-            log.error(u"Error thrown = %s", sys.exc_info()[1])
-
-
+            log.error(u'Error thrown = %s', sys.exc_info()[1])

=== modified file 'openlp/plugins/bibles/lib/bibleOSISimpl.py'
--- openlp/plugins/bibles/lib/bibleOSISimpl.py	2009-06-04 20:06:32 +0000
+++ openlp/plugins/bibles/lib/bibleOSISimpl.py	2009-06-17 05:11:16 +0000
@@ -24,29 +24,31 @@
 
 class BibleOSISImpl():
     global log
-    log=logging.getLogger(u'BibleOSISImpl')
+    log = logging.getLogger(u'BibleOSISImpl')
     log.info(u'BibleOSISImpl loaded')
 
     def __init__(self, biblepath, bibledb):
         self.bibledb = bibledb
-        self.booksOfBible = {} # books of the bible linked to bibleid  {osis , name}
-        self.abbrevOfBible = {} # books of the bible linked to bibleid  {osis ,Abbrev }
+        # books of the bible linked to bibleid  {osis , name}
+        self.booksOfBible = {}
+        # books of the bible linked to bibleid  {osis ,Abbrev }
+        self.abbrevOfBible = {}
 
         filepath = os.path.split(os.path.abspath(__file__))[0]
-        filepath = os.path.abspath(os.path.join(filepath, '..', 'resources','osisbooks.csv'))
-        fbibles=open(filepath, 'r')
+        filepath = os.path.abspath(os.path.join(filepath, u'..', u'resources',u'osisbooks.csv'))
+        fbibles=open(filepath, u'r')
         for line in fbibles:
-            p = line.split(",")
-            self.booksOfBible[p[0]] = p[1].replace('\n', '')
-            self.abbrevOfBible[p[0]] = p[2].replace('\n', '')
+            p = line.split(u',')
+            self.booksOfBible[p[0]] = p[1].replace(u'\n', u'')
+            self.abbrevOfBible[p[0]] = p[2].replace(u'\n', u'')
         self.loadbible = True
-        QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL("openlpstopimport"),self.stop_import)
+        QtCore.QObject.connect(Receiver().get_receiver(),QtCore.SIGNAL(u'openlpstopimport'),self.stop_import)
 
     def stop_import(self):
         self.loadbible= False
 
     def load_data(self, osisfile, dialogobject=None):
-        osis=open(osisfile, 'r')
+        osis=open(osisfile, u'r')
 
         book_ptr = None
         id = 0
@@ -60,19 +62,21 @@
 #            print file
             pos = file.find(verseText)
             if pos > -1: # we have a verse
-                epos= file.find(">", pos)
+                epos= file.find(u'>', pos)
                 ref =  file[pos+15:epos-1]  # Book Reference
 
                 #lets find the bible text only
-                pos = epos + 1 # find start of text
-                epos = file.find("</verse>", pos) # end  of text
+                # find start of text
+                pos = epos + 1
+                # end  of text
+                epos = file.find(u'</verse>', pos)
                 text = unicode(file[pos : epos], u'utf8')
                 #print pos, e, f[pos:e] # Found Basic Text
 
                 #remove tags of extra information
-                text = self.remove_block(u'<title',u'</title>', text)
-                text = self.remove_block(u'<note',u'</note>', text)
-                text = self.remove_block(u'<divineName',u'</divineName>', text)
+                text = self.remove_block(u'<title', u'</title>', text)
+                text = self.remove_block(u'<note', u'</note>', text)
+                text = self.remove_block(u'<divineName', u'</divineName>', text)
 
                 text = self.remove_tag(u'<lb',  text)
                 text = self.remove_tag(u'<q',  text)
@@ -103,22 +107,26 @@
                 #print p, ">>>", text
 
                 if book_ptr != p[0]:
-                    if book_ptr == None:  # first time through
-                        if p[0]  == u'Gen':  # set the max book size depending on the first book read
+                    # first time through
+                    if book_ptr == None:
+                        # set the max book size depending on the first book read
+                        if p[0]  == u'Gen':
                             dialogobject.setMax(65)
                         else:
                             dialogobject.setMax(27)
-                    if  p[0] == u'Matt': # First book of NT
+                    # First book of NT
+                    if  p[0] == u'Matt':
                         testament += 1
                     book_ptr = p[0]
                     book = self.bibledb.create_book(self.booksOfBible[p[0]] , self.abbrevOfBible[p[0]], testament)
                     dialogobject.incrementProgressBar(self.booksOfBible[p[0]] )
-                    Receiver().send_message("openlpprocessevents")
+                    Receiver().send_message(u'openlpprocessevents')
                     count = 0
                 self.bibledb.add_verse(book.id, p[1], p[2], text)
                 count += 1
-                if count % 3 == 0:   #Every 3 verses repaint the screen
-                    Receiver().send_message("openlpprocessevents")
+                #Every 3 verses repaint the screen
+                if count % 3 == 0:
+                    Receiver().send_message(u'openlpprocessevents')
                     count = 0
 
     def remove_block(self, start_tag, end_tag,  text):
@@ -129,7 +137,7 @@
         pos = text.find(start_tag)
         while pos > -1:
             epos = text.find(end_tag, pos)
-            if epos == -1: # TODO
+            if epos == -1:
                 #print "Y", pos, epos
                 pos = -1
             else:

=== modified file 'openlp/plugins/bibles/lib/biblestab.py'
--- openlp/plugins/bibles/lib/biblestab.py	2009-06-08 05:04:06 +0000
+++ openlp/plugins/bibles/lib/biblestab.py	2009-06-16 18:21:24 +0000
@@ -70,7 +70,7 @@
         self.VerseTypeLayout.addWidget(self.ParagraphRadioButton)
         self.VerseDisplayLayout.addWidget(self.VerseTypeWidget, 0, 0, 1, 1)
         self.NewChaptersCheckBox = QtGui.QCheckBox(self.VerseDisplayGroupBox)
-        self.NewChaptersCheckBox.setObjectName("NewChaptersCheckBox")
+        self.NewChaptersCheckBox.setObjectName(u'NewChaptersCheckBox')
         self.VerseDisplayLayout.addWidget(self.NewChaptersCheckBox, 1, 0, 1, 1)
         self.DisplayStyleWidget = QtGui.QWidget(self.VerseDisplayGroupBox)
         self.DisplayStyleWidget.setObjectName(u'DisplayStyleWidget')
@@ -201,11 +201,11 @@
         self.BibleSearchCheckBox.setChecked(self.bible_search)
 
     def save(self):
-        self.config.set_config(u'paragraph style', str(self.paragraph_style))
-        self.config.set_config(u'display new chapter', str(self.show_new_chapters))
-        self.config.set_config(u'display brackets', str(self.display_style))
-        self.config.set_config(u'search as type', str(self.bible_search))
-        self.config.set_config(u'bible theme', str(self.bible_theme))
+        self.config.set_config(u'paragraph style', unicode(self.paragraph_style))
+        self.config.set_config(u'display new chapter', unicode(self.show_new_chapters))
+        self.config.set_config(u'display brackets', unicode(self.display_style))
+        self.config.set_config(u'search as type', unicode(self.bible_search))
+        self.config.set_config(u'bible theme', unicode(self.bible_theme))
 
     def updateThemeList(self, theme_list):
         """
@@ -215,9 +215,9 @@
         self.BibleThemeComboBox.addItem(u'')
         for theme in theme_list:
             self.BibleThemeComboBox.addItem(theme)
-        id = self.BibleThemeComboBox.findText(str(self.bible_theme), QtCore.Qt.MatchExactly)
+        id = self.BibleThemeComboBox.findText(unicode(self.bible_theme), QtCore.Qt.MatchExactly)
         if id == -1:
             # Not Found
             id = 0
             self.bible_theme = u''
-        self.BibleThemeComboBox.setCurrentIndex(id)
+        self.BibleThemeComboBox.setCurrentIndex(id)
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/lib/common.py'
--- openlp/plugins/bibles/lib/common.py	2009-02-24 20:24:01 +0000
+++ openlp/plugins/bibles/lib/common.py	2009-06-16 18:21:24 +0000
@@ -15,7 +15,6 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
 import os
 import os.path
 import sys
@@ -42,13 +41,13 @@
 
 class BibleCommon:
     global log
-    log=logging.getLogger("BibleCommon")
-    log.info("BibleCommon")
+    log = logging.getLogger(u'BibleCommon')
+    log.info(u'BibleCommon')
     def __init__(self):
         """
         """
     def _get_web_text(self, urlstring, proxyurl):
-        log.debug( "get_web_text %s %s", proxyurl, urlstring)
+        log.debug(u'get_web_text %s %s', proxyurl, urlstring)
         if  not proxyurl == None:
             proxy_support = urllib2.ProxyHandler({'http':  self.proxyurl})
             http_support = urllib2.HTTPHandler()
@@ -56,13 +55,13 @@
             urllib2.install_opener(opener)
         xml_string = ""
         req = urllib2.Request(urlstring)
-        req.add_header('User-Agent', 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)')
+        req.add_header(u'User-Agent', 'Mozilla/4.0 (compatible; MSIE 5.5; Windows NT)')
         try:
             handle = urllib2.urlopen(req)
             xml_string = handle.read()
         except IOError, e:
-            if hasattr(e, 'reason'):
-                log.error( 'Reason : ')
+            if hasattr(e, u'reason'):
+                log.error(u'Reason : ')
                 log.error( e.reason)
         return xml_string
 
@@ -73,42 +72,40 @@
         """
         #return text.rstrip()
         # Remove Headings from the Text
-        i = text.find("<h")
+        i = text.find(u'<h')
         while i > -1:
-            j=text.find("</h", i)
+            j=text.find(u'</h', i)
             text = text[ : (i - 1)]+text[(j+4)]
-            i = text.find("<h")
+            i = text.find(u'<h')
 
         # Remove Support References from the Text
-        x = text.find("<sup>")
+        x = text.find(u'<sup>')
         while x > -1:
-            y = text.find("</sup>")
+            y = text.find(u'</sup>')
             text= text[:x] + text[y + 6:len(text)]
-            x = text.find("<sup>")
+            x = text.find(u'<sup>')
 
         # Static Clean ups
-        text= text.replace('\n', '')
-        text= text.replace('\r', '')
-        text= text.replace('&nbsp;', '')
-        text= text.replace('<P>', '')
-        text= text.replace('<I>', '')
-        text= text.replace('</I>', '')
-        text= text.replace('<P />', '')
-        text= text.replace('<p />', '')
-        text= text.replace('</P>', '')
-        text= text.replace('<BR>', '')
-        text= text.replace('<BR />', '')
-        text= text.replace(chr(189), '1/2')
-        text= text.replace("&quot;", '"')
-        text= text.replace("&apos;", "'")
+        text= text.replace(u'\n', u'')
+        text= text.replace(u'\r', u'')
+        text= text.replace(u'&nbsp;', u'')
+        text= text.replace(u'<P>', u'')
+        text= text.replace(u'<I>', u'')
+        text= text.replace(u'</I>', u'')
+        text= text.replace(u'<P />', u'')
+        text= text.replace(u'<p />', u'')
+        text= text.replace(u'</P>', u'')
+        text= text.replace(u'<BR>', u'')
+        text= text.replace(u'<BR />', u'')
+        text= text.replace(chr(189), u'1/2')
+        text= text.replace(u'&quot;", u''')
+        text= text.replace(u'&apos;", u''')
 
-        i = text.find("<")
+        i = text.find(u'<')
         while i > -1 :
-            j = text.find(">", i)
+            j = text.find(u'>', i)
             text= text[:i] + text[j+1:]
-            i = text.find("<")
+            i = text.find(u'<')
 
-        text= text.replace('>', '')
+        text= text.replace(u'>', u'')
         return text.rstrip()
-
-

=== modified file 'openlp/plugins/bibles/lib/manager.py'
--- openlp/plugins/bibles/lib/manager.py	2009-06-05 05:00:26 +0000
+++ openlp/plugins/bibles/lib/manager.py	2009-06-16 18:21:24 +0000
@@ -17,7 +17,7 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
+import logging
 import os, os.path
 import sys
 
@@ -29,13 +29,10 @@
 from openlp.plugins.bibles.lib.tables import *
 from openlp.plugins.bibles.lib.classes import *
 
-
-import logging
-
 class BibleManager():
     global log
-    log=logging.getLogger("BibleManager")
-    log.info("Bible manager loaded")
+    log=logging.getLogger(u'BibleManager')
+    log.info(u'Bible manager loaded')
     def __init__(self, config):
         """
         Finds all the bibles defined for the system
@@ -45,21 +42,21 @@
         Init confirms the bible exists and stores the database path.
         """
         self.config = config
-        log.debug( "Bible Initialising")
+        log.debug(u'Bible Initialising')
         self.bible_db_cache = None   # dict of bible database classes
         self.bible_http_cache  = None # dict of bible http readers
         self.biblePath = self.config.get_data_path()
-        self.proxyname = self.config.get_config("proxy name") #get proxy name for screen
-        self.bibleSuffix = "sqlite"
+        self.proxyname = self.config.get_config(u'proxy name') #get proxy name for screen
+        self.bibleSuffix = u'sqlite'
         self.dialogobject = None
 
         self.reload_bibles()
 
     def reload_bibles(self):
-        log.debug("Reload bibles")
+        log.debug(u'Reload bibles')
 
         files = self.config.get_files(self.bibleSuffix)
-        log.debug("Bible Files %s",  files )
+        log.debug(u'Bible Files %s',  files )
 
         self.bible_db_cache = {}
         self.bible_http_cache  = {}
@@ -70,21 +67,21 @@
 
 
         for f in files:
-            nme = f.split('.')
+            nme = f.split(u'.')
             bname = nme[0]
             self.bible_db_cache[bname] = BibleDBImpl(self.biblePath, bname, self.config)
-            biblesource = self.bible_db_cache[bname].get_meta("WEB") # look to see if lazy load bible exists and get create getter.
+            biblesource = self.bible_db_cache[bname].get_meta(u'WEB') # look to see if lazy load bible exists and get create getter.
             if biblesource:
                 self.web_bibles_present  = True
                 nhttp = BibleHTTPImpl()
                 nhttp.set_bible_source(biblesource.value)  # tell The Server where to get the verses from.
                 self.bible_http_cache [bname] = nhttp
-                meta = self.bible_db_cache[bname].get_meta("proxy") # look to see if lazy load bible exists and get create getter.
+                meta = self.bible_db_cache[bname].get_meta(u'proxy') # look to see if lazy load bible exists and get create getter.
                 proxy = None
                 if meta != None:
                     proxy = meta.value
                 nhttp.set_proxy(proxy)  # tell The Server where to get the verses from.
-                bibleid = self.bible_db_cache[bname].get_meta("bibleid").value # look to see if lazy load bible exists and get create getter.
+                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_bibleid(bibleid)  # tell The Server where to get the verses from.
             else:
                 self.bible_http_cache [bname] = None # makes the Full / partial code easier.
@@ -94,13 +91,13 @@
                 self.book_abbreviations = {} # books of the bible linked to bibleid  {osis ,Abbrev }
 
                 filepath = os.path.split(os.path.abspath(__file__))[0]
-                filepath = os.path.abspath(os.path.join(filepath, '..', 'resources','httpbooks.csv'))
+                filepath = os.path.abspath(os.path.join(filepath, u'..', u'resources',u'httpbooks.csv'))
                 fbibles=open(filepath, 'r')
                 for line in fbibles:
-                    p = line.split(",")
-                    self.book_abbreviations[p[0]] = p[1].replace('\n', '')
-                    self.book_testaments[p[0]] = p[2].replace('\n', '')
-        log.debug( "Bible Initialised")
+                    p = line.split(u',')
+                    self.book_abbreviations[p[0]] = p[1].replace(u'\n', '')
+                    self.book_testaments[p[0]] = p[2].replace(u'\n', '')
+        log.debug(u'Bible Initialised')
 
     def process_dialog(self, dialogobject):
         self.dialogobject = dialogobject
@@ -110,7 +107,7 @@
         Return a list of bibles from a given URL.
         The selected Bible can then be registered and LazyLoaded into a database
         """
-        log.debug( "register_HTTP_bible %s,%s,%s,%s,%s,%s", biblename, biblesource, bibleid, proxyurl,  proxyid, proxypass)
+        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
@@ -119,18 +116,18 @@
             nhttp = BibleHTTPImpl()
             nhttp.set_bible_source(biblesource)
             self.bible_http_cache [biblename] = nhttp
-            nbible.save_meta("WEB", biblesource) # register a lazy loading interest
-            nbible.save_meta("bibleid", bibleid) # store the we id of the bible
+            nbible.save_meta(u'WEB', biblesource) # register a lazy loading interest
+            nbible.save_meta(u'bibleid', bibleid) # store the we id of the bible
             if proxyurl != None and proxyurl != "":
-                nbible.save_meta("proxy", proxyurl) # store the proxy URL
+                nbible.save_meta(u'proxy', proxyurl) # store the proxy URL
                 nhttp.set_proxy(proxyurl)
             if proxyid != None and proxyid != "":
-                nbible.save_meta("proxyid", proxyid) # store the proxy userid
+                nbible.save_meta(u'proxyid', proxyid) # store the proxy userid
             if proxypass != None and proxypass != "":
-                nbible.save_meta("proxypass", proxypass) # store the proxy password
+                nbible.save_meta(u'proxypass', proxypass) # store the proxy password
             return True
         else:
-            log.debug( "register_http_file_bible %s not created already exists", biblename)
+            log.debug(u'register_http_file_bible %s not created already exists', biblename)
             return False
 
     def register_csv_file_bible(self, biblename, booksfile, versefile):
@@ -139,7 +136,7 @@
         If the database exists it is deleted and the database is reloaded
         from scratch.
         """
-        log.debug( "register_CSV_file_bible %s,%s,%s", biblename, booksfile, versefile)
+        log.debug(u'register_CSV_file_bible %s,%s,%s', biblename, booksfile, versefile)
         if self._is_new_bible(biblename):
             nbible = BibleDBImpl(self.biblePath, biblename, self.config) # Create new Bible
             nbible.create_tables() # Create Database
@@ -148,7 +145,7 @@
             bcsv.load_data(booksfile, versefile, self.dialogobject)
             return True
         else:
-            log.debug( "register_csv_file_bible %s not created already exists", biblename)
+            log.debug(u'register_csv_file_bible %s not created already exists', biblename)
             return False
 
     def register_osis_file_bible(self, biblename, osisfile):
@@ -157,7 +154,7 @@
         If the database exists it is deleted and the database is reloaded
         from scratch.
         """
-        log.debug( "register_OSIS_file_bible %s , %s", biblename, osisfile)
+        log.debug(u'register_OSIS_file_bible %s , %s', biblename, osisfile)
         if self._is_new_bible(biblename):
             nbible = BibleDBImpl(self.biblePath, biblename, self.config) # Create new Bible
             nbible.create_tables() # Create Database
@@ -166,11 +163,11 @@
             bcsv.load_data(osisfile, self.dialogobject)
             return True
         else:
-            log.debug( "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
 
-    def get_bibles(self, mode="full"):
-        log.debug("get_bibles")
+    def get_bibles(self, mode=u'full'):
+        log.debug(u'get_bibles')
         """
         Returns a list of Books of the bible
         Mode "Full" - Returns all the bibles for the Queck seearch
@@ -178,7 +175,7 @@
         """
         r=[]
         for b ,  o in self.bible_db_cache.iteritems():
-            if mode == "full":
+            if mode == u'full':
                 r.append(b)
             else:
                 if self.bible_http_cache [b] == None:  # we do not have an http bible
@@ -189,14 +186,14 @@
         """
         Returns a list of the books of the bible from the database
         """
-        log.debug("get_bible_books %s", bible)
+        log.debug(u'get_bible_books %s', bible)
         return self.bible_db_cache[bible].get_bible_books()
 
     def get_book_chapter_count(self, bible,  book):
         """
         Returns the number of Chapters for a given book
         """
-        log.debug( "get_book_chapter_count %s,%s", bible, book)
+        log.debug(u'get_book_chapter_count %s,%s', bible, book)
         return self.bible_db_cache[bible].get_max_bible_book_chapter(book)
 
     def get_book_verse_count(self, bible, book, chapter):
@@ -204,7 +201,7 @@
         Returns all the number of verses for a given
         book and chapterMaxBibleBookVerses
         """
-        log.debug( "get_book_verse_count %s,%s,%s", bible, book,  chapter)
+        log.debug(u'get_book_verse_count %s,%s,%s', bible, book,  chapter)
         return self.bible_db_cache[bible].get_max_bible_book_verses(book, chapter)
 
     def get_verse_from_text(self, bible, versetext):
@@ -212,23 +209,23 @@
         Returns all the number of verses for a given
         book and chapterMaxBibleBookVerses
         """
-        log.debug( "get_verses_from_text %s,%s", bible, versetext)
+        log.debug(u'get_verses_from_text %s,%s', bible, versetext)
         return self.bible_db_cache[bible].get_verses_from_text(versetext)
 
     def save_meta_data(self, bible, version, copyright, permissions):
         """
         Saves the bibles meta data
         """
-        log.debug( "save_meta data %s,%s, %s,%s", bible,  version, copyright, permissions)
-        self.bible_db_cache[bible].save_meta("Version", version)
-        self.bible_db_cache[bible].save_meta("Copyright", copyright)
-        self.bible_db_cache[bible].save_meta("Permissions", permissions)
+        log.debug(u'save_meta data %s,%s, %s,%s', bible,  version, copyright, permissions)
+        self.bible_db_cache[bible].save_meta(u'Version', version)
+        self.bible_db_cache[bible].save_meta(u'Copyright', copyright)
+        self.bible_db_cache[bible].save_meta(u'Permissions', permissions)
 
     def get_meta_data(self, bible, key):
         """
         Returns the meta data for a given key
         """
-        log.debug( "get_meta %s,%s", bible,  key)
+        log.debug(u'get_meta %s,%s', bible,  key)
         return self.bible_db_cache[bible].get_meta(key)
 
     def get_verse_text(self, bible, bookname, schapter, echapter, sverse, everse = 0 ):
@@ -240,11 +237,11 @@
         Rest can be guessed at !
         """
         text  = []
-        log.debug( "get_verse_text %s,%s,%s,%s,%s,%s",  bible, bookname,  schapter, echapter, sverse, everse)
+        log.debug(u'get_verse_text %s,%s,%s,%s,%s,%s',  bible, bookname,  schapter, echapter, sverse, everse)
         if not self.bible_http_cache [bible] == None:
             book= self.bible_db_cache[bible].get_bible_book(bookname) # check to see if book/chapter exists
             if book == None:
-                log.debug("get_verse_text : new book")
+                log.debug(u'get_verse_text : new book')
                 for chapter in range(schapter, echapter+1):
                     search_results = self.bible_http_cache [bible].get_bible_chapter(bible, 0, bookname, chapter)
                     if search_results.has_verselist() :
@@ -258,7 +255,7 @@
                             book = self.bible_db_cache[bible].create_book(bookname, \
                                                                           self.book_abbreviations[bookname],  \
                                                                           self.book_testaments[bookname])
-                            log.debug("New http book %s , %s, %s",  book, book.id, book.name)
+                            log.debug(u'New http book %s , %s, %s',  book, book.id, book.name)
                             self.bible_db_cache[bible].create_chapter(book.id, \
                                                                       search_results.get_chapter(),\
                                                                       search_results.get_verselist())
@@ -270,7 +267,7 @@
                                                                           chapter, \
                                                                           search_results.get_verselist())
             else:
-                log.debug("get_verse_text : old book")
+                log.debug(u'get_verse_text : old book')
                 for chapter in range(schapter, echapter+1):
                     v = self.bible_db_cache[bible].get_bible_chapter(book.id, chapter)
                     if v == None:
@@ -280,7 +277,7 @@
                                                                       search_results.get_chapter(),\
                                                                       search_results.get_verselist())
                         except :
-                            log.error("Errow thrown %s", sys.exc_info()[1])
+                            log.error(u'Errow thrown %s', sys.exc_info()[1])
 
         if schapter == echapter:
             text = self.bible_db_cache[bible].get_bible_text(bookname, schapter, sverse, everse)
@@ -305,7 +302,7 @@
         Check cache to see if new bible
         """
         for b ,  o in self.bible_db_cache.iteritems():
-            log.debug( "Bible from cache in is_new_bible %s", b )
+            log.debug(u'Bible from cache in is_new_bible %s', b )
             if b == name :
                 return False
         return True

=== modified file 'openlp/plugins/bibles/lib/mediaitem.py'
--- openlp/plugins/bibles/lib/mediaitem.py	2009-06-08 05:04:06 +0000
+++ openlp/plugins/bibles/lib/mediaitem.py	2009-06-17 05:11:16 +0000
@@ -23,9 +23,8 @@
 
 from openlp.core.lib import ServiceItem, MediaManagerItem, Receiver, translate
 from openlp.plugins.bibles.forms import BibleImportForm
-from openlp.plugins.bibles.lib import TextListData
 
-class BibleList(QtGui.QListView):
+class BibleList(QtGui.QListWidget):
 
     def __init__(self,parent=None,name=None):
         QtGui.QListView.__init__(self,parent)
@@ -189,13 +188,11 @@
         self.SearchTabWidget.addTab(self.AdvancedTab, u'Advanced')
         # Add the search tab widget to the page layout
         self.PageLayout.addWidget(self.SearchTabWidget)
-        self.BibleListView = BibleList()
-        self.BibleListView.setAlternatingRowColors(True)
-        self.BibleListData = TextListData()
-        self.BibleListView.setModel(self.BibleListData)
-        self.BibleListView.setSelectionMode(QtGui.QAbstractItemView.ExtendedSelection)
-        self.BibleListView.setDragEnabled(True)
-        self.PageLayout.addWidget(self.BibleListView)
+        self.BibleListWidget = BibleList()
+        self.BibleListWidget.setAlternatingRowColors(True)
+        self.BibleListWidget.setSelectionMode(QtGui.QAbstractItemView.ExtendedSelection)
+        self.BibleListWidget.setDragEnabled(True)
+        self.PageLayout.addWidget(self.BibleListWidget)
         # Combo Boxes
         QtCore.QObject.connect(self.AdvancedVersionComboBox,
             QtCore.SIGNAL(u'activated(int)'), self.onAdvancedVersionComboBox)
@@ -212,18 +209,18 @@
             QtCore.SIGNAL(u'pressed()'), self.onAdvancedSearchButton)
         QtCore.QObject.connect(self.QuickSearchButton,
             QtCore.SIGNAL(u'pressed()'), self.onQuickSearchButton)
-        QtCore.QObject.connect(self.BibleListView,
+        QtCore.QObject.connect(self.BibleListWidget,
             QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), self.onBiblePreviewClick)
         # Context Menus
-        self.BibleListView.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
-        self.BibleListView.addAction(self.contextMenuAction(
-            self.BibleListView, u':/system/system_preview.png',
+        self.BibleListWidget.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
+        self.BibleListWidget.addAction(self.contextMenuAction(
+            self.BibleListWidget, u':/system/system_preview.png',
             translate(u'BibleMediaItem',u'&Preview Verse'), self.onBiblePreviewClick))
-        self.BibleListView.addAction(self.contextMenuAction(
-            self.BibleListView, u':/system/system_live.png',
+        self.BibleListWidget.addAction(self.contextMenuAction(
+            self.BibleListWidget, u':/system/system_live.png',
             translate(u'BibleMediaItem',u'&Show Live'), self.onBibleLiveClick))
-        self.BibleListView.addAction(self.contextMenuAction(
-            self.BibleListView, u':/system/system_add.png',
+        self.BibleListWidget.addAction(self.contextMenuAction(
+            self.BibleListWidget, u':/system/system_add.png',
             translate(u'BibleMediaItem',u'&Add to Service'), self.onBibleAddClick))
 
     def retranslateUi(self):
@@ -272,11 +269,11 @@
                 self.initialiseBible(bible)
 
     def onAdvancedVersionComboBox(self):
-        self.initialiseBible(str(self.AdvancedVersionComboBox.currentText()))
+        self.initialiseBible(unicode(self.AdvancedVersionComboBox.currentText()))
 
     def onAdvancedBookComboBox(self):
-        self.initialiseChapterVerse(str(self.AdvancedVersionComboBox.currentText()),
-            str(self.AdvancedBookComboBox.currentText()))
+        self.initialiseChapterVerse(unicode(self.AdvancedVersionComboBox.currentText()),
+            unicode(self.AdvancedBookComboBox.currentText()))
 
     def onBibleNewClick(self):
         self.bibleimportform = BibleImportForm(self.parent.config, self.parent.biblemanager, self)
@@ -291,15 +288,16 @@
         t1 =  self.AdvancedFromChapter.currentText()
         t2 =  self.AdvancedToChapter.currentText()
         if t1 != t2:
-            bible = str(self.AdvancedVersionComboBox.currentText())
-            book = str(self.AdvancedBookComboBox.currentText())
-            vse = self.parent.biblemanager.get_book_verse_count(bible, book, int(t2))[0] # get the verse count for new chapter
+            bible = unicode(self.AdvancedVersionComboBox.currentText())
+            book = unicode(self.AdvancedBookComboBox.currentText())
+            # get the verse count for new chapter
+            vse = self.parent.biblemanager.get_book_verse_count(bible, book, int(t2))[0]
             self.adjustComboBox(1, vse, self.AdvancedToVerse)
 
     def onAdvancedSearchButton(self):
         log.debug(u'Advanced Search Button pressed')
-        bible = str(self.AdvancedVersionComboBox.currentText())
-        book = str(self.AdvancedBookComboBox.currentText())
+        bible = unicode(self.AdvancedVersionComboBox.currentText())
+        book = unicode(self.AdvancedBookComboBox.currentText())
         chapter_from =  int(self.AdvancedFromChapter.currentText())
         chapter_to =  int(self.AdvancedToChapter.currentText())
         verse_from =  int(self.AdvancedFromVerse.currentText())
@@ -307,29 +305,30 @@
         self.search_results = self.parent.biblemanager.get_verse_text(bible, book,
             chapter_from, chapter_to, verse_from, verse_to)
         if self.ClearAdvancedSearchComboBox.currentIndex() == 0:
-            self.BibleListData.resetStore()
-            self.displayResults(bible)
+            self.BibleListWidget.clear()
+        self.displayResults(bible)
 
     def onAdvancedFromChapter(self):
-        bible = str(self.AdvancedVersionComboBox.currentText())
-        book = str(self.AdvancedBookComboBox.currentText())
+        bible = unicode(self.AdvancedVersionComboBox.currentText())
+        book = unicode(self.AdvancedBookComboBox.currentText())
         cf = self.AdvancedFromChapter.currentText()
         self.adjustComboBox(cf, self.chapters_from, self.AdvancedToChapter)
-        vse = self.parent.biblemanager.get_book_verse_count(bible, book, int(cf))[0] # get the verse count for new chapter
+        # get the verse count for new chapter
+        vse = self.parent.biblemanager.get_book_verse_count(bible, book, int(cf))[0]
         self.adjustComboBox(1, vse, self.AdvancedFromVerse)
         self.adjustComboBox(1, vse, self.AdvancedToVerse)
 
     def onQuickSearchButton(self):
         log.debug(u'Quick Search Button pressed')
-        bible = str(self.QuickVersionComboBox.currentText())
-        text = str(self.QuickSearchEdit.displayText())
+        bible = unicode(self.QuickVersionComboBox.currentText())
+        text = unicode(self.QuickSearchEdit.displayText())
         if self.ClearQuickSearchComboBox.currentIndex() == 0:
-            self.BibleListData.resetStore()
+            self.BibleListWidget.clear()
         if self.QuickSearchComboBox.currentIndex() == 1:
             self.search_results = self.parent.biblemanager.get_verse_from_text(bible, text)
         else:
             self.searchByReference(bible, text)
-        if not self.search_results == None:
+        if self.search_results is not None:
             self.displayResults(bible)
 
     def onBibleLiveClick(self):
@@ -352,24 +351,25 @@
 
     def generateSlideData(self, service_item):
         log.debug(u'generating slide data')
-        items = self.BibleListView.selectedIndexes()
+        items = self.BibleListWidget.selectedIndexes()
         old_chapter = u''
         raw_slides=[]
         raw_footer = []
         bible_text = u''
         for item in items:
-            text = self.BibleListData.getValue(item)
+            bitem =  self.BibleListWidget.item(item.row())
+            text = unicode((bitem.data(QtCore.Qt.UserRole)).toString())
             verse = text[:text.find(u'(')]
             bible = text[text.find(u'(') + 1:text.find(u')')]
             self.searchByReference(bible, verse)
             book = self.search_results[0][0]
-            chapter = str(self.search_results[0][1])
-            verse = str(self.search_results[0][2])
+            chapter = unicode(self.search_results[0][1])
+            verse = unicode(self.search_results[0][2])
             text = self.search_results[0][3]
             if self.parent.bibles_tab.paragraph_style: #Paragraph
                 text = text + u'\n\n'
             if self.parent.bibles_tab.display_style == 1:
-                loc = self.formatVerse(old_chapter, chapter, verse, u'(', u')')
+                loc = self.formatVerse(old_chapter, chapter, verse, u'(u', u')')
             elif  self.parent.bibles_tab.display_style == 2:
                 loc = self.formatVerse(old_chapter, chapter, verse, u'{', u'}')
             elif  self.parent.bibles_tab.display_style == 3:
@@ -407,7 +407,7 @@
 
     def initialiseBible(self, bible):
         log.debug(u'initialiseBible %s', bible)
-        books = self.parent.biblemanager.get_bible_books(str(bible))
+        books = self.parent.biblemanager.get_bible_books(unicode(bible))
         self.AdvancedBookComboBox.clear()
         first = True
         for book in books:
@@ -429,12 +429,14 @@
         log.debug(u'adjustComboBox %s , %s , %s', combo, frm,  to)
         combo.clear()
         for i in range(int(frm), int(to) + 1):
-            combo.addItem(str(i))
+            combo.addItem(unicode(i))
 
     def displayResults(self, bible):
         for book, chap, vse , txt in self.search_results:
-            text = str(u' %s %d:%d (%s)'%(book , chap,vse, bible))
-            self.BibleListData.addRow(0,text)
+            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.BibleListWidget.addItem(bible_verse)
 
     def searchByReference(self, bible,  search):
         log.debug(u'searchByReference %s ,%s', bible, search)
@@ -496,8 +498,8 @@
                 else:
                     end_chapter = sp1[0]
                     end_verse = sp1[1]
-        #print 'search = ' + str(original)
-        #print 'results = ' + str(book) + ' @ '+ str(start_chapter)+' @ '+ str(end_chapter)+' @ '+ str(start_verse)+ ' @ '+ str(end_verse)
+        #print 'search = ' + unicode(original)
+        #print 'results = ' + unicode(book) + ' @ '+ unicode(start_chapter)+' @ '+ unicode(end_chapter)+' @ '+ unicode(start_verse)+ ' @ '+ unicode(end_verse)
         if end_chapter == '':
             end_chapter = start_chapter.rstrip()
         if start_verse == '':
@@ -509,9 +511,9 @@
             end_verse = 99
         if start_chapter == '':
             message = u'No chapter found for search'
-        #print 'message = ' + str(message)
-        #print 'search = ' + str(original)
-        #print 'results = ' + str(book) + ' @ '+ str(start_chapter)+' @ '+ str(end_chapter)+' @ '+ str(start_verse)+ ' @ '+ str(end_verse)
+        #print 'message = ' + unicode(message)
+        #print 'search = ' + unicode(original)
+        #print 'results = ' + unicode(book) + ' @ '+ unicode(start_chapter)+' @ '+ unicode(end_chapter)+' @ '+ unicode(start_verse)+ ' @ '+ unicode(end_verse)
         if message == None:
             self.search_results = None
             self.search_results = self.parent.biblemanager.get_verse_text(bible, book,

=== modified file 'openlp/plugins/bibles/lib/tables.py'
--- openlp/plugins/bibles/lib/tables.py	2009-02-22 07:44:08 +0000
+++ openlp/plugins/bibles/lib/tables.py	2009-06-16 18:21:24 +0000
@@ -22,31 +22,31 @@
 
 metadata = MetaData()
 #Define the tables and indexes
-meta_table = Table('metadata', metadata, 
-    Column('key', String(255), primary_key=True), 
-    Column('value', String(255)), 
+meta_table = Table(u'metadata', metadata, 
+    Column(u'key', String(255), primary_key=True), 
+    Column(u'value', String(255)), 
 )
 
-testament_table = Table('testament', metadata, 
-    Column('id', Integer, primary_key=True), 
-    Column('name', String(30)), 
+testament_table = Table(u'testament', metadata, 
+    Column(u'id', Integer, primary_key=True), 
+    Column(u'name', String(30)), 
 )
    
-book_table = Table('book', metadata, 
-    Column('id', Integer, primary_key=True), 
-    Column('testament_id', Integer, schema.ForeignKey('testament.id')), 
-    Column('name', String(30)), 
-    Column('abbreviation', String(5)), 
+book_table = Table(u'book', metadata, 
+    Column(u'id', Integer, primary_key=True), 
+    Column(u'testament_id', Integer, schema.ForeignKey(u'testament.id')), 
+    Column(u'name', String(30)), 
+    Column(u'abbreviation', String(5)), 
 )
-Index('idx_name', book_table.c.name, book_table.c.id)
-Index('idx_abbrev', book_table.c.abbreviation, book_table.c.id)
+Index(u'idx_name', book_table.c.name, book_table.c.id)
+Index(u'idx_abbrev', book_table.c.abbreviation, book_table.c.id)
 
-verse_table = Table('verse', metadata, 
-   Column('id', Integer, primary_key=True), 
-    Column('book_id', Integer , schema.ForeignKey('book.id')), 
-    Column('chapter', Integer), 
-    Column('verse', Integer), 
-    Column('text', Text), 
+verse_table = Table(u'verse', metadata, 
+   Column(u'id', Integer, primary_key=True), 
+    Column(u'book_id', Integer , schema.ForeignKey(u'book.id')), 
+    Column(u'chapter', Integer), 
+    Column(u'verse', Integer), 
+    Column(u'text', Text), 
 )
-Index('idx_chapter_verse_book', verse_table.c.chapter, verse_table.c.verse, verse_table.c.book_id, verse_table.c.id)
-Index('idx_chapter_verse_text', verse_table.c.text, verse_table.c.verse, verse_table.c.book_id, verse_table.c.id)
+Index(u'idx_chapter_verse_book', verse_table.c.chapter, verse_table.c.verse, verse_table.c.book_id, verse_table.c.id)
+Index(u'idx_chapter_verse_text', verse_table.c.text, verse_table.c.verse, verse_table.c.book_id, verse_table.c.id)
\ No newline at end of file

=== removed file 'openlp/plugins/bibles/lib/textlistdata.py'
--- openlp/plugins/bibles/lib/textlistdata.py	2009-06-07 18:39:31 +0000
+++ openlp/plugins/bibles/lib/textlistdata.py	1970-01-01 00:00:00 +0000
@@ -1,83 +0,0 @@
-# -*- coding: utf-8 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008-2009 Martin Thompson, Tim Bentley
-
-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
-"""
-import logging
-
-from PyQt4 import QtCore, QtGui
-
-
-class TextListData(QtCore.QAbstractListModel):
-    """
-    An abstract list of strings
-    """
-    global log
-    log = logging.getLogger(u'TextListData')
-    log.info(u'started')
-
-    def __init__(self):
-        QtCore.QAbstractListModel.__init__(self)
-        # will be a list of (database id , title) tuples
-        self.items = []
-
-    def resetStore(self):
-        #reset list so can be reloaded
-        self.items = []
-
-    def rowCount(self, parent):
-        return len(self.items)
-
-    def insertRow(self, row, id, title):
-        self.beginInsertRows(QtCore.QModelIndex(),row,row)
-        log.debug(u'insert row %d:%s for id %d' % (row,title, id))
-        self.items.insert(row, (id, title))
-        self.endInsertRows()
-
-    def removeRow(self, row):
-        self.beginRemoveRows(QModelIndex(), row,row)
-        self.items.pop(row)
-        self.endRemoveRows()
-
-    def addRow(self, id, title):
-        self.insertRow(len(self.items), id, title)
-
-    def data(self, index, role):
-        row = index.row()
-        # if the last row is selected and deleted, we then get called with an empty row!
-        if row > len(self.items):
-            return QtCore.QVariant()
-        if role == QtCore.Qt.DisplayRole:
-            retval = self.items[row][1]
-        else:
-            retval = QtCore.QVariant()
-        if type(retval) is not type(QtCore.QVariant):
-            return QtCore.QVariant(retval)
-        else:
-            return retval
-
-    def getIdList(self):
-        filelist = [item[0] for item in self.items];
-        return filelist
-
-    def getValue(self, index):
-        row = index.row()
-        return self.items[row][1]
-
-    def deleteRow(self, index):
-        row = index.row()
-        self.removeRow(row)

=== modified file 'openlp/plugins/bibles/test/test_bibleManager.py'
--- openlp/plugins/bibles/test/test_bibleManager.py	2009-01-10 08:33:31 +0000
+++ openlp/plugins/bibles/test/test_bibleManager.py	2009-06-16 18:21:24 +0000
@@ -36,25 +36,25 @@
 
 console=logging.StreamHandler()
 # set a format which is simpler for console use
-formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
+formatter = logging.Formatter(u'%(name)-12s: %(levelname)-8s %(message)s')
 # tell the handler to use this format
 console.setFormatter(formatter)
-logging.getLogger('').addHandler(console)
-log=logging.getLogger('')
+logging.getLogger(u'').addHandler(console)
+log=logging.getLogger(u'')
 
-logging.info("\nLogging started")
+logging.info(u'\nLogging started')
 
 class TestBibleManager:
-    log=logging.getLogger("testBibleMgr")
+    log=logging.getLogger(u'testBibleMgr')
     def setup_class(self):
-        log.debug("\n.......Register BM")
+        log.debug(u'\n.......Register BM')
         self.bm = BibleManager()
 
     def testRegisterCSVBibleFiles(self):
         # Register a bible from files
-        log.debug("\n.......testRegisterBibleFiles")
-        self.bm.registerFileBible("TheMessage",'biblebooks_msg_short.csv','bibleverses_msg_short.csv')
-        self.bm.registerFileBible("NIV",'biblebooks_niv_short.csv','bibleverses_niv_short.csv')        
+        log.debug(u'\n.......testRegisterBibleFiles')
+        self.bm.registerFileBible(u'TheMessage",'biblebooks_msg_short.csv','bibleverses_msg_short.csv')
+        self.bm.registerFileBible(u'NIV",'biblebooks_niv_short.csv','bibleverses_niv_short.csv')        
         b = self.bm.get_bibles()
         for b1 in b:
             log.debug( b1)
@@ -62,10 +62,10 @@
             
     def testRegisterHTTPBible(self):
         # Register a bible from files
-        log.debug( "\n.......testRegisterBibleHTTP")
-        self.bm.registerHTTPBible("asv","Crosswalk", "", "", "")
-        self.bm.registerHTTPBible("nasb","Biblegateway", "", "", "")
-        self.bm.registerHTTPBible("nkj","Biblegateway", "http://tigger2:3128/";, "", "")                
+        log.debug( "\n.......testRegisterBibleHTTP')
+        self.bm.registerHTTPBible(u'asv","Crosswalk", u'", u'", u'')
+        self.bm.registerHTTPBible(u'nasb","Biblegateway", u'", u'", u'')
+        self.bm.registerHTTPBible(u'nkj","Biblegateway", u'http://tigger2:3128/";, u'", u'')                
         b = self.bm.get_bibles()
         for b1 in b:
             log.debug( b1)
@@ -73,7 +73,7 @@
 
             
     def testGetBibles(self):
-        log.debug( "\n.......testGetBibles")
+        log.debug( "\n.......testGetBibles')
         # make sure the shuffled sequence does not lose any elements
         b = self.bm.get_bibles()
         for b1 in b:
@@ -81,38 +81,38 @@
             assert(b1 in b)
 
     def testGetBibleBooks(self):
-        log.debug( "\n.......testGetBibleBooks")
-        c = self.bm.get_bible_books("NIV")
+        log.debug( "\n.......testGetBibleBooks')
+        c = self.bm.get_bible_books(u'NIV')
         for c1 in c:
             log.debug( c1)
             assert(c1 in c)
             
     def testGetBookChapterCount(self):
-        log.debug( "\n.......testGetBookChapterCount")       
-        assert(self.bm.get_book_chapter_count("Matthew") == '28')
+        log.debug( "\n.......testGetBookChapterCount')       
+        assert(self.bm.get_book_chapter_count(u'Matthew') == '28')
 
     def testGetBookVerseCount(self):
-        log.debug( "\n.......testGetBookVerseCount")    
-        assert(self.bm.get_book_verse_count("Genesis", 1) == '31')
-        assert(self.bm.get_book_verse_count("Genesis", 2) == '25')
-        assert(self.bm.get_book_verse_count("Matthew", 1) == '25')
-        assert(self.bm.get_book_verse_count("Revelation", 1) == '20')        
+        log.debug( "\n.......testGetBookVerseCount')    
+        assert(self.bm.get_book_verse_count(u'Genesis", 1) == '31')
+        assert(self.bm.get_book_verse_count(u'Genesis", 2) == '25')
+        assert(self.bm.get_book_verse_count(u'Matthew", 1) == '25')
+        assert(self.bm.get_book_verse_count(u'Revelation", 1) == '20')        
 
     def testGetVerseText(self):
-        log.debug( "\n.......testGetVerseText")
-        #c = self.bm.get_verse_text("TheMessage",'Genesis',1,2,1)
+        log.debug( "\n.......testGetVerseText')
+        #c = self.bm.get_verse_text(u'TheMessage",'Genesis',1,2,1)
         #log.debug( c )
-        #c = self.bm.get_verse_text('NIV','Genesis',1,1,2)
+        #c = self.bm.get_verse_text(u'NIV','Genesis',1,1,2)
         #log.debug( c ) 
-        c = self.bm.get_verse_text('asv','Genesis',10,1,20)
+        c = self.bm.get_verse_text(u'asv','Genesis',10,1,20)
         log.debug( c )
-        c = self.bm.get_verse_text('nasb','Genesis',10,1,20)
+        c = self.bm.get_verse_text(u'nasb','Genesis',10,1,20)
         log.debug( c )       
-        c = self.bm.get_verse_text('nkj','Revelation',10,1,20)
+        c = self.bm.get_verse_text(u'nkj','Revelation',10,1,20)
         log.debug( c ) 
         
     def testLoadBible(self):
-        log.debug( "\n.......testLoadBible")
-        #self.bm.loadBible('asv')
-        #self.bm.loadBible('nasb')        
-        #self.bm.loadBible('nkj') 
+        log.debug( "\n.......testLoadBible')
+        #self.bm.loadBible(u'asv')
+        #self.bm.loadBible(u'nasb')        
+        #self.bm.loadBible(u'nkj') 
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/test/test_bibleManagerAPI.py'
--- openlp/plugins/bibles/test/test_bibleManagerAPI.py	2008-12-10 19:17:23 +0000
+++ openlp/plugins/bibles/test/test_bibleManagerAPI.py	2009-06-16 18:21:24 +0000
@@ -36,22 +36,22 @@
 
 console=logging.StreamHandler()
 # set a format which is simpler for console use
-formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
+formatter = logging.Formatter(u'%(name)-12s: %(levelname)-8s %(message)s')
 # tell the handler to use this format
 console.setFormatter(formatter)
-logging.getLogger('').addHandler(console)
-log=logging.getLogger('')
+logging.getLogger(u'').addHandler(console)
+log=logging.getLogger(u'')
 
-logging.info("\nLogging started")
+logging.info(u'\nLogging started')
 
 class TestBibleManager:
-    log=logging.getLogger("testBibleMgr")
+    log=logging.getLogger(u'testBibleMgr')
     def setup_class(self):
-        log.debug("\n.......Register BM")
+        log.debug(u'\n.......Register BM')
         self.bm = BibleManager()
            
     def testGetBibles(self):
-        log.debug( "\n.......testGetBibles")
+        log.debug( "\n.......testGetBibles')
         # make sure the shuffled sequence does not lose any elements
         b = self.bm.getBibles()
         for b1 in b:
@@ -59,37 +59,36 @@
             assert(b1 in b)
 
     def testGetBibleBooks(self):
-        log.debug( "\n.......testGetBibleBooks")
-        c = self.bm.getBibleBooks("asv")
+        log.debug( "\n.......testGetBibleBooks')
+        c = self.bm.getBibleBooks(u'asv')
         for c1 in c:
             log.debug( c1)
             assert(c1 in c)
             
     def testGetBookChapterCount(self):
-        log.debug( "\n.......testGetBookChapterCount")       
-        assert(self.bm.getBookChapterCount("asv","Matthew")[0] == 28)
+        log.debug( "\n.......testGetBookChapterCount')       
+        assert(self.bm.getBookChapterCount(u'asv","Matthew')[0] == 28)
 
     def testGetBookVerseCount(self):
-        log.debug( "\n.......testGetBookVerseCount")    
-        assert(self.bm.getBookVerseCount("asv","Genesis", 1)[0] == 31)
-        assert(self.bm.getBookVerseCount("TheMessage","Genesis", 2)[0] == 25)
-        assert(self.bm.getBookVerseCount("asv","Matthew", 1)[0] == 25)
-        assert(self.bm.getBookVerseCount("TheMessage","Revelation", 1)[0] == 20)        
+        log.debug( "\n.......testGetBookVerseCount')    
+        assert(self.bm.getBookVerseCount(u'asv","Genesis", 1)[0] == 31)
+        assert(self.bm.getBookVerseCount(u'TheMessage","Genesis", 2)[0] == 25)
+        assert(self.bm.getBookVerseCount(u'asv","Matthew", 1)[0] == 25)
+        assert(self.bm.getBookVerseCount(u'TheMessage","Revelation", 1)[0] == 20)        
 
     def testGetVerseText(self):
-        log.debug( "\n.......testGetVerseText")
-        #c = self.bm.getVerseText("TheMessage",'Genesis',1,2,1)
+        log.debug( "\n.......testGetVerseText')
+        #c = self.bm.getVerseText(u'TheMessage",'Genesis',1,2,1)
         #log.debug( c )
-        #c = self.bm.getVerseText('NIV','Genesis',1,1,2)
+        #c = self.bm.getVerseText(u'NIV','Genesis',1,1,2)
         #log.debug( c ) 
-        c = self.bm.getVerseText('asv','Genesis',10,1,20)
+        c = self.bm.getVerseText(u'asv','Genesis',10,1,20)
         log.debug( c )
-        c = self.bm.getVerseText('TheMessage','Genesis',10,1,20)
+        c = self.bm.getVerseText(u'TheMessage','Genesis',10,1,20)
         log.debug( c )       
-        c = self.bm.getVerseText('asv','Revelation',10,1,20)
+        c = self.bm.getVerseText(u'asv','Revelation',10,1,20)
         log.debug( c ) 
-        c = self.bm.getVersesFromText("asv", "Jesus wept")
+        c = self.bm.getVersesFromText(u'asv", u'Jesus wept')
         log.debug( c )   
-        c = self.bm.getVersesFromText("TheMessage", "Jesus wept")
-        log.debug( c )          
-
+        c = self.bm.getVersesFromText(u'TheMessage", u'Jesus wept')
+        log.debug( c )          
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/test/test_bibleManagerCSV.py'
--- openlp/plugins/bibles/test/test_bibleManagerCSV.py	2008-12-15 18:10:47 +0000
+++ openlp/plugins/bibles/test/test_bibleManagerCSV.py	2009-06-16 18:21:24 +0000
@@ -36,26 +36,26 @@
 
 console=logging.StreamHandler()
 # set a format which is simpler for console use
-formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
+formatter = logging.Formatter(u'%(name)-12s: %(levelname)-8s %(message)s')
 # tell the handler to use this format
 console.setFormatter(formatter)
-logging.getLogger('').addHandler(console)
-log=logging.getLogger('')
+logging.getLogger(u'').addHandler(console)
+log=logging.getLogger(u'')
 
-logging.info("\nLogging started")
+logging.info(u'\nLogging started')
 
 class TestBibleManager:
-    log=logging.getLogger("testBibleMgr")
+    log=logging.getLogger(u'testBibleMgr')
     def setup_class(self):
-        log.debug("\n.......Register BM")
+        log.debug(u'\n.......Register BM')
         self.bm = BibleManager()
 
     def testRegisterCSVBibleFiles(self):
         # Register a bible from files
-        log.debug("\n.......testRegisterBibleFiles")
-        self.bm.registerCSVFileBible("TheMessage",'biblebooks_msg_short.csv','bibleverses_msg_short.csv')
-        self.bm.registerCSVFileBible("NIV",'biblebooks_niv_short.csv','bibleverses_niv_short.csv')        
+        log.debug(u'\n.......testRegisterBibleFiles')
+        self.bm.registerCSVFileBible(u'TheMessage",'biblebooks_msg_short.csv','bibleverses_msg_short.csv')
+        self.bm.registerCSVFileBible(u'NIV",'biblebooks_niv_short.csv','bibleverses_niv_short.csv')        
         b = self.bm.get_bibles()
         for b1 in b:
             log.debug( b1)
-            assert(b1 in b)    
+            assert(b1 in b)    
\ No newline at end of file

=== modified file 'openlp/plugins/bibles/test/test_bibleManagerOSIS.py'
--- openlp/plugins/bibles/test/test_bibleManagerOSIS.py	2009-01-10 08:33:31 +0000
+++ openlp/plugins/bibles/test/test_bibleManagerOSIS.py	2009-06-16 18:21:24 +0000
@@ -36,25 +36,25 @@
 
 console=logging.StreamHandler()
 # set a format which is simpler for console use
-formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
+formatter = logging.Formatter(u'%(name)-12s: %(levelname)-8s %(message)s')
 # tell the handler to use this format
 console.setFormatter(formatter)
-logging.getLogger('').addHandler(console)
-log=logging.getLogger('')
+logging.getLogger(u'').addHandler(console)
+log=logging.getLogger(u'')
 
-logging.info("\nLogging started")
+logging.info(u'\nLogging started')
 
 class TestBibleManager:
-    log=logging.getLogger("testBibleMgr")
+    log=logging.getLogger(u'testBibleMgr')
     def setup_class(self):
-        log.debug("\n.......Register BM")
+        log.debug(u'\n.......Register BM')
         self.bm = BibleManager()
 
     def testRegisterOSISBibleFiles(self):
         # Register a bible from files
-        log.debug("\n.......testRegisterOSISBibleFiles")
-        self.bm.register_osis_file_bible("asv",'asv.osis')
+        log.debug(u'\n.......testRegisterOSISBibleFiles')
+        self.bm.register_osis_file_bible(u'asv",'asv.osis')
         b = self.bm.get_bibles()
         for b1 in b:
             log.debug( b1)
-            assert(b1 in b)    
+            assert(b1 in b)    
\ No newline at end of file

=== modified file 'openlp/plugins/custom/customplugin.py'
--- openlp/plugins/custom/customplugin.py	2009-05-21 16:07:01 +0000
+++ openlp/plugins/custom/customplugin.py	2009-06-17 05:11:16 +0000
@@ -23,7 +23,7 @@
 
 from forms import EditCustomForm
 from openlp.core.lib import Plugin, Event,  EventType
-from openlp.plugins.custom.lib import CustomManager, CustomTab, CustomMediaItem, CustomServiceItem
+from openlp.plugins.custom.lib import CustomManager, CustomTab, CustomMediaItem
 
 
 class CustomPlugin(Plugin):
@@ -40,10 +40,8 @@
         self.edit_custom_form = EditCustomForm(self.custommanager)
         # Create the plugin icon
         self.icon = QtGui.QIcon()
-        self.icon.addPixmap(QtGui.QPixmap(':/media/media_custom.png'),
+        self.icon.addPixmap(QtGui.QPixmap(u':/media/media_custom.png'),
             QtGui.QIcon.Normal, QtGui.QIcon.Off)
-        self.preview_service_item = CustomServiceItem(self.preview_controller)
-        self.live_service_item = CustomServiceItem(self.live_controller)
 
     def get_media_manager_item(self):
         # Create the CustomManagerItem object

=== modified file 'openlp/plugins/custom/forms/editcustomdialog.py'
--- openlp/plugins/custom/forms/editcustomdialog.py	2009-05-21 16:07:01 +0000
+++ openlp/plugins/custom/forms/editcustomdialog.py	2009-06-17 05:11:16 +0000
@@ -12,102 +12,102 @@
 
 class Ui_customEditDialog(object):
     def setupUi(self, customEditDialog):
-        customEditDialog.setObjectName("customEditDialog")
+        customEditDialog.setObjectName(u'customEditDialog')
         customEditDialog.resize(590, 541)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         customEditDialog.setWindowIcon(icon)
         self.gridLayout = QtGui.QGridLayout(customEditDialog)
-        self.gridLayout.setObjectName("gridLayout")
+        self.gridLayout.setObjectName(u'gridLayout')
         self.horizontalLayout = QtGui.QHBoxLayout()
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.TitleLabel = QtGui.QLabel(customEditDialog)
-        self.TitleLabel.setObjectName("TitleLabel")
+        self.TitleLabel.setObjectName(u'TitleLabel')
         self.horizontalLayout.addWidget(self.TitleLabel)
         self.TitleEdit = QtGui.QLineEdit(customEditDialog)
-        self.TitleEdit.setObjectName("TitleEdit")
+        self.TitleEdit.setObjectName(u'TitleEdit')
         self.horizontalLayout.addWidget(self.TitleEdit)
         self.gridLayout.addLayout(self.horizontalLayout, 0, 0, 1, 1)
         self.horizontalLayout_4 = QtGui.QHBoxLayout()
-        self.horizontalLayout_4.setObjectName("horizontalLayout_4")
+        self.horizontalLayout_4.setObjectName(u'horizontalLayout_4')
         self.VerseListView = QtGui.QListWidget(customEditDialog)
-        self.VerseListView.setObjectName("VerseListView")
+        self.VerseListView.setObjectName(u'VerseListView')
+        self.VerseListView.setAlternatingRowColors(True)
         self.horizontalLayout_4.addWidget(self.VerseListView)
         self.verticalLayout = QtGui.QVBoxLayout()
-        self.verticalLayout.setObjectName("verticalLayout")
+        self.verticalLayout.setObjectName(u'verticalLayout')
         self.UpButton = QtGui.QPushButton(customEditDialog)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/services/service_up.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/services/service_up.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.UpButton.setIcon(icon1)
-        self.UpButton.setObjectName("UpButton")
+        self.UpButton.setObjectName(u'UpButton')
         self.verticalLayout.addWidget(self.UpButton)
         spacerItem = QtGui.QSpacerItem(20, 128, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout.addItem(spacerItem)
         self.DownButton = QtGui.QPushButton(customEditDialog)
         icon2 = QtGui.QIcon()
-        icon2.addPixmap(QtGui.QPixmap(":/services/service_down.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon2.addPixmap(QtGui.QPixmap(u':/services/service_down.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.DownButton.setIcon(icon2)
-        self.DownButton.setObjectName("DownButton")
+        self.DownButton.setObjectName(u'DownButton')
         self.verticalLayout.addWidget(self.DownButton)
         self.horizontalLayout_4.addLayout(self.verticalLayout)
         self.gridLayout.addLayout(self.horizontalLayout_4, 1, 0, 1, 1)
         self.EditWidget = QtGui.QWidget(customEditDialog)
-        self.EditWidget.setObjectName("EditWidget")
+        self.EditWidget.setObjectName(u'EditWidget')
         self.EditLayout = QtGui.QHBoxLayout(self.EditWidget)
         self.EditLayout.setSpacing(8)
         self.EditLayout.setMargin(0)
-        self.EditLayout.setObjectName("EditLayout")
+        self.EditLayout.setObjectName(u'EditLayout')
         self.VerseTextEdit = QtGui.QTextEdit(self.EditWidget)
-        self.VerseTextEdit.setObjectName("VerseTextEdit")
+        self.VerseTextEdit.setObjectName(u'VerseTextEdit')
         self.EditLayout.addWidget(self.VerseTextEdit)
         self.ButtonWidget = QtGui.QWidget(self.EditWidget)
-        self.ButtonWidget.setObjectName("ButtonWidget")
+        self.ButtonWidget.setObjectName(u'ButtonWidget')
         self.ButtonLayout = QtGui.QVBoxLayout(self.ButtonWidget)
         self.ButtonLayout.setSpacing(8)
         self.ButtonLayout.setMargin(0)
-        self.ButtonLayout.setObjectName("ButtonLayout")
+        self.ButtonLayout.setObjectName(u'ButtonLayout')
         self.AddButton = QtGui.QPushButton(self.ButtonWidget)
-        self.AddButton.setObjectName("AddButton")
+        self.AddButton.setObjectName(u'AddButton')
         self.ButtonLayout.addWidget(self.AddButton)
         self.EditButton = QtGui.QPushButton(self.ButtonWidget)
-        self.EditButton.setObjectName("EditButton")
+        self.EditButton.setObjectName(u'EditButton')
         self.ButtonLayout.addWidget(self.EditButton)
         self.SaveButton = QtGui.QPushButton(self.ButtonWidget)
-        self.SaveButton.setObjectName("SaveButton")
+        self.SaveButton.setObjectName(u'SaveButton')
         self.ButtonLayout.addWidget(self.SaveButton)
         self.DeleteButton = QtGui.QPushButton(self.ButtonWidget)
-        self.DeleteButton.setObjectName("DeleteButton")
+        self.DeleteButton.setObjectName(u'DeleteButton')
         self.ButtonLayout.addWidget(self.DeleteButton)
         self.ClearButton = QtGui.QPushButton(self.ButtonWidget)
-        self.ClearButton.setObjectName("ClearButton")
+        self.ClearButton.setObjectName(u'ClearButton')
         self.ButtonLayout.addWidget(self.ClearButton)
         spacerItem1 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.ButtonLayout.addItem(spacerItem1)
         self.EditLayout.addWidget(self.ButtonWidget)
         self.gridLayout.addWidget(self.EditWidget, 2, 0, 1, 1)
         self.horizontalLayout = QtGui.QHBoxLayout()
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.ThemeLabel = QtGui.QLabel(customEditDialog)
-        self.ThemeLabel.setObjectName("ThemeLabel")
+        self.ThemeLabel.setObjectName(u'ThemeLabel')
         self.horizontalLayout.addWidget(self.ThemeLabel)
         self.ThemecomboBox = QtGui.QComboBox(customEditDialog)
-        self.ThemecomboBox.setObjectName("ThemecomboBox")
+        self.ThemecomboBox.setObjectName(u'ThemecomboBox')
         self.horizontalLayout.addWidget(self.ThemecomboBox)
         self.gridLayout.addLayout(self.horizontalLayout, 3, 0, 1, 1)
         self.horizontalLayout_2 = QtGui.QHBoxLayout()
-        self.horizontalLayout_2.setObjectName("horizontalLayout_2")
+        self.horizontalLayout_2.setObjectName(u'horizontalLayout_2')
         self.CreditLabel = QtGui.QLabel(customEditDialog)
-        self.CreditLabel.setObjectName("CreditLabel")
+        self.CreditLabel.setObjectName(u'CreditLabel')
         self.horizontalLayout_2.addWidget(self.CreditLabel)
         self.CreditEdit = QtGui.QLineEdit(customEditDialog)
-        self.CreditEdit.setObjectName("CreditEdit")
+        self.CreditEdit.setObjectName(u'CreditEdit')
         self.horizontalLayout_2.addWidget(self.CreditEdit)
         self.gridLayout.addLayout(self.horizontalLayout_2, 4, 0, 1, 1)
         self.buttonBox = QtGui.QDialogButtonBox(customEditDialog)
         self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
-        self.buttonBox.setObjectName("buttonBox")
+        self.buttonBox.setObjectName(u'buttonBox')
         self.gridLayout.addWidget(self.buttonBox, 5, 0, 1, 1)
-
         self.retranslateUi(customEditDialog)
         QtCore.QMetaObject.connectSlotsByName(customEditDialog)
         customEditDialog.setTabOrder(self.TitleEdit, self.VerseTextEdit)
@@ -120,12 +120,12 @@
         customEditDialog.setTabOrder(self.DeleteButton, self.buttonBox)
 
     def retranslateUi(self, customEditDialog):
-        customEditDialog.setWindowTitle(translate("customEditDialog", "Edit Custom Slides"))
-        self.TitleLabel.setText(translate("customEditDialog", "Title:"))
-        self.AddButton.setText(translate("customEditDialog", "Add"))
-        self.EditButton.setText(translate("customEditDialog", "Edit"))
-        self.SaveButton.setText(translate("customEditDialog", "Save"))
-        self.DeleteButton.setText(translate("customEditDialog", "Delete"))
-        self.ClearButton.setText(translate("customEditDialog", "Clear"))
-        self.ThemeLabel.setText(translate("customEditDialog", "Theme:"))
-        self.CreditLabel.setText(translate("customEditDialog", "Credits:"))
+        customEditDialog.setWindowTitle(translate(u'customEditDialog', u'Edit Custom Slides'))
+        self.TitleLabel.setText(translate(u'customEditDialog', u'Title:'))
+        self.AddButton.setText(translate(u'customEditDialog', u'Add'))
+        self.EditButton.setText(translate(u'customEditDialog', u'Edit'))
+        self.SaveButton.setText(translate(u'customEditDialog', u'Save'))
+        self.DeleteButton.setText(translate(u'customEditDialog', u'Delete'))
+        self.ClearButton.setText(translate(u'customEditDialog', u'Clear'))
+        self.ThemeLabel.setText(translate(u'customEditDialog', u'Theme:'))
+        self.CreditLabel.setText(translate(u'customEditDialog', u'Credits:'))

=== modified file 'openlp/plugins/custom/forms/editcustomform.py'
--- openlp/plugins/custom/forms/editcustomform.py	2009-05-01 05:02:53 +0000
+++ openlp/plugins/custom/forms/editcustomform.py	2009-06-17 05:11:16 +0000
@@ -35,33 +35,32 @@
         #self.parent = parent
         self.setupUi(self)
         # Connecting signals and slots
-        QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL("rejected()"), self.rejected)
-        QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL("accepted()"), self.accept)
-        QtCore.QObject.connect(self.AddButton, QtCore.SIGNAL("pressed()"), self.onAddButtonPressed)
-        QtCore.QObject.connect(self.EditButton, QtCore.SIGNAL("pressed()"), self.onEditButtonPressed)
-        QtCore.QObject.connect(self.SaveButton, QtCore.SIGNAL("pressed()"), self.onSaveButtonPressed)
-        QtCore.QObject.connect(self.DeleteButton, QtCore.SIGNAL("pressed()"), self.onDeleteButtonPressed)
-        QtCore.QObject.connect(self.ClearButton, QtCore.SIGNAL("pressed()"), self.onClearButtonPressed)
-        QtCore.QObject.connect(self.UpButton, QtCore.SIGNAL("pressed()"), self.onUpButtonPressed)
-        QtCore.QObject.connect(self.DownButton, QtCore.SIGNAL("pressed()"), self.onDownButtonPressed)
-        QtCore.QObject.connect(self.TitleEdit, QtCore.SIGNAL("lostFocus()"), self.validate)
+        QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(u'rejected()'), self.rejected)
+        QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(u'accepted()'), self.accept)
+        QtCore.QObject.connect(self.AddButton, QtCore.SIGNAL(u'pressed()'), self.onAddButtonPressed)
+        QtCore.QObject.connect(self.EditButton, QtCore.SIGNAL(u'pressed()'), self.onEditButtonPressed)
+        QtCore.QObject.connect(self.SaveButton, QtCore.SIGNAL(u'pressed()'), self.onSaveButtonPressed)
+        QtCore.QObject.connect(self.DeleteButton, QtCore.SIGNAL(u'pressed()'), self.onDeleteButtonPressed)
+        QtCore.QObject.connect(self.ClearButton, QtCore.SIGNAL(u'pressed()'), self.onClearButtonPressed)
+        QtCore.QObject.connect(self.UpButton, QtCore.SIGNAL(u'pressed()'), self.onUpButtonPressed)
+        QtCore.QObject.connect(self.DownButton, QtCore.SIGNAL(u'pressed()'), self.onDownButtonPressed)
+        QtCore.QObject.connect(self.TitleEdit, QtCore.SIGNAL(u'lostFocus()'), self.validate)
 
         QtCore.QObject.connect(self.VerseListView,
-            QtCore.SIGNAL("itemDoubleClicked(QListWidgetItem*)"), self.onVerseListViewSelected)
+            QtCore.SIGNAL(u'itemDoubleClicked(QListWidgetItem*)'), self.onVerseListViewSelected)
         QtCore.QObject.connect(self.VerseListView,
-            QtCore.SIGNAL("itemClicked(QListWidgetItem*)"), self.onVerseListViewPressed)
+            QtCore.SIGNAL(u'itemClicked(QListWidgetItem*)'), self.onVerseListViewPressed)
         # Create other objects and forms
         self.custommanager = custommanager
         self.initialise()
-        self.VerseListView.setAlternatingRowColors(True)
 
     def initialise(self):
         self.valid = True
         self.DeleteButton.setEnabled(False)
         self.EditButton.setEnabled(False)
         self.SaveButton.setEnabled(False)
-        self.TitleEdit.setText('')
-        self.CreditEdit.setText('')
+        self.TitleEdit.setText(u'')
+        self.CreditEdit.setText(u'')
         self.VerseTextEdit.clear()
         self.VerseListView.clear()
         #make sure we have a new item
@@ -86,7 +85,7 @@
             verseList = songXML.get_verses()
             for verse in verseList:
                 self.VerseListView.addItem(verse[1])
-            theme = str(self.customSlide.theme_name)
+            theme = unicode(self.customSlide.theme_name)
             id = self.ThemecomboBox.findText(theme, QtCore.Qt.MatchExactly)
             if id == -1:
                 id = 0 # Not Found
@@ -96,14 +95,13 @@
             self.ThemecomboBox.setCurrentIndex(0)
 
     def accept(self):
-        self.validate()
-        if self.valid:
+        if self.validate():
             sxml=SongXMLBuilder()
             sxml.new_document()
             sxml.add_lyrics_to_song()
             count = 1
             for i in range (0, self.VerseListView.count()):
-                sxml.add_verse_to_lyrics(u'custom', str(count),  str(self.VerseListView.item(i).text()))
+                sxml.add_verse_to_lyrics(u'custom', unicode(count),  unicode(self.VerseListView.item(i).text()))
                 count += 1
             self.customSlide.title = unicode(self.TitleEdit.displayText())
             self.customSlide.text = unicode(sxml.extract_xml())
@@ -124,7 +122,8 @@
 
     def onDownButtonPressed(self):
         selectedRow = self.VerseListView.currentRow()
-        if selectedRow != self.VerseListView.count() - 1: # zero base arrays
+        # zero base arrays
+        if selectedRow != self.VerseListView.count() - 1:
             qw = self.VerseListView.takeItem(selectedRow)
             self.VerseListView.insertItem(selectedRow + 1, qw)
             self.VerseListView.setCurrentRow(selectedRow + 1)
@@ -146,6 +145,7 @@
         self.VerseListView.addItem(self.VerseTextEdit.toPlainText())
         self.DeleteButton.setEnabled(False)
         self.VerseTextEdit.clear()
+        self.validate()
 
     def onEditButtonPressed(self):
         self.VerseTextEdit.setPlainText(self.VerseListView.currentItem().text())
@@ -163,16 +163,16 @@
         self.EditButton.setEnabled(False)
 
     def validate(self):
-        invalid = 0
-        self.valid = True
+        valid = True
         if len(self.TitleEdit.displayText()) == 0:
-            invalid += 1
-            self.TitleLabel.setStyleSheet('color: red')
-        else:
-            self.TitleLabel.setStyleSheet('color: black')
-
-        if self.VerseListView.count() == 0:    # must have 1 slide
-            invalid += 1
-
-        if invalid == 1:
-            self.valid = False
+            valid = False
+            self.TitleEdit.setStyleSheet(u'background-color: red; color: white')
+        else:
+            self.TitleEdit.setStyleSheet(u'')
+        # must have 1 slide
+        if self.VerseListView.count() == 0:
+            valid = False
+            self.VerseListView.setStyleSheet(u'background-color: red; color: white')
+        else:
+            self.VerseListView.setStyleSheet(u'')
+        return valid

=== modified file 'openlp/plugins/custom/lib/__init__.py'
--- openlp/plugins/custom/lib/__init__.py	2009-06-03 15:38:14 +0000
+++ openlp/plugins/custom/lib/__init__.py	2009-06-17 05:11:16 +0000
@@ -17,9 +17,6 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
-from textlistdata import TextListData
-from customserviceitem import CustomServiceItem
 from manager import CustomManager
 from customtab import CustomTab
 from mediaitem import CustomMediaItem

=== removed file 'openlp/plugins/custom/lib/customserviceitem.py'
--- openlp/plugins/custom/lib/customserviceitem.py	2009-05-21 16:07:01 +0000
+++ openlp/plugins/custom/lib/customserviceitem.py	1970-01-01 00:00:00 +0000
@@ -1,118 +0,0 @@
-# -*- coding: utf-8 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 Martin Thompson, Tim Bentley
-
-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
-"""
-from PyQt4 import QtCore, QtGui
-import logging
-
-from openlp.core.lib import ServiceItem
-
-from openlp.plugins.custom.lib import TextListData
-
-class CustomServiceItem(ServiceItem):
-    """
-    The service item is a base class for the plugins to use to interact with
-    * the service manager (and hence the OOS disk files),
-    * the slide controller(s - both preview and live)
-    * and the renderer - which produces the
-          main screen
-          the preview preview and
-          the live preview
-
-    The image plugin passes one of these to the preview/live when requested
-      The preview/live controllers keep hold of it
-    The service manager has one in its service structure for each Image item in the OOS
-    When something goes live/previews -
-      it simply tells the slide controller to use it???
-
-    It contains 1 or more images
-
-    """
-    global log
-    log=logging.getLogger(u'CustomServiceItem')
-    log.info(u'CustomServiceItem loaded')
-
-    def __init__(self, controller):
-        """
-        Init Method
-        """
-        log.info("init")
-        self.imgs=TextListData()
-#         self.slide_controller=controller
-#         self.slide_controller.ControllerContents=QtGui.QListView()
-#         c=self.slide_controller.ControllerContents
-#         c.uniformItemSizes=True
-#         c.setModel(self.imgs)
-#         c.setGeometry(0,0,200,200)
-
-    def render(self):
-        """
-        The render method is what the plugin uses to render its meda to the
-        screen.
-        """
-        # render the "image chooser first"
-#         for f in self.imgs:
-#             fl ,  nm = os.path.split(str(f))
-#             c = self.slide_controller.rowCount()
-#             self.slide_controller.setRowCount(c+1)
-#             twi = QtGui.QTableWidgetItem(str(f))
-#             self.slide_controller.setItem(c , 0, twi)
-#             twi = QtGui.QTableWidgetItem(str(nm))
-#             self.slide_controller.setItem(c , 1, twi)
-#             self.slide_controller.setRowHeight(c, 80)
-
-        # render the preview screen here
-
-    def get_parent_node(self):
-        """
-        This method returns a parent node to be inserted into the Service
-        Manager.
-        """
-        pass
-
-    def add(self, data):
-        """
-        append an image to the list
-        """
-        if type(data)==type("string"):
-            log.info("add filename:"+data)
-            self.imgs.addRow(data)
-        else: # it's another service item to be merged in
-            log.info("add Item..."+str(data))
-            for filename in data.imgs.get_file_list():
-                self.add(filename)
-
-
-    def get_oos_text(self):
-        """
-        Turn the image list into a set of filenames for storage in the oos file
-        """
-        log.info("Get oos text")
-        log.info(str(self.imgs))
-        log.info(str(self.imgs.get_file_list()))
-        return '\n'.join(self.imgs.get_file_list())
-
-    def set_from_oos(self, text):
-        """
-        get text from the OOS file and setup the internal structure
-        """
-        log.info("Set from OOS:"+text)
-        files=text.split('\n')
-        for f in files:
-            self.imgs.addRow(f)
-

=== modified file 'openlp/plugins/custom/lib/mediaitem.py'
--- openlp/plugins/custom/lib/mediaitem.py	2009-06-07 19:34:24 +0000
+++ openlp/plugins/custom/lib/mediaitem.py	2009-06-17 05:11:16 +0000
@@ -22,9 +22,8 @@
 from PyQt4 import QtCore, QtGui
 
 from openlp.core.lib import MediaManagerItem,  SongXMLParser,  ServiceItem,  translate
-from openlp.plugins.custom.lib import TextListData
 
-class CustomList(QtGui.QListView):
+class CustomList(QtGui.QListWidget):
 
     def __init__(self,parent=None,name=None):
         QtGui.QListView.__init__(self,parent)
@@ -103,60 +102,38 @@
         self.CustomWidget.setObjectName(u'CustomWidget')
         # Add the Custom widget to the page layout
         self.PageLayout.addWidget(self.CustomWidget)
-        self.CustomListView = CustomList()
-        self.CustomListView.setAlternatingRowColors(True)
-        self.CustomListData = TextListData()
-        self.CustomListView.setModel(self.CustomListData)
-        self.CustomListView.setDragEnabled(True)
-        self.PageLayout.addWidget(self.CustomListView)
+        self.CustomListWidget = CustomList()
+        self.CustomListWidget.setAlternatingRowColors(True)
+        self.CustomListWidget.setDragEnabled(True)
+        self.PageLayout.addWidget(self.CustomListWidget)
         # Signals
-        QtCore.QObject.connect(self.CustomListView,
+        QtCore.QObject.connect(self.CustomListWidget,
             QtCore.SIGNAL(u'doubleClicked(QModelIndex)'), self.onCustomPreviewClick)
         #define and add the context menu
-        self.CustomListView.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
-        self.CustomListView.addAction(self.contextMenuAction(self.CustomListView,
+        self.CustomListWidget.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
+        self.CustomListWidget.addAction(self.contextMenuAction(self.CustomListWidget,
             ':/custom/custom_edit.png', translate(u'CustomMediaItem', u'&Edit Custom'),
             self.onCustomEditClick))
-        self.CustomListView.addAction(self.contextMenuSeparator(self.CustomListView))
-        self.CustomListView.addAction(self.contextMenuAction(
-            self.CustomListView, ':/system/system_preview.png',
+        self.CustomListWidget.addAction(self.contextMenuSeparator(self.CustomListWidget))
+        self.CustomListWidget.addAction(self.contextMenuAction(
+            self.CustomListWidget, ':/system/system_preview.png',
             translate(u'CustomMediaItem',u'&Preview Custom'), self.onCustomPreviewClick))
-        self.CustomListView.addAction(self.contextMenuAction(
-            self.CustomListView, ':/system/system_live.png',
+        self.CustomListWidget.addAction(self.contextMenuAction(
+            self.CustomListWidget, ':/system/system_live.png',
             translate(u'CustomMediaItem',u'&Show Live'), self.onCustomLiveClick))
-        self.CustomListView.addAction(self.contextMenuAction(
-            self.CustomListView, ':/system/system_add.png',
+        self.CustomListWidget.addAction(self.contextMenuAction(
+            self.CustomListWidget, ':/system/system_add.png',
             translate(u'CustomMediaItem',u'&Add to Service'), self.onCustomAddClick))
 
-#    def retranslateUi(self):
-#        self.ClearTextButton.setText(translate(u'CustomMediaItem', u'Clear'))
-#        self.SearchTextButton.setText(translate(u'CustomMediaItem', u'Search'))
-
     def initialise(self):
         self.loadCustomList(self.parent.custommanager.get_all_slides())
 
     def loadCustomList(self, list):
-        self.CustomListData.resetStore()
+        self.CustomListWidget.clear()
         for CustomSlide in list:
-            self.CustomListData.addRow(CustomSlide.id,CustomSlide.title)
-
-    def onClearTextButtonClick(self):
-        """
-        Clear the search text.
-        """
-        self.SearchTextEdit.clear()
-
-    def onSearchTextEditChanged(self, text):
-        # only search if > 3 characters
-        if len(text) > 3:
-            self.onSearchTextButtonClick()
-
-    def onSearchTextButtonClick(self):
-        search_keywords = str(self.SearchTextEdit.displayText())
-        search_results  = []
-        search_type = self.SearchTypeComboBox.currentText()
-        search_results = self.Custommanager.search_Custom_lyrics(search_keywords)
-        self._display_results(search_results)
+            custom_name = QtGui.QListWidgetItem(CustomSlide.title)
+            custom_name.setData(QtCore.Qt.UserRole, QtCore.QVariant(CustomSlide.id))
+            self.CustomListWidget.addItem(custom_name)
 
     def onCustomNewClick(self):
         self.parent.edit_custom_form.loadCustom(0)
@@ -164,18 +141,18 @@
         self.initialise()
 
     def onCustomEditClick(self):
-        indexes = self.CustomListView.selectedIndexes()
-        for index in indexes:
-            self.parent.edit_custom_form.loadCustom(self.CustomListData.getId(index))
-            self.parent.edit_custom_form.exec_()
+        item = self.CustomListWidget.currentItem()
+        item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0]
+        self.parent.edit_custom_form.loadCustom(item_id)
+        self.parent.edit_custom_form.exec_()
         self.initialise()
 
     def onCustomDeleteClick(self):
-        indexes = self.CustomListView.selectedIndexes()
-        for index in indexes:
-            id = self.CustomListData.getId(index)
-            self.parent.custommanager.delete_custom(id)
-            self.CustomListData.deleteRow(index)
+        item = self.CustomListWidget.currentItem()
+        item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0]
+        self.parent.custommanager.delete_custom(item_id)
+        row = self.CustomListWidget.row(item)
+        self.CustomListWidget.takeItem(row)
 
     def onCustomPreviewClick(self):
         log.debug(u'Custom Preview Requested')
@@ -203,20 +180,19 @@
         raw_footer = []
         slide = None
         theme = None
-        indexes = self.CustomListView.selectedIndexes()
-        for index in indexes:
-            id = self.CustomListData.getId(index)
-            customSlide = self.parent.custommanager.get_custom(id)
-            title = customSlide.title
-            credit = customSlide.credits
-            theme = customSlide.theme_name
-            if len(theme) is not 0 :
-                service_item.theme = theme
-            songXML=SongXMLParser(customSlide.text)
-            verseList = songXML.get_verses()
-            for verse in verseList:
-                raw_slides.append(verse[1])
-            raw_footer.append(title + u' '+ credit)
+        item = self.CustomListWidget.currentItem()
+        item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0]
+        customSlide = self.parent.custommanager.get_custom(item_id)
+        title = customSlide.title
+        credit = customSlide.credits
+        theme = customSlide.theme_name
+        if len(theme) is not 0 :
+            service_item.theme = theme
+        songXML=SongXMLParser(customSlide.text)
+        verseList = songXML.get_verses()
+        for verse in verseList:
+            raw_slides.append(verse[1])
+        raw_footer.append(title + u' '+ credit)
         if theme is not None:
             service_item.title = title
             for slide in raw_slides:

=== modified file 'openlp/plugins/custom/lib/tables.py'
--- openlp/plugins/custom/lib/tables.py	2009-03-07 09:20:26 +0000
+++ openlp/plugins/custom/lib/tables.py	2009-06-16 18:21:24 +0000
@@ -22,10 +22,10 @@
 from openlp.plugins.custom.lib.meta import metadata
 
 # Definition of the "songs" table
-custom_slide_table = Table('custom_slide', metadata,
-    Column('id', types.Integer(), primary_key=True),
-    Column('title', types.Unicode(255), nullable=False),
-    Column('text', types.UnicodeText, nullable=False),
-    Column('credits', types.UnicodeText),
-    Column('theme_name', types.Unicode(128))
-)
+custom_slide_table = Table(u'custom_slide', metadata,
+    Column(u'id', types.Integer(), primary_key=True),
+    Column(u'title', types.Unicode(255), nullable=False),
+    Column(u'text', types.UnicodeText, nullable=False),
+    Column(u'credits', types.UnicodeText),
+    Column(u'theme_name', types.Unicode(128))
+)
\ No newline at end of file

=== removed file 'openlp/plugins/custom/lib/textlistdata.py'
--- openlp/plugins/custom/lib/textlistdata.py	2009-06-03 15:38:14 +0000
+++ openlp/plugins/custom/lib/textlistdata.py	1970-01-01 00:00:00 +0000
@@ -1,80 +0,0 @@
-# -*- coding: utf-8 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008-2009 Martin Thompson, Tim Bentley
-
-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
-"""
-import logging
-
-from PyQt4 import QtCore, QtGui
-
-class TextListData(QtCore.QAbstractListModel):
-    """
-    An abstract list of strings
-    """
-    global log
-    log = logging.getLogger(u'TextListData')
-    log.info(u'started')
-
-    def __init__(self):
-        QtCore.QAbstractListModel.__init__(self)
-        self.items = [] # will be a list of (database id , title) tuples
-
-    def resetStore(self):
-        #reset list so can be reloaded
-        self.items = []
-
-    def rowCount(self, parent):
-        return len(self.items)
-
-    def insertRow(self, row, id, title):
-        self.beginInsertRows(QtCore.QModelIndex(),row,row)
-        log.debug("insert row %d:%s for id %d" % (row,title, id))
-        self.items.insert(row, (id, title))
-        self.endInsertRows()
-
-    def removeRow(self, row):
-        self.beginRemoveRows(QtCore.QModelIndex(), row,row)
-        self.items.pop(row)
-        self.endRemoveRows()
-
-    def addRow(self, id, title):
-        self.insertRow(len(self.items), id, title)
-
-    def data(self, index, role):
-        row = index.row()
-        if row > len(self.items): # if the last row is selected and deleted, we then get called with an empty row!
-            return QtCore.QVariant()
-        if role == QtCore.Qt.DisplayRole:
-            retval = self.items[row][1]
-        else:
-            retval = QtCore.QVariant()
-        if type(retval) is not type(QtCore.QVariant):
-            return QtCore.QVariant(retval)
-        else:
-            return retval
-
-    def getIdList(self):
-        filelist = [item[0] for item in self.items];
-        return filelist
-
-    def getId(self, index):
-        row = index.row()
-        return self.items[row][0]
-
-    def deleteRow(self, index):
-        row = index.row()
-        self.removeRow(row)

=== modified file 'openlp/plugins/images/lib/imageserviceitem.py'
--- openlp/plugins/images/lib/imageserviceitem.py	2009-05-22 18:30:25 +0000
+++ openlp/plugins/images/lib/imageserviceitem.py	2009-06-16 18:21:24 +0000
@@ -42,13 +42,13 @@
 
     """
     global log
-    log=logging.getLogger("ImageServiceItem")
-    log.info("ImageServiceItem loaded")
+    log=logging.getLogger(u'ImageServiceItem')
+    log.info(u'ImageServiceItem loaded')
     def __init__(self, controller):
         """
         Init Method
         """
-        log.info("init")
+        log.info(u'init')
         self.imgs=ListWithPreviews()
 #         self.slide_controller=controller
 #         self.slide_controller.ControllerContents=QtGui.QListView()
@@ -64,12 +64,12 @@
         """
         # render the "image chooser first"
 #         for f in self.imgs:
-#             fl ,  nm = os.path.split(str(f))
+#             fl ,  nm = os.path.split(unicode(f))
 #             c = self.slide_controller.rowCount()
 #             self.slide_controller.setRowCount(c+1)
-#             twi = QtGui.QTableWidgetItem(str(f))
+#             twi = QtGui.QTableWidgetItem(unicode(f))
 #             self.slide_controller.setItem(c , 0, twi)
-#             twi = QtGui.QTableWidgetItem(str(nm))
+#             twi = QtGui.QTableWidgetItem(unicode(nm))
 #             self.slide_controller.setItem(c , 1, twi)
 #             self.slide_controller.setRowHeight(c, 80)
 
@@ -85,11 +85,11 @@
         """
         append an image to the list
         """
-        if type(data)==type("string"):
-            log.info("add filename:"+data)
+        if type(data)==type(u'string'):
+            log.info(u'add filename:'+data)
             self.imgs.addRow(data)
         else: # it's another service item to be merged in
-            log.info("add Item..."+str(data))
+            log.info(u'add Item...'+unicode(data))
             for filename in data.get_file_list():
                 self.add(filename)
 
@@ -98,17 +98,16 @@
         """
         Turn the image list into a set of filenames for storage in the oos file
         """
-        log.info("Get oos text")
-        log.info(str(self.imgs))
-#        log.info(str(self.imgs.get_file_list()))
+        log.info(u'Get oos text')
+        log.info(unicode(self.imgs))
+#        log.info(unicode(self.imgs.get_file_list()))
         return '\n'.join(self.imgs.get_file_list())
 
     def set_from_oos(self, text):
         """
         get text from the OOS file and setup the internal structure
         """
-        log.info("Set from OOS:"+text)
-        files=text.split('\n')
+        log.info(u'Set from OOS:'+text)
+        files=text.split(u'\n')
         for f in files:
             self.imgs.addRow(f)
-

=== modified file 'openlp/plugins/images/lib/listwithpreviews.py'
--- openlp/plugins/images/lib/listwithpreviews.py	2009-05-22 19:36:16 +0000
+++ openlp/plugins/images/lib/listwithpreviews.py	2009-06-16 18:21:24 +0000
@@ -27,8 +27,8 @@
     An abstract list of strings and the preview icon to go with them
     """
     global log
-    log = logging.getLogger("ListWithPreviews")
-    log.info("started")
+    log = logging.getLogger(u'ListWithPreviews')
+    log.info(u'started')
 
     def __init__(self):
         QtCore.QAbstractListModel.__init__(self)
@@ -41,13 +41,13 @@
 
     def insertRow(self, row, filename):
         self.beginInsertRows(QtCore.QModelIndex(),row,row)
-        log.info("insert row %d:%s"% (row,filename))
+        log.info(u'insert row %d:%s'% (row,filename))
         # get short filename to display next to image
-        (prefix, shortfilename) = os.path.split(str(filename))
-        log.info("shortfilename=%s"% (shortfilename))
+        (prefix, shortfilename) = os.path.split(unicode(filename))
+        log.info(u'shortfilename=%s'% (shortfilename))
         # create a preview image
         if os.path.exists(filename):
-            preview = QtGui.QPixmap(str(filename))
+            preview = QtGui.QPixmap(unicode(filename))
             w = self.maximagewidth;
             h = self.rowheight
             preview = preview.scaled(w, h, QtCore.Qt.KeepAspectRatio, QtCore.Qt.SmoothTransformation)

=== modified file 'openlp/plugins/images/lib/mediaitem.py'
--- openlp/plugins/images/lib/mediaitem.py	2009-06-07 19:34:24 +0000
+++ openlp/plugins/images/lib/mediaitem.py	2009-06-16 18:21:24 +0000
@@ -123,10 +123,10 @@
             translate(u'ImageMediaItem', u'Select Image(s)'),
             self.parent.config.get_last_dir(),
             u'Images (*.jpg *.gif *.png *.bmp)')
-        log.info(u'New image(s)', str(files))
+        log.info(u'New image(s)', unicode(files))
         if len(files) > 0:
             self.loadImageList(files)
-            dir, filename = os.path.split(str(files[0]))
+            dir, filename = os.path.split(unicode(files[0]))
             self.parent.config.set_last_dir(dir)
             self.parent.config.set_list(u'images', self.ImageListData.getFileList())
 
@@ -146,7 +146,7 @@
         service_item.title = u'Images'
         for index in indexes:
             filename = self.ImageListData.getFilename(index)
-            frame = QtGui.QPixmap(str(filename))
+            frame = QtGui.QPixmap(unicode(filename))
             (path, name) =os.path.split(filename)
             service_item.add_from_image(name, frame)
 
@@ -169,4 +169,4 @@
         service_item = ServiceItem(self.parent)
         service_item.addIcon(u':/media/media_image.png')
         self.generateSlideData(service_item)
-        self.parent.service_manager.addServiceItem(service_item)
+        self.parent.service_manager.addServiceItem(service_item)
\ No newline at end of file

=== modified file 'openlp/plugins/media/lib/filelistdata.py'
--- openlp/plugins/media/lib/filelistdata.py	2009-04-25 06:11:15 +0000
+++ openlp/plugins/media/lib/filelistdata.py	2009-06-16 18:21:24 +0000
@@ -39,10 +39,10 @@
 
     def insertRow(self, row, filename):
         self.beginInsertRows(QModelIndex(),row,row)
-        log.info("insert row %d:%s"%(row,filename))
+        log.info(u'insert row %d:%s'%(row,filename))
         # get short filename to display next to image
-        (prefix, shortfilename) = os.path.split(str(filename))
-        log.info("shortfilename=%s"%(shortfilename))
+        (prefix, shortfilename) = os.path.split(unicode(filename))
+        log.info(u'shortfilename=%s'%(shortfilename))
         # create a preview image
         self.items.insert(row, (filename, shortfilename))
         self.endInsertRows()
@@ -67,7 +67,7 @@
             retval= self.items[row][0]
         else:
             retval= QVariant()
-#         log.info("Returning"+ str(retval))
+#         log.info(u'Returning"+ unicode(retval))
         if type(retval) is not type(QVariant):
             return QVariant(retval)
         else:

=== modified file 'openlp/plugins/media/lib/mediaitem.py'
--- openlp/plugins/media/lib/mediaitem.py	2009-05-22 18:30:25 +0000
+++ openlp/plugins/media/lib/mediaitem.py	2009-06-16 18:21:24 +0000
@@ -44,30 +44,30 @@
         # Create buttons for the toolbar
         ## New Media Button ##
         self.addToolbarButton(
-            translate('MediaMediaItem',u'New Media'),
-            translate('MediaMediaItem',u'Load Media into openlp.org'),
+            translate(u'MediaMediaItem',u'New Media'),
+            translate(u'MediaMediaItem',u'Load Media into openlp.org'),
             ':/videos/video_load.png', self.onMediaNewClick, 'MediaNewItem')
         ## Delete Media Button ##
         self.addToolbarButton(
-            translate('MediaMediaItem',u'Delete Media'),
-            translate('MediaMediaItem',u'Delete the selected Media item'),
+            translate(u'MediaMediaItem',u'Delete Media'),
+            translate(u'MediaMediaItem',u'Delete the selected Media item'),
             ':/videos/video_delete.png', self.onMediaDeleteClick, 'MediaDeleteItem')
         ## Separator Line ##
         self.addToolbarSeparator()
         ## Preview Media Button ##
         self.addToolbarButton(
-            translate('MediaMediaItem',u'Preview Media'),
-            translate('MediaMediaItem',u'Preview the selected Media item'),
+            translate(u'MediaMediaItem',u'Preview Media'),
+            translate(u'MediaMediaItem',u'Preview the selected Media item'),
             ':/system/system_preview.png', self.onMediaPreviewClick, 'MediaPreviewItem')
         ## Live Media Button ##
         self.addToolbarButton(
-            translate('MediaMediaItem',u'Go Live'),
-            translate('MediaMediaItem',u'Send the selected Media item live'),
+            translate(u'MediaMediaItem',u'Go Live'),
+            translate(u'MediaMediaItem',u'Send the selected Media item live'),
             ':/system/system_live.png', self.onMediaLiveClick, 'MediaLiveItem')
         ## Add Media Button ##
         self.addToolbarButton(
-            translate('MediaMediaItem',u'Add Media To Service'),
-            translate('MediaMediaItem',u'Add the selected Media items(s) to the service'),
+            translate(u'MediaMediaItem',u'Add Media To Service'),
+            translate(u'MediaMediaItem',u'Add the selected Media items(s) to the service'),
             ':/system/system_add.png',self.onMediaAddClick, 'MediaAddItem')
         ## Add the Medialist widget ##
 
@@ -83,13 +83,13 @@
 
         self.MediaListView.addAction(self.contextMenuAction(
             self.MediaListView, ':/system/system_preview.png',
-            translate('MediaMediaItem',u'&Preview Media'), self.onMediaPreviewClick))
+            translate(u'MediaMediaItem',u'&Preview Media'), self.onMediaPreviewClick))
         self.MediaListView.addAction(self.contextMenuAction(
             self.MediaListView, ':/system/system_live.png',
-            translate('MediaMediaItem',u'&Show Live'), self.onMediaLiveClick))
+            translate(u'MediaMediaItem',u'&Show Live'), self.onMediaLiveClick))
         self.MediaListView.addAction(self.contextMenuAction(
             self.MediaListView, ':/system/system_add.png',
-            translate('MediaMediaItem',u'&Add to Service'), self.onMediaAddClick))
+            translate(u'MediaMediaItem',u'&Add to Service'), self.onMediaAddClick))
 
     def initialise(self):
         list = self.parent.config.load_list(u'Media')
@@ -97,12 +97,12 @@
 
     def onMediaNewClick(self):
         files = QtGui.QFileDialog.getOpenFileNames(None,
-            translate('MediaMediaItem', u'Select Media(s) items'),
+            translate(u'MediaMediaItem', u'Select Media(s) items'),
             self.parent.config.get_last_dir(),
             u'Videos (*.avi *.mpeg);;Audio (*.mp3 *.ogg *.wma);;All files (*)')
         if len(files) > 0:
             self.loadMediaList(files)
-            dir, filename = os.path.split(str(files[0]))
+            dir, filename = os.path.split(unicode(files[0]))
             self.parent.config.set_last_dir(dir)
             self.parent.config.set_list(u'media', self.MediaListData.getFileList())
 
@@ -132,4 +132,4 @@
         pass
 
     def onMediaAddClick(self):
-        pass
+        pass
\ No newline at end of file

=== modified file 'openlp/plugins/media/lib/mediatab.py'
--- openlp/plugins/media/lib/mediatab.py	2009-06-05 18:53:50 +0000
+++ openlp/plugins/media/lib/mediatab.py	2009-06-16 18:21:24 +0000
@@ -73,4 +73,4 @@
             self.UseVMRCheckBox.setChecked(True)
 
     def save(self):
-        self.config.set_config(u'use mode layout', str(self.use_vmr_mode))
+        self.config.set_config(u'use mode layout', unicode(self.use_vmr_mode))
\ No newline at end of file

=== modified file 'openlp/plugins/media/mediaplugin.py'
--- openlp/plugins/media/mediaplugin.py	2009-05-21 05:15:51 +0000
+++ openlp/plugins/media/mediaplugin.py	2009-06-16 18:21:24 +0000
@@ -31,7 +31,7 @@
         self.weight = -6
         # Create the plugin icon
         self.icon = QtGui.QIcon()
-        self.icon.addPixmap(QtGui.QPixmap(':/media/media_video.png'),
+        self.icon.addPixmap(QtGui.QPixmap(u':/media/media_video.png'),
             QtGui.QIcon.Normal, QtGui.QIcon.Off)
 
     def get_settings_tab(self):
@@ -42,4 +42,3 @@
         # Create the MediaManagerItem object
         self.media_item = MediaMediaItem(self, self.icon, u'Media')
         return self.media_item
-

=== modified file 'openlp/plugins/presentations/lib/filelistdata.py'
--- openlp/plugins/presentations/lib/filelistdata.py	2009-03-19 17:31:33 +0000
+++ openlp/plugins/presentations/lib/filelistdata.py	2009-06-16 18:21:24 +0000
@@ -39,10 +39,10 @@
 
     def insertRow(self, row, filename):
         self.beginInsertRows(QModelIndex(),row,row)
-        log.info("insert row %d:%s"%(row,filename))
+        log.info(u'insert row %d:%s'%(row,filename))
         # get short filename to display next to image
-        (prefix, shortfilename) = os.path.split(str(filename))
-        log.info("shortfilename=%s"%(shortfilename))
+        (prefix, shortfilename) = os.path.split(unicode(filename))
+        log.info(u'shortfilename=%s'%(shortfilename))
         # create a preview image
         self.items.insert(row, (filename, shortfilename))
         self.endInsertRows()
@@ -67,7 +67,7 @@
             retval= self.items[row][0]
         else:
             retval= QVariant()
-#         log.info("Returning"+ str(retval))
+#         log.info(u'Returning"+ unicode(retval))
         if type(retval) is not type(QVariant):
             return QVariant(retval)
         else:

=== modified file 'openlp/plugins/presentations/lib/impresscom.py'
--- openlp/plugins/presentations/lib/impresscom.py	2008-12-10 20:40:18 +0000
+++ openlp/plugins/presentations/lib/impresscom.py	2009-06-16 18:21:24 +0000
@@ -1,118 +1,118 @@
-from win32com.client import Dispatch
-
-# OOo API documentation:
-# http://api.openoffice.org/docs/common/ref/com/sun/star/presentation/XSlideShowController.html
-# http://docs.go-oo.org/sd/html/classsd_1_1SlideShow.html
-# http://www.oooforum.org/forum/viewtopic.phtml?t=5252
-# http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/Working_with_Presentations
-# http://mail.python.org/pipermail/python-win32/2008-January/006676.html
-
-class ImpressCOMApp(object):
-    def __init__(self):
-        self.createApp()
-
-    def createApp(self):
-        try:
-            self._sm = Dispatch("com.sun.star.ServiceManager")
-            self._app = self._sm.createInstance( "com.sun.star.frame.Desktop" )
-        except:
-            self._sm = None
-            self._app = None
-            return
-
-    def getApp(self):
-        if self._app == None:
-            self.createApp()
-            if self._app == None:
-                return None
-        return self._app
-
-    app = property(getApp)
-
-    def quit(self):
-        self._app.Terminate()
-        self._app = None
-        self._sm = None
-        
-class ImpressCOMPres(object):
-    def __init__(self, oooApp, filename):
-        self.oooApp = oooApp
-        self.filename = filename
-        self.open()
-        
-    def getPres(self):
-        if self._pres == None:
-            self.open()
-        return self._pres
-        
-    pres = property(getPres)
-    
-    def open(self):
-        self.comp = self.oooApp.app.loadComponentFromURL("file:///" + self.filename, "_blank", 0, []) 
-        self.presdoc = self.comp.getPresentation()
-        self.presdoc.start()
-        self._pres = self.presdoc.getController()
-        
-    def close(self):
-        self.pres.deactivate()
-        self.presdoc.end()
-        self.comp.dispose()
-        self._pres = None
-        self.presdoc = None
-        self.comp = None
-
-    def isActive(self):
-        return self.pres.isRunning() and self.pres.isActive()
- 
-    def resume(self):
-        return self.pres.resume()
-
-    def pause(self):
-        return self.pres.pause()
-
-    def blankScreen(self):
-        self.pres.blankScreen(0)
-    
-    def stop(self):
-        self.pres.deactivate()
-        # self.presdoc.end()
-
-    def go(self):
-        self.pres.activate()
-        # self.presdoc.start()
-
-    def getSlideNumber(self):
-        return self.pres.getCurrentSlideIndex
-        
-    def setSlideNumber(self, slideno):
-        self.pres.gotoSlideIndex(slideno)
-
-    slideNumber = property(getSlideNumber, setSlideNumber)
-
-    def nextStep(self):
-        self.pres.gotoNextEffect()
-
-    def prevStep(self):
-        self.pres.gotoPreviousSlide()
-
-    def moveWindow(self, top, height, left, width):
-        # position the window somehow
-        pass
-
-class ImpressCOMSlide(object):
-    def __init__(self, pres, index):
-        self.pres = pres
-        self.slide = pres.getSlideByIndex(index)
-
-    def preview(self):
-        if self.preview == None:
-            # get a slide somehow
-            pass
-        return self.preview
-
-if __name__ == '__main__':
-    ooo = ImpressCOMApp()
-    show = ImpressCOMPres(ooo, "c:/test1.ppt")
-    show.go()
-    show.resume()
-    show.nextStep()
+from win32com.client import Dispatch
+
+# OOo API documentation:
+# http://api.openoffice.org/docs/common/ref/com/sun/star/presentation/XSlideShowController.html
+# http://docs.go-oo.org/sd/html/classsd_1_1SlideShow.html
+# http://www.oooforum.org/forum/viewtopic.phtml?t=5252
+# http://wiki.services.openoffice.org/wiki/Documentation/DevGuide/Working_with_Presentations
+# http://mail.python.org/pipermail/python-win32/2008-January/006676.html
+
+class ImpressCOMApp(object):
+    def __init__(self):
+        self.createApp()
+
+    def createApp(self):
+        try:
+            self._sm = Dispatch(u'com.sun.star.ServiceManager')
+            self._app = self._sm.createInstance( "com.sun.star.frame.Desktop" )
+        except:
+            self._sm = None
+            self._app = None
+            return
+
+    def getApp(self):
+        if self._app == None:
+            self.createApp()
+            if self._app == None:
+                return None
+        return self._app
+
+    app = property(getApp)
+
+    def quit(self):
+        self._app.Terminate()
+        self._app = None
+        self._sm = None
+        
+class ImpressCOMPres(object):
+    def __init__(self, oooApp, filename):
+        self.oooApp = oooApp
+        self.filename = filename
+        self.open()
+        
+    def getPres(self):
+        if self._pres == None:
+            self.open()
+        return self._pres
+        
+    pres = property(getPres)
+    
+    def open(self):
+        self.comp = self.oooApp.app.loadComponentFromURL(u'file:///" + self.filename, "_blank", 0, []) 
+        self.presdoc = self.comp.getPresentation()
+        self.presdoc.start()
+        self._pres = self.presdoc.getController()
+        
+    def close(self):
+        self.pres.deactivate()
+        self.presdoc.end()
+        self.comp.dispose()
+        self._pres = None
+        self.presdoc = None
+        self.comp = None
+
+    def isActive(self):
+        return self.pres.isRunning() and self.pres.isActive()
+ 
+    def resume(self):
+        return self.pres.resume()
+
+    def pause(self):
+        return self.pres.pause()
+
+    def blankScreen(self):
+        self.pres.blankScreen(0)
+    
+    def stop(self):
+        self.pres.deactivate()
+        # self.presdoc.end()
+
+    def go(self):
+        self.pres.activate()
+        # self.presdoc.start()
+
+    def getSlideNumber(self):
+        return self.pres.getCurrentSlideIndex
+        
+    def setSlideNumber(self, slideno):
+        self.pres.gotoSlideIndex(slideno)
+
+    slideNumber = property(getSlideNumber, setSlideNumber)
+
+    def nextStep(self):
+        self.pres.gotoNextEffect()
+
+    def prevStep(self):
+        self.pres.gotoPreviousSlide()
+
+    def moveWindow(self, top, height, left, width):
+        # position the window somehow
+        pass
+
+class ImpressCOMSlide(object):
+    def __init__(self, pres, index):
+        self.pres = pres
+        self.slide = pres.getSlideByIndex(index)
+
+    def preview(self):
+        if self.preview == None:
+            # get a slide somehow
+            pass
+        return self.preview
+
+if __name__ == '__main__':
+    ooo = ImpressCOMApp()
+    show = ImpressCOMPres(ooo, "c:/test1.ppt')
+    show.go()
+    show.resume()
+    show.nextStep()
\ No newline at end of file

=== modified file 'openlp/plugins/presentations/lib/mediaitem.py'
--- openlp/plugins/presentations/lib/mediaitem.py	2009-06-05 05:13:34 +0000
+++ openlp/plugins/presentations/lib/mediaitem.py	2009-06-16 18:21:24 +0000
@@ -41,30 +41,30 @@
         # Create buttons for the toolbar
         ## New Presentation Button ##
         self.addToolbarButton(
-            translate('PresentationsMediaItem',u'New presentations'),
-            translate('PresentationsMediaItem',u'Load presentations into openlp.org'),
+            translate(u'PresentationsMediaItem',u'New presentations'),
+            translate(u'PresentationsMediaItem',u'Load presentations into openlp.org'),
             ':/presentations/presentation_load.png', self.onPresentationNewClick, 'PresentationNewItem')
         ## Delete Presentation Button ##
         self.addToolbarButton(
-            translate('PresentationsMediaItem',u'Delete Presentation'),
-            translate('PresentationsMediaItem',u'Delete the selected presentation'),
+            translate(u'PresentationsMediaItem',u'Delete Presentation'),
+            translate(u'PresentationsMediaItem',u'Delete the selected presentation'),
             ':/presentations/presentation_delete.png', self.onPresentationDeleteClick, 'PresentationDeleteItem')
         ## Separator Line ##
         self.addToolbarSeparator()
         ## Preview Presentation Button ##
         self.addToolbarButton(
-            translate('PresentationsMediaItem',u'Preview Presentation'),
-            translate('PresentationsMediaItem',u'Preview the selected Presentation'),
+            translate(u'PresentationsMediaItem',u'Preview Presentation'),
+            translate(u'PresentationsMediaItem',u'Preview the selected Presentation'),
             ':/system/system_preview.png', self.onPresentationPreviewClick, 'PresentationPreviewItem')
         ## Live Presentation Button ##
         self.addToolbarButton(
-            translate('PresentationsMediaItem',u'Go Live'),
-            translate('PresentationsMediaItem',u'Send the selected presentation live'),
+            translate(u'PresentationsMediaItem',u'Go Live'),
+            translate(u'PresentationsMediaItem',u'Send the selected presentation live'),
             ':/system/system_live.png', self.onPresentationLiveClick, 'PresentationLiveItem')
         ## Add Presentation Button ##
         self.addToolbarButton(
-            translate('PresentationsMediaItem',u'Add Presentation To Service'),
-            translate('PresentationsMediaItem',u'Add the selected Presentations(s) to the service'),
+            translate(u'PresentationsMediaItem',u'Add Presentation To Service'),
+            translate(u'PresentationsMediaItem',u'Add the selected Presentations(s) to the service'),
             ':/system/system_add.png',self.onPresentationAddClick, 'PresentationsAddItem')
         ## Add the Presentationlist widget ##
 
@@ -74,17 +74,17 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.PresentationWidget.sizePolicy().hasHeightForWidth())
         self.PresentationWidget.setSizePolicy(sizePolicy)
-        self.PresentationWidget.setObjectName('PresentationWidget')
+        self.PresentationWidget.setObjectName(u'PresentationWidget')
         self.DisplayLayout = QtGui.QGridLayout(self.PresentationWidget)
-        self.DisplayLayout.setObjectName('DisplayLayout')
+        self.DisplayLayout.setObjectName(u'DisplayLayout')
         self.DisplayTypeComboBox = QtGui.QComboBox(self.PresentationWidget)
-        self.DisplayTypeComboBox.setObjectName('DisplayTypeComboBox')
+        self.DisplayTypeComboBox.setObjectName(u'DisplayTypeComboBox')
         self.DisplayLayout.addWidget(self.DisplayTypeComboBox, 0, 1, 1, 2)
         self.DisplayTypeLabel = QtGui.QLabel(self.PresentationWidget)
-        self.DisplayTypeLabel.setObjectName('SearchTypeLabel')
+        self.DisplayTypeLabel.setObjectName(u'SearchTypeLabel')
         self.DisplayLayout.addWidget(self.DisplayTypeLabel, 0, 0, 1, 1)
 
-        self.DisplayTypeLabel.setText(translate('PresentationMediaItem', u'Present using:'))
+        self.DisplayTypeLabel.setText(translate(u'PresentationMediaItem', u'Present using:'))
 
         # Add the song widget to the page layout
         self.PageLayout.addWidget(self.PresentationWidget)
@@ -101,13 +101,13 @@
 
         self.PresentationsListView.addAction(self.contextMenuAction(
             self.PresentationsListView, ':/system/system_preview.png',
-            translate('PresentationsMediaItem',u'&Preview presentations'), self.onPresentationPreviewClick))
+            translate(u'PresentationsMediaItem',u'&Preview presentations'), self.onPresentationPreviewClick))
         self.PresentationsListView.addAction(self.contextMenuAction(
             self.PresentationsListView, ':/system/system_live.png',
-            translate('PresentationsMediaItem',u'&Show Live'), self.onPresentationLiveClick))
+            translate(u'PresentationsMediaItem',u'&Show Live'), self.onPresentationLiveClick))
         self.PresentationsListView.addAction(self.contextMenuAction(
             self.PresentationsListView, ':/system/system_add.png',
-            translate('PresentationsMediaItem',u'&Add to Service'), self.onPresentationAddClick))
+            translate(u'PresentationsMediaItem',u'&Add to Service'), self.onPresentationAddClick))
 
     def initialise(self):
         list = self.parent.config.load_list(u'presentations')
@@ -118,11 +118,11 @@
 
     def onPresentationNewClick(self):
         files = QtGui.QFileDialog.getOpenFileNames(None,
-            translate('PresentationsMediaItem', u'Select presentations(s)'),
+            translate(u'PresentationsMediaItem', u'Select presentations(s)'),
             self.parent.config.get_last_dir(), u'Presentations (*.ppt *.pps *.odp)')
         if len(files) > 0:
             self.loadPresentationList(files)
-            dir, filename = os.path.split(str(files[0]))
+            dir, filename = os.path.split(unicode(files[0]))
             self.parent.config.set_last_dir(dir)
             self.parent.config.set_list(u'Presentations', self.PresentationsListData.getFileList())
 
@@ -148,4 +148,4 @@
         pass
 
     def onPresentationAddClick(self):
-        pass
+        pass
\ No newline at end of file

=== modified file 'openlp/plugins/presentations/lib/powerpoint.py'
--- openlp/plugins/presentations/lib/powerpoint.py	2008-12-10 20:40:18 +0000
+++ openlp/plugins/presentations/lib/powerpoint.py	2009-06-16 18:21:24 +0000
@@ -1,139 +1,139 @@
-from win32com.client import Dispatch
-
-# PPT API documentation:
-# http://msdn.microsoft.com/en-us/library/aa269321(office.10).aspx
-
-
-class PowerPointApp(object):
-    def __init__(self):
-        self.createApp()
-
-    def createApp(self):
-        try:
-            self._app = Dispatch("PowerPoint.Application")
-        except:
-            self._app = None
-            return
-        self._app.Visible = True
-        self._app.WindowState = 2
-
-    def getApp(self):
-        if self._app == None:
-            self.createApp()
-            if self._app == None:
-                return None
-        if self._app.Windows.Count == 0:
-            self.createApp()
-        return self._app
-
-    app = property(getApp)
-
-    def quit(self):
-        self._app.Quit()
-        self._app = None
-        
-class PowerPointPres(object):
-    def __init__(self, pptApp, filename):
-        self.pptApp = pptApp
-        self.filename = filename
-        self.open()
-        
-    def getPres(self):
-        if self._pres == None:
-            for p in self.pptApp.app.Presentations:
-                if p.FullName == self.filename:
-                    self._pres = p
-                    break
-        if self._pres != None:
-            try:
-                x = self._pres.Name
-            except:
-                self._pres = None
-        if self._pres == None:
-            self.openPres()
-        return self._pres
-        
-    pres = property(getPres)
-    
-    def open(self):
-        self.pptApp.app.Presentations.Open(self.filename, False, False, True)
-        self._pres = self.pptApp.app.Presentations(ppt.app.Presentations.Count)
-
-    def close(self):
-        self.pres.Close()
-        self._pres = None
-
-    def isActive(self):
-        if self.pres.SlideShowWindow == None:
-            return False
-        if self.pres.SlideShowWindow.View == None:
-            return False
-        return True
-
-    def resume(self):
-        self.pres.SlideShowSettings.Run()
-        self.pres.SlideShowWindow.View.State = 1
-        self.pres.SlideShowWindow.Activate()
-
-    def pause(self):
-        if self.isActive():
-            self.pres.SlideShowWindow.View.State = 2
-
-    def blankScreen(self):
-        if self.isActive():
-            self.pres.SlideShowWindow.View.State = 3
-    
-    def stop(self):
-        if self.isActive():
-            self.pres.SlideShowWindow.View.Exit()
-    
-    def go(self):
-        self.pres.SlideShowSettings.Run()
-
-    def getCurrentSlideIndex(self):
-        if self.isActive():
-            return self.pres.SlideShowWindow.View.CurrentShowPosition
-        else:
-            return -1
-        
-    def setCurrentSlideIndex(self, slideno):
-        if not self.isActive():
-            self.resume()
-        self.pres.SlideShowWindow.View.GotoSlide(slideno)
-
-    currentSlideIndex = property(getSlideNumber, setSlideNumber)
-
-    def nextStep(self):
-        if not self.isActive():
-            self.resume()
-        self.pres.SlideShowWindow.View.Next()
-
-    def prevStep(self):
-        if not self.isActive():
-            self.resume()
-        self.pres.SlideShowWindow.View.Previous()
-
-    def moveWindow(self, top, height, left, width):
-        if not self.isActive():
-            self.resume()
-        self.pres.SlideShowWindow.Top = top / 20
-        self.pres.SlideShowWindow.Height = height / 20
-        self.pres.SlideShowWindow.Left = left / 20
-        self.pres.SlideShowWindow.Width = width / 20
-
-class PowerPointSlide(object):
-    def __init__(self, pres, index):
-        self.pres = pres
-        self.slide = pres.Slides[index]
-
-    def preview(self):
-        if self.preview == None:
-            self.slide.Copy
-            # import win32clipboard as w
-            # import win32con
-            # w.OpenClipboard()
-            # self.preview = w.GetClipboardData.GetData(win32con.CF_BITMAP)
-            # w.CloseClipboard()
-        return self.preview
-
-    
+from win32com.client import Dispatch
+
+# PPT API documentation:
+# http://msdn.microsoft.com/en-us/library/aa269321(office.10).aspx
+
+
+class PowerPointApp(object):
+    def __init__(self):
+        self.createApp()
+
+    def createApp(self):
+        try:
+            self._app = Dispatch(u'PowerPoint.Application')
+        except:
+            self._app = None
+            return
+        self._app.Visible = True
+        self._app.WindowState = 2
+
+    def getApp(self):
+        if self._app == None:
+            self.createApp()
+            if self._app == None:
+                return None
+        if self._app.Windows.Count == 0:
+            self.createApp()
+        return self._app
+
+    app = property(getApp)
+
+    def quit(self):
+        self._app.Quit()
+        self._app = None
+        
+class PowerPointPres(object):
+    def __init__(self, pptApp, filename):
+        self.pptApp = pptApp
+        self.filename = filename
+        self.open()
+        
+    def getPres(self):
+        if self._pres == None:
+            for p in self.pptApp.app.Presentations:
+                if p.FullName == self.filename:
+                    self._pres = p
+                    break
+        if self._pres != None:
+            try:
+                x = self._pres.Name
+            except:
+                self._pres = None
+        if self._pres == None:
+            self.openPres()
+        return self._pres
+        
+    pres = property(getPres)
+    
+    def open(self):
+        self.pptApp.app.Presentations.Open(self.filename, False, False, True)
+        self._pres = self.pptApp.app.Presentations(ppt.app.Presentations.Count)
+
+    def close(self):
+        self.pres.Close()
+        self._pres = None
+
+    def isActive(self):
+        if self.pres.SlideShowWindow == None:
+            return False
+        if self.pres.SlideShowWindow.View == None:
+            return False
+        return True
+
+    def resume(self):
+        self.pres.SlideShowSettings.Run()
+        self.pres.SlideShowWindow.View.State = 1
+        self.pres.SlideShowWindow.Activate()
+
+    def pause(self):
+        if self.isActive():
+            self.pres.SlideShowWindow.View.State = 2
+
+    def blankScreen(self):
+        if self.isActive():
+            self.pres.SlideShowWindow.View.State = 3
+    
+    def stop(self):
+        if self.isActive():
+            self.pres.SlideShowWindow.View.Exit()
+    
+    def go(self):
+        self.pres.SlideShowSettings.Run()
+
+    def getCurrentSlideIndex(self):
+        if self.isActive():
+            return self.pres.SlideShowWindow.View.CurrentShowPosition
+        else:
+            return -1
+        
+    def setCurrentSlideIndex(self, slideno):
+        if not self.isActive():
+            self.resume()
+        self.pres.SlideShowWindow.View.GotoSlide(slideno)
+
+    currentSlideIndex = property(getSlideNumber, setSlideNumber)
+
+    def nextStep(self):
+        if not self.isActive():
+            self.resume()
+        self.pres.SlideShowWindow.View.Next()
+
+    def prevStep(self):
+        if not self.isActive():
+            self.resume()
+        self.pres.SlideShowWindow.View.Previous()
+
+    def moveWindow(self, top, height, left, width):
+        if not self.isActive():
+            self.resume()
+        self.pres.SlideShowWindow.Top = top / 20
+        self.pres.SlideShowWindow.Height = height / 20
+        self.pres.SlideShowWindow.Left = left / 20
+        self.pres.SlideShowWindow.Width = width / 20
+
+class PowerPointSlide(object):
+    def __init__(self, pres, index):
+        self.pres = pres
+        self.slide = pres.Slides[index]
+
+    def preview(self):
+        if self.preview == None:
+            self.slide.Copy
+            # import win32clipboard as w
+            # import win32con
+            # w.OpenClipboard()
+            # self.preview = w.GetClipboardData.GetData(win32con.CF_BITMAP)
+            # w.CloseClipboard()
+        return self.preview
+
+    
\ No newline at end of file

=== modified file 'openlp/plugins/presentations/lib/pptview.py'
--- openlp/plugins/presentations/lib/pptview.py	2008-12-10 20:40:18 +0000
+++ openlp/plugins/presentations/lib/pptview.py	2009-06-16 18:21:24 +0000
@@ -1,126 +1,125 @@
-import sys
-import win32api
-from PyQt4 import QtGui, QtCore
-from ctypes import *
-from ctypes.wintypes import RECT
-
-pptdll = cdll.LoadLibrary(r"C:\Documents and Settings\jonathan\My Documents\Personal\openlp\openlp-2\trunk\openlp\libraries\pptviewlib\pptviewlib.dll")
-
-class BoxLayout(QtGui.QWidget):
-    def __init__(self, parent=None):
-        QtGui.QWidget.__init__(self, parent)
-        self.pptid = -1
-        self.setWindowTitle('box layout')
-
-        PPTLabel = QtGui.QLabel('Open PowerPoint file')
-        slideLabel = QtGui.QLabel('Go to slide #')
-        self.PPTEdit = QtGui.QLineEdit()
-        self.slideEdit = QtGui.QLineEdit()
-        self.total = QtGui.QLabel()
-        PPTBtn = QtGui.QPushButton("Open")
-        PPTDlgBtn = QtGui.QPushButton("...")
-        slideBtn = QtGui.QPushButton("Go")
-        prev = QtGui.QPushButton("Prev")
-        next = QtGui.QPushButton("Next")
-        blank = QtGui.QPushButton("Blank")
-        unblank = QtGui.QPushButton("Unblank")
-        restart = QtGui.QPushButton("Restart")
-        close = QtGui.QPushButton("Close")
-        resume = QtGui.QPushButton("Resume")
-        stop = QtGui.QPushButton("Stop")
-        pptwindow = QtGui.QWidget()
-
-        grid = QtGui.QGridLayout()
-        grid.addWidget(PPTLabel, 0, 0)
-        grid.addWidget(self.PPTEdit, 0, 1)
-        grid.addWidget(PPTDlgBtn, 0, 2)
-        grid.addWidget(PPTBtn, 0, 3)
-        grid.addWidget(slideLabel, 1, 0)
-        grid.addWidget(self.slideEdit, 1, 1)
-        grid.addWidget(slideBtn, 1, 3)
-        grid.addWidget(prev, 2, 0)
-        grid.addWidget(next, 2, 1)
-        grid.addWidget(blank, 3, 0)
-        grid.addWidget(unblank, 3, 1)
-        grid.addWidget(restart, 4, 0)
-        grid.addWidget(stop, 4, 1)
-        grid.addWidget(resume, 4, 2)
-        grid.addWidget(pptwindow, 5, 0, 10, 3)
-        self.connect(PPTBtn, QtCore.SIGNAL('clicked()'), self.OpenClick)
-        self.connect(PPTDlgBtn, QtCore.SIGNAL('clicked()'), self.OpenDialog)
-        self.connect(slideBtn, QtCore.SIGNAL('clicked()'), self.GotoClick)
-        self.connect(prev, QtCore.SIGNAL('clicked()'), self.PrevClick)
-        self.connect(next, QtCore.SIGNAL('clicked()'), self.NextClick)
-        self.connect(blank, QtCore.SIGNAL('clicked()'), self.BlankClick)
-        self.connect(unblank, QtCore.SIGNAL('clicked()'), self.UnblankClick)
-        self.connect(restart, QtCore.SIGNAL('clicked()'), self.RestartClick)
-        self.connect(close, QtCore.SIGNAL('clicked()'), self.CloseClick)
-        self.connect(stop, QtCore.SIGNAL('clicked()'), self.StopClick)
-        self.connect(resume, QtCore.SIGNAL('clicked()'), self.ResumeClick)
-
-        self.setLayout(grid)
-
-        self.resize(300, 150)
-
-    def PrevClick(self):
-        if self.pptid<0: return
-        pptdll.PrevStep(self.pptid)
-        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
-    
-    def NextClick(self):
-        if(self.pptid<0): return
-        pptdll.NextStep(self.pptid)
-        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
-    
-    def BlankClick(self):
-        if(self.pptid<0): return
-        pptdll.Blank(self.pptid)
-    
-    def UnblankClick(self):
-        if(self.pptid<0): return
-        pptdll.Unblank(self.pptid)
-    
-    def RestartClick(self):
-        if(self.pptid<0): return
-        pptdll.RestartShow(self.pptid)
-        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
-    
-    def StopClick(self):
-        if(self.pptid<0): return
-        pptdll.Stop(self.pptid)
-    
-    def ResumeClick(self):
-        if(self.pptid<0): return
-        pptdll.Resume(self.pptid)
-
-    def CloseClick(self):
-        if(self.pptid<0): return
-        pptdll.Close(self.pptid)
-        self.pptid = -1
-
-    def OpenClick(self):
-        if(self.pptid>=0):
-            self.CloseClick()
-        rect = RECT()
-        rect.left = 100
-        rect.top = 100
-        rect.width = 900
-        rect.hight = 700
-        #self.pptid = pptdll.OpenPPT(self.PPTEdit.text, None, rect, "c:\temp\slide")
-        self.pptid = pptdll.OpenPPT("C:\\test 1.ppt", None, rect, "c:\temp\slide")
-        self.total.setText(pptdll.GetSlideCount(self.pptid))
-        self.slideEdit.setText(str(pptdll.GetCurrentSlide(self.pptid)))
-
-    def GotoClick(self):
-        if(self.pptid<0): return
-        pptdll.GotoSlide(self.pptid, self.slideEdit.text)
-        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
-
-    def OpenDialog(self):
-        self.PPTEdit.setText(QtGui.QFileDialog.getOpenFileName(self, 'Open file'))
-
-app = QtGui.QApplication(sys.argv)
-qb = BoxLayout()
-qb.show()
-sys.exit(app.exec_())
-
+import sys
+import win32api
+from PyQt4 import QtGui, QtCore
+from ctypes import *
+from ctypes.wintypes import RECT
+
+pptdll = cdll.LoadLibrary(r"C:\Documents and Settings\jonathan\My Documents\Personal\openlp\openlp-2\trunk\openlp\libraries\pptviewlib\pptviewlib.dll')
+
+class BoxLayout(QtGui.QWidget):
+    def __init__(self, parent=None):
+        QtGui.QWidget.__init__(self, parent)
+        self.pptid = -1
+        self.setWindowTitle(u'box layout')
+
+        PPTLabel = QtGui.QLabel(u'Open PowerPoint file')
+        slideLabel = QtGui.QLabel(u'Go to slide #')
+        self.PPTEdit = QtGui.QLineEdit()
+        self.slideEdit = QtGui.QLineEdit()
+        self.total = QtGui.QLabel()
+        PPTBtn = QtGui.QPushButton(u'Open')
+        PPTDlgBtn = QtGui.QPushButton(u'...')
+        slideBtn = QtGui.QPushButton(u'Go')
+        prev = QtGui.QPushButton(u'Prev')
+        next = QtGui.QPushButton(u'Next')
+        blank = QtGui.QPushButton(u'Blank')
+        unblank = QtGui.QPushButton(u'Unblank')
+        restart = QtGui.QPushButton(u'Restart')
+        close = QtGui.QPushButton(u'Close')
+        resume = QtGui.QPushButton(u'Resume')
+        stop = QtGui.QPushButton(u'Stop')
+        pptwindow = QtGui.QWidget()
+
+        grid = QtGui.QGridLayout()
+        grid.addWidget(PPTLabel, 0, 0)
+        grid.addWidget(self.PPTEdit, 0, 1)
+        grid.addWidget(PPTDlgBtn, 0, 2)
+        grid.addWidget(PPTBtn, 0, 3)
+        grid.addWidget(slideLabel, 1, 0)
+        grid.addWidget(self.slideEdit, 1, 1)
+        grid.addWidget(slideBtn, 1, 3)
+        grid.addWidget(prev, 2, 0)
+        grid.addWidget(next, 2, 1)
+        grid.addWidget(blank, 3, 0)
+        grid.addWidget(unblank, 3, 1)
+        grid.addWidget(restart, 4, 0)
+        grid.addWidget(stop, 4, 1)
+        grid.addWidget(resume, 4, 2)
+        grid.addWidget(pptwindow, 5, 0, 10, 3)
+        self.connect(PPTBtn, QtCore.SIGNAL(u'clicked()'), self.OpenClick)
+        self.connect(PPTDlgBtn, QtCore.SIGNAL(u'clicked()'), self.OpenDialog)
+        self.connect(slideBtn, QtCore.SIGNAL(u'clicked()'), self.GotoClick)
+        self.connect(prev, QtCore.SIGNAL(u'clicked()'), self.PrevClick)
+        self.connect(next, QtCore.SIGNAL(u'clicked()'), self.NextClick)
+        self.connect(blank, QtCore.SIGNAL(u'clicked()'), self.BlankClick)
+        self.connect(unblank, QtCore.SIGNAL(u'clicked()'), self.UnblankClick)
+        self.connect(restart, QtCore.SIGNAL(u'clicked()'), self.RestartClick)
+        self.connect(close, QtCore.SIGNAL(u'clicked()'), self.CloseClick)
+        self.connect(stop, QtCore.SIGNAL(u'clicked()'), self.StopClick)
+        self.connect(resume, QtCore.SIGNAL(u'clicked()'), self.ResumeClick)
+
+        self.setLayout(grid)
+
+        self.resize(300, 150)
+
+    def PrevClick(self):
+        if self.pptid<0: return
+        pptdll.PrevStep(self.pptid)
+        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
+    
+    def NextClick(self):
+        if(self.pptid<0): return
+        pptdll.NextStep(self.pptid)
+        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
+    
+    def BlankClick(self):
+        if(self.pptid<0): return
+        pptdll.Blank(self.pptid)
+    
+    def UnblankClick(self):
+        if(self.pptid<0): return
+        pptdll.Unblank(self.pptid)
+    
+    def RestartClick(self):
+        if(self.pptid<0): return
+        pptdll.RestartShow(self.pptid)
+        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
+    
+    def StopClick(self):
+        if(self.pptid<0): return
+        pptdll.Stop(self.pptid)
+    
+    def ResumeClick(self):
+        if(self.pptid<0): return
+        pptdll.Resume(self.pptid)
+
+    def CloseClick(self):
+        if(self.pptid<0): return
+        pptdll.Close(self.pptid)
+        self.pptid = -1
+
+    def OpenClick(self):
+        if(self.pptid>=0):
+            self.CloseClick()
+        rect = RECT()
+        rect.left = 100
+        rect.top = 100
+        rect.width = 900
+        rect.hight = 700
+        #self.pptid = pptdll.OpenPPT(self.PPTEdit.text, None, rect, "c:\temp\slide')
+        self.pptid = pptdll.OpenPPT(u'C:\\test 1.ppt", None, rect, "c:\temp\slide')
+        self.total.setText(pptdll.GetSlideCount(self.pptid))
+        self.slideEdit.setText(unicode(pptdll.GetCurrentSlide(self.pptid)))
+
+    def GotoClick(self):
+        if(self.pptid<0): return
+        pptdll.GotoSlide(self.pptid, self.slideEdit.text)
+        self.slideEdit.setText(pptdll.GetCurrentSlide(self.pptid))
+
+    def OpenDialog(self):
+        self.PPTEdit.setText(QtGui.QFileDialog.getOpenFileName(self, 'Open file'))
+
+app = QtGui.QApplication(sys.argv)
+qb = BoxLayout()
+qb.show()
+sys.exit(app.exec_())
\ No newline at end of file

=== modified file 'openlp/plugins/presentations/lib/pptviewlib/ppttest.py'
--- openlp/plugins/presentations/lib/pptviewlib/ppttest.py	2008-12-10 20:40:18 +0000
+++ openlp/plugins/presentations/lib/pptviewlib/ppttest.py	2009-06-16 18:21:24 +0000
@@ -1,147 +1,146 @@
-import sys
-from PyQt4 import QtGui, QtCore
-from ctypes import *
-from ctypes.wintypes import RECT
-
-class PPTViewer(QtGui.QWidget):
-    def __init__(self, parent=None):
-        QtGui.QWidget.__init__(self, parent)
-        self.pptid = -1
-        self.setWindowTitle('PowerPoint Viewer Test')
-
-        PPTLabel = QtGui.QLabel('Open PowerPoint file')
-        slideLabel = QtGui.QLabel('Go to slide #')
-        self.PPTEdit = QtGui.QLineEdit()
-        self.slideEdit = QtGui.QLineEdit()
-        self.total = QtGui.QLabel()
-        PPTBtn = QtGui.QPushButton("Open")
-        PPTDlgBtn = QtGui.QPushButton("...")
-        slideBtn = QtGui.QPushButton("Go")
-        prev = QtGui.QPushButton("Prev")
-        next = QtGui.QPushButton("Next")
-        blank = QtGui.QPushButton("Blank")
-        unblank = QtGui.QPushButton("Unblank")
-        restart = QtGui.QPushButton("Restart")
-        close = QtGui.QPushButton("Close")
-        resume = QtGui.QPushButton("Resume")
-        stop = QtGui.QPushButton("Stop")
-        pptwindow = QtGui.QWidget()
-
-        grid = QtGui.QGridLayout()
-        grid.addWidget(PPTLabel, 0, 0)
-        grid.addWidget(self.PPTEdit, 0, 1)
-        grid.addWidget(PPTDlgBtn, 0, 2)
-        grid.addWidget(PPTBtn, 0, 3)
-        grid.addWidget(slideLabel, 1, 0)
-        grid.addWidget(self.slideEdit, 1, 1)
-        grid.addWidget(slideBtn, 1, 3)
-        grid.addWidget(prev, 2, 0)
-        grid.addWidget(next, 2, 1)
-        grid.addWidget(blank, 3, 0)
-        grid.addWidget(unblank, 3, 1)
-        grid.addWidget(restart, 4, 0)
-        grid.addWidget(close, 4, 1)
-        grid.addWidget(stop, 5, 0)
-        grid.addWidget(resume, 5, 1)
-        grid.addWidget(pptwindow, 6, 0, 10, 3)
-        self.connect(PPTBtn, QtCore.SIGNAL('clicked()'), self.OpenClick)
-        self.connect(PPTDlgBtn, QtCore.SIGNAL('clicked()'), self.OpenDialog)
-        self.connect(slideBtn, QtCore.SIGNAL('clicked()'), self.GotoClick)
-        self.connect(prev, QtCore.SIGNAL('clicked()'), self.PrevClick)
-        self.connect(next, QtCore.SIGNAL('clicked()'), self.NextClick)
-        self.connect(blank, QtCore.SIGNAL('clicked()'), self.BlankClick)
-        self.connect(unblank, QtCore.SIGNAL('clicked()'), self.UnblankClick)
-        self.connect(restart, QtCore.SIGNAL('clicked()'), self.RestartClick)
-        self.connect(close, QtCore.SIGNAL('clicked()'), self.CloseClick)
-        self.connect(stop, QtCore.SIGNAL('clicked()'), self.StopClick)
-        self.connect(resume, QtCore.SIGNAL('clicked()'), self.ResumeClick)
-
-        self.setLayout(grid)
-
-        self.resize(300, 150)
-
-    def PrevClick(self):
-        if self.pptid<0: return
-        pptdll.PrevStep(self.pptid)
-        self.UpdateCurrSlide()
-        app.processEvents()
-    
-    def NextClick(self):
-        if(self.pptid<0): return
-        pptdll.NextStep(self.pptid)
-        self.UpdateCurrSlide()
-        app.processEvents()
-    
-    def BlankClick(self):
-        if(self.pptid<0): return
-        pptdll.Blank(self.pptid)
-        app.processEvents()
-    
-    def UnblankClick(self):
-        if(self.pptid<0): return
-        pptdll.Unblank(self.pptid)
-        app.processEvents()
-    
-    def RestartClick(self):
-        if(self.pptid<0): return
-        pptdll.RestartShow(self.pptid)
-        self.UpdateCurrSlide()
-        app.processEvents()
-    
-    def StopClick(self):
-        if(self.pptid<0): return
-        pptdll.Stop(self.pptid)
-        app.processEvents()
-    
-    def ResumeClick(self):
-        if(self.pptid<0): return
-        pptdll.Resume(self.pptid)
-        app.processEvents()
-
-    def CloseClick(self):
-        if(self.pptid<0): return
-        pptdll.ClosePPT(self.pptid)
-        self.pptid = -1
-        app.processEvents()
-
-    def OpenClick(self):
-        oldid = self.pptid;
-        rect = RECT(100,100,900,700)
-        filename = str(self.PPTEdit.text())
-        print filename
-        self.pptid = pptdll.OpenPPT(filename, None, rect, "c:\\temp\\slide")
-        print "id: " + str(self.pptid)
-        if oldid>=0:
-            pptdll.ClosePPT(oldid);
-        slides = pptdll.GetSlideCount(self.pptid)
-        print "slidecount: " + str(slides)
-        self.total.setNum(pptdll.GetSlideCount(self.pptid))
-        self.UpdateCurrSlide()
-            
-    def UpdateCurrSlide(self):
-        if(self.pptid<0): return
-        slide = str(pptdll.GetCurrentSlide(self.pptid))
-        print "currslide: " + slide
-        self.slideEdit.setText(slide)
-        app.processEvents()
-
-    def GotoClick(self):
-        if(self.pptid<0): return
-        print self.slideEdit.text()
-        pptdll.GotoSlide(self.pptid, int(self.slideEdit.text()))
-        self.UpdateCurrSlide()
-        app.processEvents()
-
-    def OpenDialog(self):
-        self.PPTEdit.setText(QtGui.QFileDialog.getOpenFileName(self, 'Open file'))
-
-if __name__ == '__main__':
-    #pptdll = cdll.LoadLibrary(r"C:\Documents and Settings\jonathan\Desktop\pptviewlib.dll")
-    pptdll = cdll.LoadLibrary(r"pptviewlib.dll")
-    pptdll.SetDebug(1)
-    print "Begin..."
-    app = QtGui.QApplication(sys.argv)
-    qb = PPTViewer()
-    qb.show()
-    sys.exit(app.exec_())
-
+import sys
+from PyQt4 import QtGui, QtCore
+from ctypes import *
+from ctypes.wintypes import RECT
+
+class PPTViewer(QtGui.QWidget):
+    def __init__(self, parent=None):
+        QtGui.QWidget.__init__(self, parent)
+        self.pptid = -1
+        self.setWindowTitle(u'PowerPoint Viewer Test')
+
+        PPTLabel = QtGui.QLabel(u'Open PowerPoint file')
+        slideLabel = QtGui.QLabel(u'Go to slide #')
+        self.PPTEdit = QtGui.QLineEdit()
+        self.slideEdit = QtGui.QLineEdit()
+        self.total = QtGui.QLabel()
+        PPTBtn = QtGui.QPushButton(u'Open')
+        PPTDlgBtn = QtGui.QPushButton(u'...')
+        slideBtn = QtGui.QPushButton(u'Go')
+        prev = QtGui.QPushButton(u'Prev')
+        next = QtGui.QPushButton(u'Next')
+        blank = QtGui.QPushButton(u'Blank')
+        unblank = QtGui.QPushButton(u'Unblank')
+        restart = QtGui.QPushButton(u'Restart')
+        close = QtGui.QPushButton(u'Close')
+        resume = QtGui.QPushButton(u'Resume')
+        stop = QtGui.QPushButton(u'Stop')
+        pptwindow = QtGui.QWidget()
+
+        grid = QtGui.QGridLayout()
+        grid.addWidget(PPTLabel, 0, 0)
+        grid.addWidget(self.PPTEdit, 0, 1)
+        grid.addWidget(PPTDlgBtn, 0, 2)
+        grid.addWidget(PPTBtn, 0, 3)
+        grid.addWidget(slideLabel, 1, 0)
+        grid.addWidget(self.slideEdit, 1, 1)
+        grid.addWidget(slideBtn, 1, 3)
+        grid.addWidget(prev, 2, 0)
+        grid.addWidget(next, 2, 1)
+        grid.addWidget(blank, 3, 0)
+        grid.addWidget(unblank, 3, 1)
+        grid.addWidget(restart, 4, 0)
+        grid.addWidget(close, 4, 1)
+        grid.addWidget(stop, 5, 0)
+        grid.addWidget(resume, 5, 1)
+        grid.addWidget(pptwindow, 6, 0, 10, 3)
+        self.connect(PPTBtn, QtCore.SIGNAL(u'clicked()'), self.OpenClick)
+        self.connect(PPTDlgBtn, QtCore.SIGNAL(u'clicked()'), self.OpenDialog)
+        self.connect(slideBtn, QtCore.SIGNAL(u'clicked()'), self.GotoClick)
+        self.connect(prev, QtCore.SIGNAL(u'clicked()'), self.PrevClick)
+        self.connect(next, QtCore.SIGNAL(u'clicked()'), self.NextClick)
+        self.connect(blank, QtCore.SIGNAL(u'clicked()'), self.BlankClick)
+        self.connect(unblank, QtCore.SIGNAL(u'clicked()'), self.UnblankClick)
+        self.connect(restart, QtCore.SIGNAL(u'clicked()'), self.RestartClick)
+        self.connect(close, QtCore.SIGNAL(u'clicked()'), self.CloseClick)
+        self.connect(stop, QtCore.SIGNAL(u'clicked()'), self.StopClick)
+        self.connect(resume, QtCore.SIGNAL(u'clicked()'), self.ResumeClick)
+
+        self.setLayout(grid)
+
+        self.resize(300, 150)
+
+    def PrevClick(self):
+        if self.pptid<0: return
+        pptdll.PrevStep(self.pptid)
+        self.UpdateCurrSlide()
+        app.processEvents()
+    
+    def NextClick(self):
+        if(self.pptid<0): return
+        pptdll.NextStep(self.pptid)
+        self.UpdateCurrSlide()
+        app.processEvents()
+    
+    def BlankClick(self):
+        if(self.pptid<0): return
+        pptdll.Blank(self.pptid)
+        app.processEvents()
+    
+    def UnblankClick(self):
+        if(self.pptid<0): return
+        pptdll.Unblank(self.pptid)
+        app.processEvents()
+    
+    def RestartClick(self):
+        if(self.pptid<0): return
+        pptdll.RestartShow(self.pptid)
+        self.UpdateCurrSlide()
+        app.processEvents()
+    
+    def StopClick(self):
+        if(self.pptid<0): return
+        pptdll.Stop(self.pptid)
+        app.processEvents()
+    
+    def ResumeClick(self):
+        if(self.pptid<0): return
+        pptdll.Resume(self.pptid)
+        app.processEvents()
+
+    def CloseClick(self):
+        if(self.pptid<0): return
+        pptdll.ClosePPT(self.pptid)
+        self.pptid = -1
+        app.processEvents()
+
+    def OpenClick(self):
+        oldid = self.pptid;
+        rect = RECT(100,100,900,700)
+        filename = unicode(self.PPTEdit.text())
+        print filename
+        self.pptid = pptdll.OpenPPT(filename, None, rect, "c:\\temp\\slide')
+        print "id: " + unicode(self.pptid)
+        if oldid>=0:
+            pptdll.ClosePPT(oldid);
+        slides = pptdll.GetSlideCount(self.pptid)
+        print "slidecount: " + unicode(slides)
+        self.total.setNum(pptdll.GetSlideCount(self.pptid))
+        self.UpdateCurrSlide()
+            
+    def UpdateCurrSlide(self):
+        if(self.pptid<0): return
+        slide = unicode(pptdll.GetCurrentSlide(self.pptid))
+        print "currslide: " + slide
+        self.slideEdit.setText(slide)
+        app.processEvents()
+
+    def GotoClick(self):
+        if(self.pptid<0): return
+        print self.slideEdit.text()
+        pptdll.GotoSlide(self.pptid, int(self.slideEdit.text()))
+        self.UpdateCurrSlide()
+        app.processEvents()
+
+    def OpenDialog(self):
+        self.PPTEdit.setText(QtGui.QFileDialog.getOpenFileName(self, 'Open file'))
+
+if __name__ == '__main__':
+    #pptdll = cdll.LoadLibrary(r"C:\Documents and Settings\jonathan\Desktop\pptviewlib.dll')
+    pptdll = cdll.LoadLibrary(r"pptviewlib.dll')
+    pptdll.SetDebug(1)
+    print "Begin..."
+    app = QtGui.QApplication(sys.argv)
+    qb = PPTViewer()
+    qb.show()
+    sys.exit(app.exec_())
\ No newline at end of file

=== modified file 'openlp/plugins/presentations/lib/presentationtab.py'
--- openlp/plugins/presentations/lib/presentationtab.py	2009-06-05 18:53:50 +0000
+++ openlp/plugins/presentations/lib/presentationtab.py	2009-06-16 18:21:24 +0000
@@ -55,19 +55,19 @@
         self.VerseTypeLayout.setObjectName(u'VerseTypeLayout')
 
         self.PowerpointCheckBox = QtGui.QCheckBox(self.VerseDisplayGroupBox)
-        self.PowerpointCheckBox.setObjectName("PowerpointCheckBox")
+        self.PowerpointCheckBox.setObjectName(u'PowerpointCheckBox')
         self.VerseDisplayLayout.addWidget(self.PowerpointCheckBox, 0, 0, 1, 1)
 
         self.PowerpointPath = QtGui.QLineEdit(self.VerseDisplayGroupBox)
-        self.PowerpointPath.setObjectName("PowerpointPath")
+        self.PowerpointPath.setObjectName(u'PowerpointPath')
         self.VerseDisplayLayout.addWidget(self.PowerpointPath, 1, 0, 1, 1)
 
         self.ImpressCheckBox = QtGui.QCheckBox(self.VerseDisplayGroupBox)
-        self.ImpressCheckBox.setObjectName("ImpressCheckBox")
+        self.ImpressCheckBox.setObjectName(u'ImpressCheckBox')
         self.VerseDisplayLayout.addWidget(self.ImpressCheckBox, 2, 0, 1, 1)
 
         self.ImpressPath = QtGui.QLineEdit(self.VerseDisplayGroupBox)
-        self.ImpressPath.setObjectName("ImpressPath")
+        self.ImpressPath.setObjectName(u'ImpressPath')
         self.VerseDisplayLayout.addWidget(self.ImpressPath, 3, 0, 1, 1)
 
         self.PresentationThemeWidget = QtGui.QWidget(self.VerseDisplayGroupBox)
@@ -96,11 +96,11 @@
 
         # Signals and slots
         #QtCore.QObject.connect(self.NewChaptersCheckBox,
-           # QtCore.SIGNAL("stateChanged(int)"), self.onNewChaptersCheckBoxChanged)
+           # QtCore.SIGNAL(u'stateChanged(int)'), self.onNewChaptersCheckBoxChanged)
 
     def retranslateUi(self):
-        self.PowerpointCheckBox.setText(translate('PresentationTab', 'Powerpoint available:'))
-        self.ImpressCheckBox.setText(translate('PresentationTab', 'Impress available:'))
+        self.PowerpointCheckBox.setText(translate(u'PresentationTab', 'Powerpoint available:'))
+        self.ImpressCheckBox.setText(translate(u'PresentationTab', 'Impress available:'))
         self.PowerpointPath.setText(u'powerpoint.exe ')
         self.ImpressPath.setText(u'openoffice.org -nologo -show ')
 
@@ -114,7 +114,7 @@
     def load(self):
         pass
 #        self.paragraph_style = (self.config.get_config(u'paragraph style', u'True'))
-#        self.show_new_chapters = (self.config.get_config(u'display new chapter', u"False"))
+#        self.show_new_chapters = (self.config.get_config(u'display new chapter', u"False'))
 #        self.display_style = int(self.config.get_config(u'display brackets', u'0'))
 #        self.Presentation_theme = int(self.config.get_config(u'Presentation theme', u'0'))
 #        self.Presentation_search = (self.config.get_config(u'search as type', u'True'))
@@ -128,8 +128,8 @@
 
     def save(self):
         pass
-#        self.config.set_config(u'paragraph style', str(self.paragraph_style))
-#        self.config.set_config(u'display new chapter', str(self.show_new_chapters))
-#        self.config.set_config(u'display brackets', str(self.display_style))
-#        self.config.set_config(u'search as type', str(self.Presentation_search))
-#        self.config.set_config(u'Presentation theme', str(self.Presentation_theme))
+#        self.config.set_config(u'paragraph style', unicode(self.paragraph_style))
+#        self.config.set_config(u'display new chapter', unicode(self.show_new_chapters))
+#        self.config.set_config(u'display brackets', unicode(self.display_style))
+#        self.config.set_config(u'search as type', unicode(self.Presentation_search))
+#        self.config.set_config(u'Presentation theme', unicode(self.Presentation_theme))
\ No newline at end of file

=== modified file 'openlp/plugins/presentations/presentationplugin.py'
--- openlp/plugins/presentations/presentationplugin.py	2009-05-18 16:04:34 +0000
+++ openlp/plugins/presentations/presentationplugin.py	2009-06-16 18:21:24 +0000
@@ -33,7 +33,7 @@
         self.weight = -8
         # Create the plugin icon
         self.icon = QtGui.QIcon()
-        self.icon.addPixmap(QtGui.QPixmap(':/media/media_presentation.png'),
+        self.icon.addPixmap(QtGui.QPixmap(u':/media/media_presentation.png'),
             QtGui.QIcon.Normal, QtGui.QIcon.Off)
 
     def get_settings_tab(self):
@@ -43,4 +43,4 @@
     def get_media_manager_item(self):
         # Create the MediaManagerItem object
         self.media_item = PresentationMediaItem(self, self.icon, u'Presentations')
-        return self.media_item
+        return self.media_item
\ No newline at end of file

=== modified file 'openlp/plugins/songs/forms/editsongform.py'
--- openlp/plugins/songs/forms/editsongform.py	2009-06-14 13:50:56 +0000
+++ openlp/plugins/songs/forms/editsongform.py	2009-06-17 05:11:16 +0000
@@ -47,7 +47,7 @@
         QtCore.QObject.connect(self.AuthorRemoveItem,
             QtCore.SIGNAL(u'clicked()'), self.onAuthorRemovefromSongItemClicked)
         QtCore.QObject.connect(self.AuthorsListView,
-            QtCore.SIGNAL("itemClicked(QListWidgetItem*)"), self.onAuthorsListViewPressed)
+            QtCore.SIGNAL(u'itemClicked(QListWidgetItem*)'), self.onAuthorsListViewPressed)
         QtCore.QObject.connect(self.AddTopicButton,
             QtCore.SIGNAL(u'clicked()'), self.onAddTopicButtonClicked)
         QtCore.QObject.connect(self.AddTopicsToSongButton,
@@ -55,7 +55,7 @@
         QtCore.QObject.connect(self.TopicRemoveItem,
             QtCore.SIGNAL(u'clicked()'), self.onTopicRemovefromSongItemClicked)
         QtCore.QObject.connect(self.TopicsListView,
-            QtCore.SIGNAL("itemClicked(QListWidgetItem*)"), self.onTopicListViewPressed)
+            QtCore.SIGNAL(u'itemClicked(QListWidgetItem*)'), self.onTopicListViewPressed)
         QtCore.QObject.connect(self.AddSongBookButton,
             QtCore.SIGNAL(u'clicked()'), self.onAddSongBookButtonClicked)
         QtCore.QObject.connect(self.CopyrightInsertItem,
@@ -67,7 +67,7 @@
         QtCore.QObject.connect(self.DeleteButton,
             QtCore.SIGNAL(u'clicked()'), self.onDeleteVerseButtonClicked)
         QtCore.QObject.connect(self.VerseListWidget,
-            QtCore.SIGNAL("itemClicked(QListWidgetItem*)"), self.onVerseListViewPressed)
+            QtCore.SIGNAL(u'itemClicked(QListWidgetItem*)'), self.onVerseListViewPressed)
         QtCore.QObject.connect(self.SongbookCombo,
             QtCore.SIGNAL(u'activated(int)'), self.onSongBookComboChanged)
         QtCore.QObject.connect(self.ThemeSelectionComboItem,
@@ -132,6 +132,9 @@
         self.TitleEditItem.setText(u'')
         self.AlternativeEdit.setText(u'')
         self.CopyrightEditItem.setText(u'')
+        self.VerseOrderEdit.setText(u'')
+        self.CommentsEdit.setText(u'')
+        self.CCLNumberEdit.setText(u'')
         self.VerseListWidget.clear()
         self.AuthorsListView.clear()
         self.TopicsListView.clear()
@@ -160,6 +163,18 @@
             self.AlternativeEdit.setText(title[1])
         self.CopyrightEditItem.setText(self.song.copyright)
         self.VerseListWidget.clear()
+        if self.song.verse_order is not None:
+            self.VerseOrderEdit.setText(self.song.verse_order)
+        else:
+            self.VerseOrderEdit.setText(u'')
+        if self.song.comments is not None:
+            self.CommentsEdit.setText(self.song.comments)
+        else:
+            self.CommentsEdit.setText(u'')
+        if self.song.ccli_number is not None:
+            self.CCLNumberEdit.setText(self.song.ccli_number)
+        else:
+            self.CCLNumberEdit.setText(u'')
         #lazy xml migration for now
         if self.song.lyrics.startswith(u'<?xml version='):
             songXML=SongXMLParser(self.song.lyrics)
@@ -227,7 +242,6 @@
         self.song.topics.remove(topic)
         row = self.TopicsListView.row(item)
         self.TopicsListView.takeItem(row)
-
     def onAddAuthorsButtonClicked(self):
         """
         Slot documentation goes here.
@@ -324,6 +338,15 @@
         self.song.title = self.TitleEditItem.text()
         self.title_change = True
 
+    def on_VerseOrderEdit_lostFocus(self):
+        self.song.verse_order = self.VerseOrderEdit.text()
+
+    def on_CommentsEdit_lostFocus(self):
+        self.song.comments = self.CommentsEdit.text()
+
+    def on_CCLNumberEdit_lostFocus(self):
+        self.song.ccli_number = self.CCLNumberEdit.text()
+
     def onCopyrightInsertItemTriggered(self):
         text = self.CopyrightEditItem.displayText()
         pos = self.CopyrightEditItem.cursorPosition()
@@ -334,7 +357,6 @@
 
     def onAccept(self):
         log.debug(u'OnAccept')
-        #self.song.topics.append(9) << need opject here
         if not self._validate_song():
             return
         self.song.title = unicode(self.TitleEditItem.displayText())
@@ -355,10 +377,14 @@
         sxml.add_lyrics_to_song()
         count = 1
         text = u' '
+        verse_order = u''
         for i in range (0, self.VerseListWidget.count()):
             sxml.add_verse_to_lyrics(u'Verse', unicode(count),  unicode(self.VerseListWidget.item(i).text()))
             text = text + unicode(self.VerseListWidget.item(i).text()) + u' '
+            verse_order = verse_order +unicode(count) + u' '
             count += 1
+        if self.song.verse_order is None:
+            self.song.verse_order = verse_order
         text =  text.replace("'", u'')
         text =  text.replace(u',', u'')
         text =  text.replace(u';', u'')

=== modified file 'openlp/plugins/songs/forms/openlpexportform.py'
--- openlp/plugins/songs/forms/openlpexportform.py	2009-05-01 22:26:43 +0000
+++ openlp/plugins/songs/forms/openlpexportform.py	2009-06-16 18:21:24 +0000
@@ -3,7 +3,7 @@
 """
 OpenLP - Open Source Lyrics Projection
 Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 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
 the terms of the GNU General Public License as published by the Free Software
@@ -17,10 +17,8 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
 from PyQt4 import QtCore, QtGui
-
-from openlp.core.resources import *
+from openlp.core.lib import translate
 
 class OpenLPExportForm(object):
 
@@ -29,36 +27,36 @@
         self.setupUi()
 
     def setupUi(self):
-        self.OpenLPExportForm.setObjectName("OpenLPExportForm")
+        self.OpenLPExportForm.setObjectName(u'OpenLPExportForm')
         self.OpenLPExportForm.resize(473, 459)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.OpenLPExportForm.setWindowIcon(icon)
         self.verticalLayout_5 = QtGui.QVBoxLayout(self.OpenLPExportForm)
         self.verticalLayout_5.setMargin(8)
-        self.verticalLayout_5.setObjectName("verticalLayout_5")
+        self.verticalLayout_5.setObjectName(u'verticalLayout_5')
         self.ExportFileWidget = QtGui.QWidget(self.OpenLPExportForm)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ExportFileWidget.sizePolicy().hasHeightForWidth())
         self.ExportFileWidget.setSizePolicy(sizePolicy)
-        self.ExportFileWidget.setObjectName("ExportFileWidget")
+        self.ExportFileWidget.setObjectName(u'ExportFileWidget')
         self.horizontalLayout = QtGui.QHBoxLayout(self.ExportFileWidget)
         self.horizontalLayout.setSpacing(3)
         self.horizontalLayout.setMargin(0)
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.ExportFileLabel = QtGui.QLabel(self.ExportFileWidget)
-        self.ExportFileLabel.setObjectName("ExportFileLabel")
+        self.ExportFileLabel.setObjectName(u'ExportFileLabel')
         self.horizontalLayout.addWidget(self.ExportFileLabel)
         self.ExportFileLineEdit = QtGui.QLineEdit(self.ExportFileWidget)
-        self.ExportFileLineEdit.setObjectName("ExportFileLineEdit")
+        self.ExportFileLineEdit.setObjectName(u'ExportFileLineEdit')
         self.horizontalLayout.addWidget(self.ExportFileLineEdit)
         self.ExportFileSelectPushButton = QtGui.QPushButton(self.ExportFileWidget)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/exports/export_load.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/exports/export_load.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ExportFileSelectPushButton.setIcon(icon1)
-        self.ExportFileSelectPushButton.setObjectName("ExportFileSelectPushButton")
+        self.ExportFileSelectPushButton.setObjectName(u'ExportFileSelectPushButton')
         self.horizontalLayout.addWidget(self.ExportFileSelectPushButton)
         self.verticalLayout_5.addWidget(self.ExportFileWidget)
         self.SongListFrame = QtGui.QFrame(self.OpenLPExportForm)
@@ -69,31 +67,31 @@
         self.SongListFrame.setSizePolicy(sizePolicy)
         self.SongListFrame.setFrameShape(QtGui.QFrame.Box)
         self.SongListFrame.setFrameShadow(QtGui.QFrame.Raised)
-        self.SongListFrame.setObjectName("SongListFrame")
+        self.SongListFrame.setObjectName(u'SongListFrame')
         self.horizontalLayout_6 = QtGui.QHBoxLayout(self.SongListFrame)
         self.horizontalLayout_6.setSpacing(8)
         self.horizontalLayout_6.setMargin(8)
-        self.horizontalLayout_6.setObjectName("horizontalLayout_6")
+        self.horizontalLayout_6.setObjectName(u'horizontalLayout_6')
         self.ExportFileSongListWidget = QtGui.QWidget(self.SongListFrame)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Expanding)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ExportFileSongListWidget.sizePolicy().hasHeightForWidth())
         self.ExportFileSongListWidget.setSizePolicy(sizePolicy)
-        self.ExportFileSongListWidget.setObjectName("ExportFileSongListWidget")
+        self.ExportFileSongListWidget.setObjectName(u'ExportFileSongListWidget')
         self.verticalLayout = QtGui.QVBoxLayout(self.ExportFileSongListWidget)
         self.verticalLayout.setSpacing(6)
         self.verticalLayout.setMargin(0)
-        self.verticalLayout.setObjectName("verticalLayout")
+        self.verticalLayout.setObjectName(u'verticalLayout')
         self.ExportListLabel = QtGui.QLabel(self.ExportFileSongListWidget)
-        self.ExportListLabel.setObjectName("ExportListLabel")
+        self.ExportListLabel.setObjectName(u'ExportListLabel')
         self.verticalLayout.addWidget(self.ExportListLabel)
         self.ExportListTable = QtGui.QTableWidget(self.ExportFileSongListWidget)
         self.ExportListTable.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
         self.ExportListTable.setShowGrid(False)
         self.ExportListTable.setWordWrap(False)
         self.ExportListTable.setCornerButtonEnabled(False)
-        self.ExportListTable.setObjectName("ExportListTable")
+        self.ExportListTable.setObjectName(u'ExportListTable')
         self.ExportListTable.setColumnCount(2)
         self.ExportListTable.setRowCount(0)
         item = QtGui.QTableWidgetItem()
@@ -102,11 +100,11 @@
         self.ExportListTable.setHorizontalHeaderItem(1, item)
         self.verticalLayout.addWidget(self.ExportListTable)
         self.ExportSelectAllWidget = QtGui.QWidget(self.ExportFileSongListWidget)
-        self.ExportSelectAllWidget.setObjectName("ExportSelectAllWidget")
+        self.ExportSelectAllWidget.setObjectName(u'ExportSelectAllWidget')
         self.horizontalLayout_2 = QtGui.QHBoxLayout(self.ExportSelectAllWidget)
         self.horizontalLayout_2.setSpacing(6)
         self.horizontalLayout_2.setMargin(0)
-        self.horizontalLayout_2.setObjectName("horizontalLayout_2")
+        self.horizontalLayout_2.setObjectName(u'horizontalLayout_2')
         self.ExportSelectAllPushButton = QtGui.QPushButton(self.ExportSelectAllWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -115,9 +113,9 @@
         self.ExportSelectAllPushButton.setSizePolicy(sizePolicy)
         self.ExportSelectAllPushButton.setMinimumSize(QtCore.QSize(100, 0))
         icon2 = QtGui.QIcon()
-        icon2.addPixmap(QtGui.QPixmap(":/exports/export_selectall.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon2.addPixmap(QtGui.QPixmap(u':/exports/export_selectall.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ExportSelectAllPushButton.setIcon(icon2)
-        self.ExportSelectAllPushButton.setObjectName("ExportSelectAllPushButton")
+        self.ExportSelectAllPushButton.setObjectName(u'ExportSelectAllPushButton')
         self.horizontalLayout_2.addWidget(self.ExportSelectAllPushButton)
         spacerItem = QtGui.QSpacerItem(89, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_2.addItem(spacerItem)
@@ -129,19 +127,19 @@
         sizePolicy.setHeightForWidth(self.exportFilterWidget.sizePolicy().hasHeightForWidth())
         self.exportFilterWidget.setSizePolicy(sizePolicy)
         self.exportFilterWidget.setMinimumSize(QtCore.QSize(0, 0))
-        self.exportFilterWidget.setObjectName("exportFilterWidget")
+        self.exportFilterWidget.setObjectName(u'exportFilterWidget')
         self.horizontalLayout_3 = QtGui.QHBoxLayout(self.exportFilterWidget)
         self.horizontalLayout_3.setMargin(0)
-        self.horizontalLayout_3.setObjectName("horizontalLayout_3")
+        self.horizontalLayout_3.setObjectName(u'horizontalLayout_3')
         self.ExportFilterComboBox = QtGui.QComboBox(self.exportFilterWidget)
         self.ExportFilterComboBox.setMinimumSize(QtCore.QSize(70, 0))
-        self.ExportFilterComboBox.setObjectName("ExportFilterComboBox")
+        self.ExportFilterComboBox.setObjectName(u'ExportFilterComboBox')
         self.ExportFilterComboBox.addItem(QtCore.QString())
         self.ExportFilterComboBox.addItem(QtCore.QString())
         self.ExportFilterComboBox.addItem(QtCore.QString())
         self.horizontalLayout_3.addWidget(self.ExportFilterComboBox)
         self.ExportFilterLineEdit = QtGui.QLineEdit(self.exportFilterWidget)
-        self.ExportFilterLineEdit.setObjectName("ExportFilterLineEdit")
+        self.ExportFilterLineEdit.setObjectName(u'ExportFilterLineEdit')
         self.horizontalLayout_3.addWidget(self.ExportFilterLineEdit)
         self.verticalLayout.addWidget(self.exportFilterWidget)
         self.horizontalLayout_6.addWidget(self.ExportFileSongListWidget)
@@ -151,10 +149,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.AddSelectedWidget.sizePolicy().hasHeightForWidth())
         self.AddSelectedWidget.setSizePolicy(sizePolicy)
-        self.AddSelectedWidget.setObjectName("AddSelectedWidget")
+        self.AddSelectedWidget.setObjectName(u'AddSelectedWidget')
         self.verticalLayout_3 = QtGui.QVBoxLayout(self.AddSelectedWidget)
         self.verticalLayout_3.setMargin(0)
-        self.verticalLayout_3.setObjectName("verticalLayout_3")
+        self.verticalLayout_3.setObjectName(u'verticalLayout_3')
         spacerItem1 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout_3.addItem(spacerItem1)
         self.AddSelectedPushButton = QtGui.QPushButton(self.AddSelectedWidget)
@@ -165,9 +163,9 @@
         self.AddSelectedPushButton.setSizePolicy(sizePolicy)
         self.AddSelectedPushButton.setMinimumSize(QtCore.QSize(25, 25))
         icon3 = QtGui.QIcon()
-        icon3.addPixmap(QtGui.QPixmap(":/exports/export_move_to_list.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon3.addPixmap(QtGui.QPixmap(u':/exports/export_move_to_list.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.AddSelectedPushButton.setIcon(icon3)
-        self.AddSelectedPushButton.setObjectName("AddSelectedPushButton")
+        self.AddSelectedPushButton.setObjectName(u'AddSelectedPushButton')
         self.verticalLayout_3.addWidget(self.AddSelectedPushButton)
         spacerItem2 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout_3.addItem(spacerItem2)
@@ -178,19 +176,19 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.SelectedFileListWidget.sizePolicy().hasHeightForWidth())
         self.SelectedFileListWidget.setSizePolicy(sizePolicy)
-        self.SelectedFileListWidget.setObjectName("SelectedFileListWidget")
+        self.SelectedFileListWidget.setObjectName(u'SelectedFileListWidget')
         self.verticalLayout_2 = QtGui.QVBoxLayout(self.SelectedFileListWidget)
         self.verticalLayout_2.setMargin(0)
-        self.verticalLayout_2.setObjectName("verticalLayout_2")
+        self.verticalLayout_2.setObjectName(u'verticalLayout_2')
         self.SelectedListLabel = QtGui.QLabel(self.SelectedFileListWidget)
-        self.SelectedListLabel.setObjectName("SelectedListLabel")
+        self.SelectedListLabel.setObjectName(u'SelectedListLabel')
         self.verticalLayout_2.addWidget(self.SelectedListLabel)
         self.SelectedListTable = QtGui.QTableWidget(self.SelectedFileListWidget)
         self.SelectedListTable.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
         self.SelectedListTable.setShowGrid(False)
         self.SelectedListTable.setWordWrap(False)
         self.SelectedListTable.setCornerButtonEnabled(False)
-        self.SelectedListTable.setObjectName("SelectedListTable")
+        self.SelectedListTable.setObjectName(u'SelectedListTable')
         self.SelectedListTable.setColumnCount(2)
         self.SelectedListTable.setRowCount(0)
         item = QtGui.QTableWidgetItem()
@@ -199,11 +197,11 @@
         self.SelectedListTable.setHorizontalHeaderItem(1, item)
         self.verticalLayout_2.addWidget(self.SelectedListTable)
         self.SelectedSelectAllWidget = QtGui.QWidget(self.SelectedFileListWidget)
-        self.SelectedSelectAllWidget.setObjectName("SelectedSelectAllWidget")
+        self.SelectedSelectAllWidget.setObjectName(u'SelectedSelectAllWidget')
         self.horizontalLayout_4 = QtGui.QHBoxLayout(self.SelectedSelectAllWidget)
         self.horizontalLayout_4.setSpacing(6)
         self.horizontalLayout_4.setMargin(0)
-        self.horizontalLayout_4.setObjectName("horizontalLayout_4")
+        self.horizontalLayout_4.setObjectName(u'horizontalLayout_4')
         self.SelectedSelectAllPushButton = QtGui.QPushButton(self.SelectedSelectAllWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -212,7 +210,7 @@
         self.SelectedSelectAllPushButton.setSizePolicy(sizePolicy)
         self.SelectedSelectAllPushButton.setMinimumSize(QtCore.QSize(100, 0))
         self.SelectedSelectAllPushButton.setIcon(icon2)
-        self.SelectedSelectAllPushButton.setObjectName("SelectedSelectAllPushButton")
+        self.SelectedSelectAllPushButton.setObjectName(u'SelectedSelectAllPushButton')
         self.horizontalLayout_4.addWidget(self.SelectedSelectAllPushButton)
         spacerItem3 = QtGui.QSpacerItem(92, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_4.addItem(spacerItem3)
@@ -223,10 +221,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.SelectedRemoveSelectedWidget.sizePolicy().hasHeightForWidth())
         self.SelectedRemoveSelectedWidget.setSizePolicy(sizePolicy)
-        self.SelectedRemoveSelectedWidget.setObjectName("SelectedRemoveSelectedWidget")
+        self.SelectedRemoveSelectedWidget.setObjectName(u'SelectedRemoveSelectedWidget')
         self.horizontalLayout_5 = QtGui.QHBoxLayout(self.SelectedRemoveSelectedWidget)
         self.horizontalLayout_5.setMargin(0)
-        self.horizontalLayout_5.setObjectName("horizontalLayout_5")
+        self.horizontalLayout_5.setObjectName(u'horizontalLayout_5')
         self.SelectedRemoveSelectedButton = QtGui.QPushButton(self.SelectedRemoveSelectedWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -235,9 +233,9 @@
         self.SelectedRemoveSelectedButton.setSizePolicy(sizePolicy)
         self.SelectedRemoveSelectedButton.setMinimumSize(QtCore.QSize(140, 0))
         icon4 = QtGui.QIcon()
-        icon4.addPixmap(QtGui.QPixmap(":/exports/export_remove.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon4.addPixmap(QtGui.QPixmap(u':/exports/export_remove.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.SelectedRemoveSelectedButton.setIcon(icon4)
-        self.SelectedRemoveSelectedButton.setObjectName("SelectedRemoveSelectedButton")
+        self.SelectedRemoveSelectedButton.setObjectName(u'SelectedRemoveSelectedButton')
         self.horizontalLayout_5.addWidget(self.SelectedRemoveSelectedButton)
         spacerItem4 = QtGui.QSpacerItem(49, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_5.addItem(spacerItem4)
@@ -250,61 +248,61 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ProgressGroupBox.sizePolicy().hasHeightForWidth())
         self.ProgressGroupBox.setSizePolicy(sizePolicy)
-        self.ProgressGroupBox.setObjectName("ProgressGroupBox")
+        self.ProgressGroupBox.setObjectName(u'ProgressGroupBox')
         self.verticalLayout_4 = QtGui.QVBoxLayout(self.ProgressGroupBox)
         self.verticalLayout_4.setSpacing(8)
         self.verticalLayout_4.setContentsMargins(8, 0, 8, 8)
-        self.verticalLayout_4.setObjectName("verticalLayout_4")
+        self.verticalLayout_4.setObjectName(u'verticalLayout_4')
         self.ProgressLabel = QtGui.QLabel(self.ProgressGroupBox)
-        self.ProgressLabel.setObjectName("ProgressLabel")
+        self.ProgressLabel.setObjectName(u'ProgressLabel')
         self.verticalLayout_4.addWidget(self.ProgressLabel)
         self.ProgressBar = QtGui.QProgressBar(self.ProgressGroupBox)
-        self.ProgressBar.setProperty("value", QtCore.QVariant(24))
-        self.ProgressBar.setObjectName("ProgressBar")
+        self.ProgressBar.setProperty(u'value', QtCore.QVariant(24))
+        self.ProgressBar.setObjectName(u'ProgressBar')
         self.verticalLayout_4.addWidget(self.ProgressBar)
         self.verticalLayout_5.addWidget(self.ProgressGroupBox)
         self.ButtonBarWidget = QtGui.QWidget(self.OpenLPExportForm)
-        self.ButtonBarWidget.setObjectName("ButtonBarWidget")
+        self.ButtonBarWidget.setObjectName(u'ButtonBarWidget')
         self.horizontalLayout_7 = QtGui.QHBoxLayout(self.ButtonBarWidget)
         self.horizontalLayout_7.setSpacing(8)
         self.horizontalLayout_7.setMargin(0)
-        self.horizontalLayout_7.setObjectName("horizontalLayout_7")
+        self.horizontalLayout_7.setObjectName(u'horizontalLayout_7')
         spacerItem5 = QtGui.QSpacerItem(288, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_7.addItem(spacerItem5)
         self.ExportPushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ExportPushButton.setObjectName("ExportPushButton")
+        self.ExportPushButton.setObjectName(u'ExportPushButton')
         self.horizontalLayout_7.addWidget(self.ExportPushButton)
         self.ClosePushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ClosePushButton.setObjectName("ClosePushButton")
+        self.ClosePushButton.setObjectName(u'ClosePushButton')
         self.horizontalLayout_7.addWidget(self.ClosePushButton)
         self.verticalLayout_5.addWidget(self.ButtonBarWidget)
 
         self.retranslateUi()
-        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL("clicked()"), self.OpenLPExportForm.close)
-        QtCore.QObject.connect(self.ExportSelectAllPushButton, QtCore.SIGNAL("clicked()"), self.ExportListTable.selectAll)
-        QtCore.QObject.connect(self.SelectedSelectAllPushButton, QtCore.SIGNAL("clicked()"), self.SelectedListTable.selectAll)
-        QtCore.QObject.connect(self.SelectedRemoveSelectedButton, QtCore.SIGNAL("clicked()"), self.SelectedListTable.clear)
+        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL(u'clicked()'), self.OpenLPExportForm.close)
+        QtCore.QObject.connect(self.ExportSelectAllPushButton, QtCore.SIGNAL(u'clicked()'), self.ExportListTable.selectAll)
+        QtCore.QObject.connect(self.SelectedSelectAllPushButton, QtCore.SIGNAL(u'clicked()'), self.SelectedListTable.selectAll)
+        QtCore.QObject.connect(self.SelectedRemoveSelectedButton, QtCore.SIGNAL(u'clicked()'), self.SelectedListTable.clear)
         QtCore.QMetaObject.connectSlotsByName(self.OpenLPExportForm)
 
     def retranslateUi(self):
-        self.OpenLPExportForm.setWindowTitle(QtGui.QApplication.translate("OpenLPExportForm", "openlp.org Song Exporter", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFileLabel.setText(QtGui.QApplication.translate("OpenLPExportForm", "Select openlp.org export filename:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportListLabel.setText(QtGui.QApplication.translate("OpenLPExportForm", "Full Song List", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportListTable.horizontalHeaderItem(0).setText(QtGui.QApplication.translate("OpenLPExportForm", "Song Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportListTable.horizontalHeaderItem(1).setText(QtGui.QApplication.translate("OpenLPExportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportSelectAllPushButton.setText(QtGui.QApplication.translate("OpenLPExportForm", "Select All", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFilterComboBox.setItemText(0, QtGui.QApplication.translate("OpenLPExportForm", "Lyrics", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFilterComboBox.setItemText(1, QtGui.QApplication.translate("OpenLPExportForm", "Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFilterComboBox.setItemText(2, QtGui.QApplication.translate("OpenLPExportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListLabel.setText(QtGui.QApplication.translate("OpenLPExportForm", "Song Export List", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListTable.horizontalHeaderItem(0).setText(QtGui.QApplication.translate("OpenLPExportForm", "Song Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListTable.horizontalHeaderItem(1).setText(QtGui.QApplication.translate("OpenLPExportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedSelectAllPushButton.setText(QtGui.QApplication.translate("OpenLPExportForm", "Select All", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedRemoveSelectedButton.setText(QtGui.QApplication.translate("OpenLPExportForm", "Remove Selected", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressGroupBox.setTitle(QtGui.QApplication.translate("OpenLPExportForm", "Progress:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressLabel.setText(QtGui.QApplication.translate("OpenLPExportForm", "Ready to export", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportPushButton.setText(QtGui.QApplication.translate("OpenLPExportForm", "Export", None, QtGui.QApplication.UnicodeUTF8))
-        self.ClosePushButton.setText(QtGui.QApplication.translate("OpenLPExportForm", "Close", None, QtGui.QApplication.UnicodeUTF8))
+        self.OpenLPExportForm.setWindowTitle(translate(u'OpenLPExportForm', u'openlp.org Song Exporter'))
+        self.ExportFileLabel.setText(translate(u'OpenLPExportForm', u'Select openlp.org export filename:'))
+        self.ExportListLabel.setText(translate(u'OpenLPExportForm', u'Full Song List'))
+        self.ExportListTable.horizontalHeaderItem(0).setText(translate(u'OpenLPExportForm', u'Song Title'))
+        self.ExportListTable.horizontalHeaderItem(1).setText(translate(u'OpenLPExportForm', u'Author'))
+        self.ExportSelectAllPushButton.setText(translate(u'OpenLPExportForm', u'Select All'))
+        self.ExportFilterComboBox.setItemText(0, translate(u'OpenLPExportForm', u'Lyrics'))
+        self.ExportFilterComboBox.setItemText(1, translate(u'OpenLPExportForm', u'Title'))
+        self.ExportFilterComboBox.setItemText(2, translate(u'OpenLPExportForm', u'Author'))
+        self.SelectedListLabel.setText(translate(u'OpenLPExportForm', u'Song Export List'))
+        self.SelectedListTable.horizontalHeaderItem(0).setText(translate(u'OpenLPExportForm', u'Song Title'))
+        self.SelectedListTable.horizontalHeaderItem(1).setText(translate(u'OpenLPExportForm', u'Author'))
+        self.SelectedSelectAllPushButton.setText(translate(u'OpenLPExportForm', u'Select All'))
+        self.SelectedRemoveSelectedButton.setText(translate(u'OpenLPExportForm', u'Remove Selected'))
+        self.ProgressGroupBox.setTitle(translate(u'OpenLPExportForm', u'Progress:'))
+        self.ProgressLabel.setText(translate(u'OpenLPExportForm', u'Ready to export'))
+        self.ExportPushButton.setText(translate(u'OpenLPExportForm', u'Export'))
+        self.ClosePushButton.setText(translate(u'OpenLPExportForm', u'Close'))
 
     def show(self):
         self.OpenLPExportForm.show()

=== modified file 'openlp/plugins/songs/forms/openlpimportform.py'
--- openlp/plugins/songs/forms/openlpimportform.py	2009-05-01 22:26:43 +0000
+++ openlp/plugins/songs/forms/openlpimportform.py	2009-06-16 18:21:24 +0000
@@ -3,7 +3,7 @@
 """
 OpenLP - Open Source Lyrics Projection
 Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 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
 the terms of the GNU General Public License as published by the Free Software
@@ -17,10 +17,8 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
 from PyQt4 import QtCore, QtGui
-
-from openlp.core.resources import *
+from openlp.core.lib import translate
 
 class OpenLPImportForm(object):
 
@@ -29,36 +27,36 @@
         self.setupUi()
 
     def setupUi(self):
-        self.OpenLPImportForm.setObjectName("OpenLPImportForm")
+        self.OpenLPImportForm.setObjectName(u'OpenLPImportForm')
         self.OpenLPImportForm.resize(473, 459)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.OpenLPImportForm.setWindowIcon(icon)
         self.verticalLayout_5 = QtGui.QVBoxLayout(self.OpenLPImportForm)
         self.verticalLayout_5.setMargin(8)
-        self.verticalLayout_5.setObjectName("verticalLayout_5")
+        self.verticalLayout_5.setObjectName(u'verticalLayout_5')
         self.ImportFileWidget = QtGui.QWidget(self.OpenLPImportForm)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ImportFileWidget.sizePolicy().hasHeightForWidth())
         self.ImportFileWidget.setSizePolicy(sizePolicy)
-        self.ImportFileWidget.setObjectName("ImportFileWidget")
+        self.ImportFileWidget.setObjectName(u'ImportFileWidget')
         self.horizontalLayout = QtGui.QHBoxLayout(self.ImportFileWidget)
         self.horizontalLayout.setSpacing(3)
         self.horizontalLayout.setMargin(0)
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.ImportFileLabel = QtGui.QLabel(self.ImportFileWidget)
-        self.ImportFileLabel.setObjectName("ImportFileLabel")
+        self.ImportFileLabel.setObjectName(u'ImportFileLabel')
         self.horizontalLayout.addWidget(self.ImportFileLabel)
         self.ImportFileLineEdit = QtGui.QLineEdit(self.ImportFileWidget)
-        self.ImportFileLineEdit.setObjectName("ImportFileLineEdit")
+        self.ImportFileLineEdit.setObjectName(u'ImportFileLineEdit')
         self.horizontalLayout.addWidget(self.ImportFileLineEdit)
         self.ImportFileSelectPushButton = QtGui.QPushButton(self.ImportFileWidget)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/imports/import_load.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/imports/import_load.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ImportFileSelectPushButton.setIcon(icon1)
-        self.ImportFileSelectPushButton.setObjectName("ImportFileSelectPushButton")
+        self.ImportFileSelectPushButton.setObjectName(u'ImportFileSelectPushButton')
         self.horizontalLayout.addWidget(self.ImportFileSelectPushButton)
         self.verticalLayout_5.addWidget(self.ImportFileWidget)
         self.SongListFrame = QtGui.QFrame(self.OpenLPImportForm)
@@ -69,31 +67,31 @@
         self.SongListFrame.setSizePolicy(sizePolicy)
         self.SongListFrame.setFrameShape(QtGui.QFrame.Box)
         self.SongListFrame.setFrameShadow(QtGui.QFrame.Raised)
-        self.SongListFrame.setObjectName("SongListFrame")
+        self.SongListFrame.setObjectName(u'SongListFrame')
         self.horizontalLayout_6 = QtGui.QHBoxLayout(self.SongListFrame)
         self.horizontalLayout_6.setSpacing(8)
         self.horizontalLayout_6.setMargin(8)
-        self.horizontalLayout_6.setObjectName("horizontalLayout_6")
+        self.horizontalLayout_6.setObjectName(u'horizontalLayout_6')
         self.ImportFileSongListWidget = QtGui.QWidget(self.SongListFrame)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Expanding)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ImportFileSongListWidget.sizePolicy().hasHeightForWidth())
         self.ImportFileSongListWidget.setSizePolicy(sizePolicy)
-        self.ImportFileSongListWidget.setObjectName("ImportFileSongListWidget")
+        self.ImportFileSongListWidget.setObjectName(u'ImportFileSongListWidget')
         self.verticalLayout = QtGui.QVBoxLayout(self.ImportFileSongListWidget)
         self.verticalLayout.setSpacing(6)
         self.verticalLayout.setMargin(0)
-        self.verticalLayout.setObjectName("verticalLayout")
+        self.verticalLayout.setObjectName(u'verticalLayout')
         self.ImportListLabel = QtGui.QLabel(self.ImportFileSongListWidget)
-        self.ImportListLabel.setObjectName("ImportListLabel")
+        self.ImportListLabel.setObjectName(u'ImportListLabel')
         self.verticalLayout.addWidget(self.ImportListLabel)
         self.ImportListTable = QtGui.QTableWidget(self.ImportFileSongListWidget)
         self.ImportListTable.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
         self.ImportListTable.setShowGrid(False)
         self.ImportListTable.setWordWrap(False)
         self.ImportListTable.setCornerButtonEnabled(False)
-        self.ImportListTable.setObjectName("ImportListTable")
+        self.ImportListTable.setObjectName(u'ImportListTable')
         self.ImportListTable.setColumnCount(2)
         self.ImportListTable.setRowCount(0)
         item = QtGui.QTableWidgetItem()
@@ -102,11 +100,11 @@
         self.ImportListTable.setHorizontalHeaderItem(1, item)
         self.verticalLayout.addWidget(self.ImportListTable)
         self.ImportSelectAllWidget = QtGui.QWidget(self.ImportFileSongListWidget)
-        self.ImportSelectAllWidget.setObjectName("ImportSelectAllWidget")
+        self.ImportSelectAllWidget.setObjectName(u'ImportSelectAllWidget')
         self.horizontalLayout_2 = QtGui.QHBoxLayout(self.ImportSelectAllWidget)
         self.horizontalLayout_2.setSpacing(6)
         self.horizontalLayout_2.setMargin(0)
-        self.horizontalLayout_2.setObjectName("horizontalLayout_2")
+        self.horizontalLayout_2.setObjectName(u'horizontalLayout_2')
         self.ImportSelectAllPushButton = QtGui.QPushButton(self.ImportSelectAllWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -115,9 +113,9 @@
         self.ImportSelectAllPushButton.setSizePolicy(sizePolicy)
         self.ImportSelectAllPushButton.setMinimumSize(QtCore.QSize(100, 0))
         icon2 = QtGui.QIcon()
-        icon2.addPixmap(QtGui.QPixmap(":/imports/import_selectall.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon2.addPixmap(QtGui.QPixmap(u':/imports/import_selectall.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ImportSelectAllPushButton.setIcon(icon2)
-        self.ImportSelectAllPushButton.setObjectName("ImportSelectAllPushButton")
+        self.ImportSelectAllPushButton.setObjectName(u'ImportSelectAllPushButton')
         self.horizontalLayout_2.addWidget(self.ImportSelectAllPushButton)
         spacerItem = QtGui.QSpacerItem(89, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_2.addItem(spacerItem)
@@ -129,19 +127,19 @@
         sizePolicy.setHeightForWidth(self.importFilterWidget.sizePolicy().hasHeightForWidth())
         self.importFilterWidget.setSizePolicy(sizePolicy)
         self.importFilterWidget.setMinimumSize(QtCore.QSize(0, 0))
-        self.importFilterWidget.setObjectName("importFilterWidget")
+        self.importFilterWidget.setObjectName(u'importFilterWidget')
         self.horizontalLayout_3 = QtGui.QHBoxLayout(self.importFilterWidget)
         self.horizontalLayout_3.setMargin(0)
-        self.horizontalLayout_3.setObjectName("horizontalLayout_3")
+        self.horizontalLayout_3.setObjectName(u'horizontalLayout_3')
         self.ImportFilterComboBox = QtGui.QComboBox(self.importFilterWidget)
         self.ImportFilterComboBox.setMinimumSize(QtCore.QSize(70, 0))
-        self.ImportFilterComboBox.setObjectName("ImportFilterComboBox")
+        self.ImportFilterComboBox.setObjectName(u'ImportFilterComboBox')
         self.ImportFilterComboBox.addItem(QtCore.QString())
         self.ImportFilterComboBox.addItem(QtCore.QString())
         self.ImportFilterComboBox.addItem(QtCore.QString())
         self.horizontalLayout_3.addWidget(self.ImportFilterComboBox)
         self.importFilterLineEdit = QtGui.QLineEdit(self.importFilterWidget)
-        self.importFilterLineEdit.setObjectName("importFilterLineEdit")
+        self.importFilterLineEdit.setObjectName(u'importFilterLineEdit')
         self.horizontalLayout_3.addWidget(self.importFilterLineEdit)
         self.verticalLayout.addWidget(self.importFilterWidget)
         self.horizontalLayout_6.addWidget(self.ImportFileSongListWidget)
@@ -151,10 +149,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.AddSelectedWidget.sizePolicy().hasHeightForWidth())
         self.AddSelectedWidget.setSizePolicy(sizePolicy)
-        self.AddSelectedWidget.setObjectName("AddSelectedWidget")
+        self.AddSelectedWidget.setObjectName(u'AddSelectedWidget')
         self.verticalLayout_3 = QtGui.QVBoxLayout(self.AddSelectedWidget)
         self.verticalLayout_3.setMargin(0)
-        self.verticalLayout_3.setObjectName("verticalLayout_3")
+        self.verticalLayout_3.setObjectName(u'verticalLayout_3')
         spacerItem1 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout_3.addItem(spacerItem1)
         self.AddSelectedPushButton = QtGui.QPushButton(self.AddSelectedWidget)
@@ -165,9 +163,9 @@
         self.AddSelectedPushButton.setSizePolicy(sizePolicy)
         self.AddSelectedPushButton.setMinimumSize(QtCore.QSize(25, 25))
         icon3 = QtGui.QIcon()
-        icon3.addPixmap(QtGui.QPixmap(":/imports/import_move_to_list.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon3.addPixmap(QtGui.QPixmap(u':/imports/import_move_to_list.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.AddSelectedPushButton.setIcon(icon3)
-        self.AddSelectedPushButton.setObjectName("AddSelectedPushButton")
+        self.AddSelectedPushButton.setObjectName(u'AddSelectedPushButton')
         self.verticalLayout_3.addWidget(self.AddSelectedPushButton)
         spacerItem2 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout_3.addItem(spacerItem2)
@@ -178,19 +176,19 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.SelectedFileListWidget.sizePolicy().hasHeightForWidth())
         self.SelectedFileListWidget.setSizePolicy(sizePolicy)
-        self.SelectedFileListWidget.setObjectName("SelectedFileListWidget")
+        self.SelectedFileListWidget.setObjectName(u'SelectedFileListWidget')
         self.verticalLayout_2 = QtGui.QVBoxLayout(self.SelectedFileListWidget)
         self.verticalLayout_2.setMargin(0)
-        self.verticalLayout_2.setObjectName("verticalLayout_2")
+        self.verticalLayout_2.setObjectName(u'verticalLayout_2')
         self.SelectedListLabel = QtGui.QLabel(self.SelectedFileListWidget)
-        self.SelectedListLabel.setObjectName("SelectedListLabel")
+        self.SelectedListLabel.setObjectName(u'SelectedListLabel')
         self.verticalLayout_2.addWidget(self.SelectedListLabel)
         self.SelectedListTable = QtGui.QTableWidget(self.SelectedFileListWidget)
         self.SelectedListTable.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
         self.SelectedListTable.setShowGrid(False)
         self.SelectedListTable.setWordWrap(False)
         self.SelectedListTable.setCornerButtonEnabled(False)
-        self.SelectedListTable.setObjectName("SelectedListTable")
+        self.SelectedListTable.setObjectName(u'SelectedListTable')
         self.SelectedListTable.setColumnCount(2)
         self.SelectedListTable.setRowCount(0)
         item = QtGui.QTableWidgetItem()
@@ -199,11 +197,11 @@
         self.SelectedListTable.setHorizontalHeaderItem(1, item)
         self.verticalLayout_2.addWidget(self.SelectedListTable)
         self.SelectedSelectAllWidget = QtGui.QWidget(self.SelectedFileListWidget)
-        self.SelectedSelectAllWidget.setObjectName("SelectedSelectAllWidget")
+        self.SelectedSelectAllWidget.setObjectName(u'SelectedSelectAllWidget')
         self.horizontalLayout_4 = QtGui.QHBoxLayout(self.SelectedSelectAllWidget)
         self.horizontalLayout_4.setSpacing(6)
         self.horizontalLayout_4.setMargin(0)
-        self.horizontalLayout_4.setObjectName("horizontalLayout_4")
+        self.horizontalLayout_4.setObjectName(u'horizontalLayout_4')
         self.SelectedSelectAllPushButton = QtGui.QPushButton(self.SelectedSelectAllWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -212,7 +210,7 @@
         self.SelectedSelectAllPushButton.setSizePolicy(sizePolicy)
         self.SelectedSelectAllPushButton.setMinimumSize(QtCore.QSize(100, 0))
         self.SelectedSelectAllPushButton.setIcon(icon2)
-        self.SelectedSelectAllPushButton.setObjectName("SelectedSelectAllPushButton")
+        self.SelectedSelectAllPushButton.setObjectName(u'SelectedSelectAllPushButton')
         self.horizontalLayout_4.addWidget(self.SelectedSelectAllPushButton)
         spacerItem3 = QtGui.QSpacerItem(92, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_4.addItem(spacerItem3)
@@ -223,10 +221,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.SelectedRemoveSelectedWidget.sizePolicy().hasHeightForWidth())
         self.SelectedRemoveSelectedWidget.setSizePolicy(sizePolicy)
-        self.SelectedRemoveSelectedWidget.setObjectName("SelectedRemoveSelectedWidget")
+        self.SelectedRemoveSelectedWidget.setObjectName(u'SelectedRemoveSelectedWidget')
         self.horizontalLayout_5 = QtGui.QHBoxLayout(self.SelectedRemoveSelectedWidget)
         self.horizontalLayout_5.setMargin(0)
-        self.horizontalLayout_5.setObjectName("horizontalLayout_5")
+        self.horizontalLayout_5.setObjectName(u'horizontalLayout_5')
         self.SelectedRemoveSelectedButton = QtGui.QPushButton(self.SelectedRemoveSelectedWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -235,9 +233,9 @@
         self.SelectedRemoveSelectedButton.setSizePolicy(sizePolicy)
         self.SelectedRemoveSelectedButton.setMinimumSize(QtCore.QSize(140, 0))
         icon4 = QtGui.QIcon()
-        icon4.addPixmap(QtGui.QPixmap(":/imports/import_remove.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon4.addPixmap(QtGui.QPixmap(u':/imports/import_remove.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.SelectedRemoveSelectedButton.setIcon(icon4)
-        self.SelectedRemoveSelectedButton.setObjectName("SelectedRemoveSelectedButton")
+        self.SelectedRemoveSelectedButton.setObjectName(u'SelectedRemoveSelectedButton')
         self.horizontalLayout_5.addWidget(self.SelectedRemoveSelectedButton)
         spacerItem4 = QtGui.QSpacerItem(49, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_5.addItem(spacerItem4)
@@ -250,61 +248,61 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ProgressGroupBox.sizePolicy().hasHeightForWidth())
         self.ProgressGroupBox.setSizePolicy(sizePolicy)
-        self.ProgressGroupBox.setObjectName("ProgressGroupBox")
+        self.ProgressGroupBox.setObjectName(u'ProgressGroupBox')
         self.verticalLayout_4 = QtGui.QVBoxLayout(self.ProgressGroupBox)
         self.verticalLayout_4.setSpacing(8)
         self.verticalLayout_4.setContentsMargins(8, 0, 8, 8)
-        self.verticalLayout_4.setObjectName("verticalLayout_4")
+        self.verticalLayout_4.setObjectName(u'verticalLayout_4')
         self.ProgressLabel = QtGui.QLabel(self.ProgressGroupBox)
-        self.ProgressLabel.setObjectName("ProgressLabel")
+        self.ProgressLabel.setObjectName(u'ProgressLabel')
         self.verticalLayout_4.addWidget(self.ProgressLabel)
         self.ProgressBar = QtGui.QProgressBar(self.ProgressGroupBox)
-        self.ProgressBar.setProperty("value", QtCore.QVariant(0))
-        self.ProgressBar.setObjectName("ProgressBar")
+        self.ProgressBar.setProperty(u'value', QtCore.QVariant(0))
+        self.ProgressBar.setObjectName(u'ProgressBar')
         self.verticalLayout_4.addWidget(self.ProgressBar)
         self.verticalLayout_5.addWidget(self.ProgressGroupBox)
         self.ButtonBarWidget = QtGui.QWidget(self.OpenLPImportForm)
-        self.ButtonBarWidget.setObjectName("ButtonBarWidget")
+        self.ButtonBarWidget.setObjectName(u'ButtonBarWidget')
         self.horizontalLayout_7 = QtGui.QHBoxLayout(self.ButtonBarWidget)
         self.horizontalLayout_7.setSpacing(8)
         self.horizontalLayout_7.setMargin(0)
-        self.horizontalLayout_7.setObjectName("horizontalLayout_7")
+        self.horizontalLayout_7.setObjectName(u'horizontalLayout_7')
         spacerItem5 = QtGui.QSpacerItem(288, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_7.addItem(spacerItem5)
         self.ImportPushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ImportPushButton.setObjectName("ImportPushButton")
+        self.ImportPushButton.setObjectName(u'ImportPushButton')
         self.horizontalLayout_7.addWidget(self.ImportPushButton)
         self.ClosePushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ClosePushButton.setObjectName("ClosePushButton")
+        self.ClosePushButton.setObjectName(u'ClosePushButton')
         self.horizontalLayout_7.addWidget(self.ClosePushButton)
         self.verticalLayout_5.addWidget(self.ButtonBarWidget)
 
         self.retranslateUi()
-        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL("clicked()"), self.OpenLPImportForm.close)
-        QtCore.QObject.connect(self.ImportSelectAllPushButton, QtCore.SIGNAL("clicked()"), self.ImportListTable.selectAll)
-        QtCore.QObject.connect(self.SelectedSelectAllPushButton, QtCore.SIGNAL("clicked()"), self.SelectedListTable.selectAll)
-        QtCore.QObject.connect(self.SelectedRemoveSelectedButton, QtCore.SIGNAL("clicked()"), self.SelectedListTable.clear)
+        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL(u'clicked()'), self.OpenLPImportForm.close)
+        QtCore.QObject.connect(self.ImportSelectAllPushButton, QtCore.SIGNAL(u'clicked()'), self.ImportListTable.selectAll)
+        QtCore.QObject.connect(self.SelectedSelectAllPushButton, QtCore.SIGNAL(u'clicked()'), self.SelectedListTable.selectAll)
+        QtCore.QObject.connect(self.SelectedRemoveSelectedButton, QtCore.SIGNAL(u'clicked()'), self.SelectedListTable.clear)
         QtCore.QMetaObject.connectSlotsByName(self.OpenLPImportForm)
 
     def retranslateUi(self):
-        self.OpenLPImportForm.setWindowTitle(QtGui.QApplication.translate("OpenLPImportForm", "openlp.org Song Importer", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportFileLabel.setText(QtGui.QApplication.translate("OpenLPImportForm", "Select openlp.org songfile to import:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportListLabel.setText(QtGui.QApplication.translate("OpenLPImportForm", "Import File Song List", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportListTable.horizontalHeaderItem(0).setText(QtGui.QApplication.translate("OpenLPImportForm", "Song Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportListTable.horizontalHeaderItem(1).setText(QtGui.QApplication.translate("OpenLPImportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportSelectAllPushButton.setText(QtGui.QApplication.translate("OpenLPImportForm", "Select All", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportFilterComboBox.setItemText(0, QtGui.QApplication.translate("OpenLPImportForm", "Lyrics", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportFilterComboBox.setItemText(1, QtGui.QApplication.translate("OpenLPImportForm", "Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportFilterComboBox.setItemText(2, QtGui.QApplication.translate("OpenLPImportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListLabel.setText(QtGui.QApplication.translate("OpenLPImportForm", "Song Import List", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListTable.horizontalHeaderItem(0).setText(QtGui.QApplication.translate("OpenLPImportForm", "Song Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListTable.horizontalHeaderItem(1).setText(QtGui.QApplication.translate("OpenLPImportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedSelectAllPushButton.setText(QtGui.QApplication.translate("OpenLPImportForm", "Select All", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedRemoveSelectedButton.setText(QtGui.QApplication.translate("OpenLPImportForm", "Remove Selected", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressGroupBox.setTitle(QtGui.QApplication.translate("OpenLPImportForm", "Progress:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressLabel.setText(QtGui.QApplication.translate("OpenLPImportForm", "Ready to import", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportPushButton.setText(QtGui.QApplication.translate("OpenLPImportForm", "Import", None, QtGui.QApplication.UnicodeUTF8))
-        self.ClosePushButton.setText(QtGui.QApplication.translate("OpenLPImportForm", "Close", None, QtGui.QApplication.UnicodeUTF8))
+        self.OpenLPImportForm.setWindowTitle(translate(u'OpenLPImportForm', u'openlp.org Song Importer'))
+        self.ImportFileLabel.setText(translate(u'OpenLPImportForm', u'Select openlp.org songfile to import:'))
+        self.ImportListLabel.setText(translate(u'OpenLPImportForm', u'Import File Song List'))
+        self.ImportListTable.horizontalHeaderItem(0).setText(translate(u'OpenLPImportForm', u'Song Title'))
+        self.ImportListTable.horizontalHeaderItem(1).setText(translate(u'OpenLPImportForm', u'Author'))
+        self.ImportSelectAllPushButton.setText(translate(u'OpenLPImportForm', u'Select All'))
+        self.ImportFilterComboBox.setItemText(0, translate(u'OpenLPImportForm', u'Lyrics'))
+        self.ImportFilterComboBox.setItemText(1, translate(u'OpenLPImportForm', u'Title'))
+        self.ImportFilterComboBox.setItemText(2, translate(u'OpenLPImportForm', u'Author'))
+        self.SelectedListLabel.setText(translate(u'OpenLPImportForm', u'Song Import List'))
+        self.SelectedListTable.horizontalHeaderItem(0).setText(translate(u'OpenLPImportForm', u'Song Title'))
+        self.SelectedListTable.horizontalHeaderItem(1).setText(translate(u'OpenLPImportForm', u'Author'))
+        self.SelectedSelectAllPushButton.setText(translate(u'OpenLPImportForm', u'Select All'))
+        self.SelectedRemoveSelectedButton.setText(translate(u'OpenLPImportForm', u'Remove Selected'))
+        self.ProgressGroupBox.setTitle(translate(u'OpenLPImportForm', u'Progress:'))
+        self.ProgressLabel.setText(translate(u'OpenLPImportForm', u'Ready to import'))
+        self.ImportPushButton.setText(translate(u'OpenLPImportForm', u'Import'))
+        self.ClosePushButton.setText(translate(u'OpenLPImportForm', u'Close'))
 
     def show(self):
         self.OpenLPImportForm.show()

=== modified file 'openlp/plugins/songs/forms/opensongexportform.py'
--- openlp/plugins/songs/forms/opensongexportform.py	2009-05-01 22:26:43 +0000
+++ openlp/plugins/songs/forms/opensongexportform.py	2009-06-16 18:21:24 +0000
@@ -3,7 +3,7 @@
 """
 OpenLP - Open Source Lyrics Projection
 Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 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
 the terms of the GNU General Public License as published by the Free Software
@@ -17,10 +17,8 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
 from PyQt4 import QtCore, QtGui
-
-from openlp.core.resources import *
+from openlp.core.lib import translate
 
 class OpenSongExportForm(object):
 
@@ -29,36 +27,36 @@
         self.setupUi()
 
     def setupUi(self):
-        self.OpenSongExportForm.setObjectName("OpenSongExportForm")
+        self.OpenSongExportForm.setObjectName(u'OpenSongExportForm')
         self.OpenSongExportForm.resize(473, 459)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.OpenSongExportForm.setWindowIcon(icon)
         self.verticalLayout_5 = QtGui.QVBoxLayout(self.OpenSongExportForm)
         self.verticalLayout_5.setMargin(8)
-        self.verticalLayout_5.setObjectName("verticalLayout_5")
+        self.verticalLayout_5.setObjectName(u'verticalLayout_5')
         self.ExportFileWidget = QtGui.QWidget(self.OpenSongExportForm)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ExportFileWidget.sizePolicy().hasHeightForWidth())
         self.ExportFileWidget.setSizePolicy(sizePolicy)
-        self.ExportFileWidget.setObjectName("ExportFileWidget")
+        self.ExportFileWidget.setObjectName(u'ExportFileWidget')
         self.horizontalLayout = QtGui.QHBoxLayout(self.ExportFileWidget)
         self.horizontalLayout.setSpacing(3)
         self.horizontalLayout.setMargin(0)
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.ExportFileLabel = QtGui.QLabel(self.ExportFileWidget)
-        self.ExportFileLabel.setObjectName("ExportFileLabel")
+        self.ExportFileLabel.setObjectName(u'ExportFileLabel')
         self.horizontalLayout.addWidget(self.ExportFileLabel)
         self.ExportFileLineEdit = QtGui.QLineEdit(self.ExportFileWidget)
-        self.ExportFileLineEdit.setObjectName("ExportFileLineEdit")
+        self.ExportFileLineEdit.setObjectName(u'ExportFileLineEdit')
         self.horizontalLayout.addWidget(self.ExportFileLineEdit)
         self.ExportFileSelectPushButton = QtGui.QPushButton(self.ExportFileWidget)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/exports/export_load.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/exports/export_load.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ExportFileSelectPushButton.setIcon(icon1)
-        self.ExportFileSelectPushButton.setObjectName("ExportFileSelectPushButton")
+        self.ExportFileSelectPushButton.setObjectName(u'ExportFileSelectPushButton')
         self.horizontalLayout.addWidget(self.ExportFileSelectPushButton)
         self.verticalLayout_5.addWidget(self.ExportFileWidget)
         self.SongListFrame = QtGui.QFrame(self.OpenSongExportForm)
@@ -69,31 +67,31 @@
         self.SongListFrame.setSizePolicy(sizePolicy)
         self.SongListFrame.setFrameShape(QtGui.QFrame.Box)
         self.SongListFrame.setFrameShadow(QtGui.QFrame.Raised)
-        self.SongListFrame.setObjectName("SongListFrame")
+        self.SongListFrame.setObjectName(u'SongListFrame')
         self.horizontalLayout_6 = QtGui.QHBoxLayout(self.SongListFrame)
         self.horizontalLayout_6.setSpacing(8)
         self.horizontalLayout_6.setMargin(8)
-        self.horizontalLayout_6.setObjectName("horizontalLayout_6")
+        self.horizontalLayout_6.setObjectName(u'horizontalLayout_6')
         self.ExportFileSongListWidget = QtGui.QWidget(self.SongListFrame)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Expanding)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ExportFileSongListWidget.sizePolicy().hasHeightForWidth())
         self.ExportFileSongListWidget.setSizePolicy(sizePolicy)
-        self.ExportFileSongListWidget.setObjectName("ExportFileSongListWidget")
+        self.ExportFileSongListWidget.setObjectName(u'ExportFileSongListWidget')
         self.verticalLayout = QtGui.QVBoxLayout(self.ExportFileSongListWidget)
         self.verticalLayout.setSpacing(6)
         self.verticalLayout.setMargin(0)
-        self.verticalLayout.setObjectName("verticalLayout")
+        self.verticalLayout.setObjectName(u'verticalLayout')
         self.ExportListLabel = QtGui.QLabel(self.ExportFileSongListWidget)
-        self.ExportListLabel.setObjectName("ExportListLabel")
+        self.ExportListLabel.setObjectName(u'ExportListLabel')
         self.verticalLayout.addWidget(self.ExportListLabel)
         self.ExportListTable = QtGui.QTableWidget(self.ExportFileSongListWidget)
         self.ExportListTable.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
         self.ExportListTable.setShowGrid(False)
         self.ExportListTable.setWordWrap(False)
         self.ExportListTable.setCornerButtonEnabled(False)
-        self.ExportListTable.setObjectName("ExportListTable")
+        self.ExportListTable.setObjectName(u'ExportListTable')
         self.ExportListTable.setColumnCount(2)
         self.ExportListTable.setRowCount(0)
         item = QtGui.QTableWidgetItem()
@@ -102,11 +100,11 @@
         self.ExportListTable.setHorizontalHeaderItem(1, item)
         self.verticalLayout.addWidget(self.ExportListTable)
         self.ExportSelectAllWidget = QtGui.QWidget(self.ExportFileSongListWidget)
-        self.ExportSelectAllWidget.setObjectName("ExportSelectAllWidget")
+        self.ExportSelectAllWidget.setObjectName(u'ExportSelectAllWidget')
         self.horizontalLayout_2 = QtGui.QHBoxLayout(self.ExportSelectAllWidget)
         self.horizontalLayout_2.setSpacing(6)
         self.horizontalLayout_2.setMargin(0)
-        self.horizontalLayout_2.setObjectName("horizontalLayout_2")
+        self.horizontalLayout_2.setObjectName(u'horizontalLayout_2')
         self.ExportSelectAllPushButton = QtGui.QPushButton(self.ExportSelectAllWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -115,9 +113,9 @@
         self.ExportSelectAllPushButton.setSizePolicy(sizePolicy)
         self.ExportSelectAllPushButton.setMinimumSize(QtCore.QSize(100, 0))
         icon2 = QtGui.QIcon()
-        icon2.addPixmap(QtGui.QPixmap(":/exports/export_selectall.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon2.addPixmap(QtGui.QPixmap(u':/exports/export_selectall.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ExportSelectAllPushButton.setIcon(icon2)
-        self.ExportSelectAllPushButton.setObjectName("ExportSelectAllPushButton")
+        self.ExportSelectAllPushButton.setObjectName(u'ExportSelectAllPushButton')
         self.horizontalLayout_2.addWidget(self.ExportSelectAllPushButton)
         spacerItem = QtGui.QSpacerItem(89, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_2.addItem(spacerItem)
@@ -129,19 +127,19 @@
         sizePolicy.setHeightForWidth(self.exportFilterWidget.sizePolicy().hasHeightForWidth())
         self.exportFilterWidget.setSizePolicy(sizePolicy)
         self.exportFilterWidget.setMinimumSize(QtCore.QSize(0, 0))
-        self.exportFilterWidget.setObjectName("exportFilterWidget")
+        self.exportFilterWidget.setObjectName(u'exportFilterWidget')
         self.horizontalLayout_3 = QtGui.QHBoxLayout(self.exportFilterWidget)
         self.horizontalLayout_3.setMargin(0)
-        self.horizontalLayout_3.setObjectName("horizontalLayout_3")
+        self.horizontalLayout_3.setObjectName(u'horizontalLayout_3')
         self.ExportFilterComboBox = QtGui.QComboBox(self.exportFilterWidget)
         self.ExportFilterComboBox.setMinimumSize(QtCore.QSize(70, 0))
-        self.ExportFilterComboBox.setObjectName("ExportFilterComboBox")
+        self.ExportFilterComboBox.setObjectName(u'ExportFilterComboBox')
         self.ExportFilterComboBox.addItem(QtCore.QString())
         self.ExportFilterComboBox.addItem(QtCore.QString())
         self.ExportFilterComboBox.addItem(QtCore.QString())
         self.horizontalLayout_3.addWidget(self.ExportFilterComboBox)
         self.ExportFilterLineEdit = QtGui.QLineEdit(self.exportFilterWidget)
-        self.ExportFilterLineEdit.setObjectName("ExportFilterLineEdit")
+        self.ExportFilterLineEdit.setObjectName(u'ExportFilterLineEdit')
         self.horizontalLayout_3.addWidget(self.ExportFilterLineEdit)
         self.verticalLayout.addWidget(self.exportFilterWidget)
         self.horizontalLayout_6.addWidget(self.ExportFileSongListWidget)
@@ -151,10 +149,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.AddSelectedWidget.sizePolicy().hasHeightForWidth())
         self.AddSelectedWidget.setSizePolicy(sizePolicy)
-        self.AddSelectedWidget.setObjectName("AddSelectedWidget")
+        self.AddSelectedWidget.setObjectName(u'AddSelectedWidget')
         self.verticalLayout_3 = QtGui.QVBoxLayout(self.AddSelectedWidget)
         self.verticalLayout_3.setMargin(0)
-        self.verticalLayout_3.setObjectName("verticalLayout_3")
+        self.verticalLayout_3.setObjectName(u'verticalLayout_3')
         spacerItem1 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout_3.addItem(spacerItem1)
         self.AddSelectedPushButton = QtGui.QPushButton(self.AddSelectedWidget)
@@ -165,9 +163,9 @@
         self.AddSelectedPushButton.setSizePolicy(sizePolicy)
         self.AddSelectedPushButton.setMinimumSize(QtCore.QSize(25, 25))
         icon3 = QtGui.QIcon()
-        icon3.addPixmap(QtGui.QPixmap(":/exports/export_move_to_list.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon3.addPixmap(QtGui.QPixmap(u':/exports/export_move_to_list.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.AddSelectedPushButton.setIcon(icon3)
-        self.AddSelectedPushButton.setObjectName("AddSelectedPushButton")
+        self.AddSelectedPushButton.setObjectName(u'AddSelectedPushButton')
         self.verticalLayout_3.addWidget(self.AddSelectedPushButton)
         spacerItem2 = QtGui.QSpacerItem(20, 40, QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Expanding)
         self.verticalLayout_3.addItem(spacerItem2)
@@ -178,19 +176,19 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.SelectedFileListWidget.sizePolicy().hasHeightForWidth())
         self.SelectedFileListWidget.setSizePolicy(sizePolicy)
-        self.SelectedFileListWidget.setObjectName("SelectedFileListWidget")
+        self.SelectedFileListWidget.setObjectName(u'SelectedFileListWidget')
         self.verticalLayout_2 = QtGui.QVBoxLayout(self.SelectedFileListWidget)
         self.verticalLayout_2.setMargin(0)
-        self.verticalLayout_2.setObjectName("verticalLayout_2")
+        self.verticalLayout_2.setObjectName(u'verticalLayout_2')
         self.SelectedListLabel = QtGui.QLabel(self.SelectedFileListWidget)
-        self.SelectedListLabel.setObjectName("SelectedListLabel")
+        self.SelectedListLabel.setObjectName(u'SelectedListLabel')
         self.verticalLayout_2.addWidget(self.SelectedListLabel)
         self.SelectedListTable = QtGui.QTableWidget(self.SelectedFileListWidget)
         self.SelectedListTable.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)
         self.SelectedListTable.setShowGrid(False)
         self.SelectedListTable.setWordWrap(False)
         self.SelectedListTable.setCornerButtonEnabled(False)
-        self.SelectedListTable.setObjectName("SelectedListTable")
+        self.SelectedListTable.setObjectName(u'SelectedListTable')
         self.SelectedListTable.setColumnCount(2)
         self.SelectedListTable.setRowCount(0)
         item = QtGui.QTableWidgetItem()
@@ -199,11 +197,11 @@
         self.SelectedListTable.setHorizontalHeaderItem(1, item)
         self.verticalLayout_2.addWidget(self.SelectedListTable)
         self.SelectedSelectAllWidget = QtGui.QWidget(self.SelectedFileListWidget)
-        self.SelectedSelectAllWidget.setObjectName("SelectedSelectAllWidget")
+        self.SelectedSelectAllWidget.setObjectName(u'SelectedSelectAllWidget')
         self.horizontalLayout_4 = QtGui.QHBoxLayout(self.SelectedSelectAllWidget)
         self.horizontalLayout_4.setSpacing(6)
         self.horizontalLayout_4.setMargin(0)
-        self.horizontalLayout_4.setObjectName("horizontalLayout_4")
+        self.horizontalLayout_4.setObjectName(u'horizontalLayout_4')
         self.SelectedSelectAllPushButton = QtGui.QPushButton(self.SelectedSelectAllWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -212,7 +210,7 @@
         self.SelectedSelectAllPushButton.setSizePolicy(sizePolicy)
         self.SelectedSelectAllPushButton.setMinimumSize(QtCore.QSize(100, 0))
         self.SelectedSelectAllPushButton.setIcon(icon2)
-        self.SelectedSelectAllPushButton.setObjectName("SelectedSelectAllPushButton")
+        self.SelectedSelectAllPushButton.setObjectName(u'SelectedSelectAllPushButton')
         self.horizontalLayout_4.addWidget(self.SelectedSelectAllPushButton)
         spacerItem3 = QtGui.QSpacerItem(92, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_4.addItem(spacerItem3)
@@ -223,10 +221,10 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.SelectedRemoveSelectedWidget.sizePolicy().hasHeightForWidth())
         self.SelectedRemoveSelectedWidget.setSizePolicy(sizePolicy)
-        self.SelectedRemoveSelectedWidget.setObjectName("SelectedRemoveSelectedWidget")
+        self.SelectedRemoveSelectedWidget.setObjectName(u'SelectedRemoveSelectedWidget')
         self.horizontalLayout_5 = QtGui.QHBoxLayout(self.SelectedRemoveSelectedWidget)
         self.horizontalLayout_5.setMargin(0)
-        self.horizontalLayout_5.setObjectName("horizontalLayout_5")
+        self.horizontalLayout_5.setObjectName(u'horizontalLayout_5')
         self.SelectedRemoveSelectedButton = QtGui.QPushButton(self.SelectedRemoveSelectedWidget)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Minimum, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
@@ -235,9 +233,9 @@
         self.SelectedRemoveSelectedButton.setSizePolicy(sizePolicy)
         self.SelectedRemoveSelectedButton.setMinimumSize(QtCore.QSize(140, 0))
         icon4 = QtGui.QIcon()
-        icon4.addPixmap(QtGui.QPixmap(":/exports/export_remove.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon4.addPixmap(QtGui.QPixmap(u':/exports/export_remove.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.SelectedRemoveSelectedButton.setIcon(icon4)
-        self.SelectedRemoveSelectedButton.setObjectName("SelectedRemoveSelectedButton")
+        self.SelectedRemoveSelectedButton.setObjectName(u'SelectedRemoveSelectedButton')
         self.horizontalLayout_5.addWidget(self.SelectedRemoveSelectedButton)
         spacerItem4 = QtGui.QSpacerItem(49, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_5.addItem(spacerItem4)
@@ -250,61 +248,61 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ProgressGroupBox.sizePolicy().hasHeightForWidth())
         self.ProgressGroupBox.setSizePolicy(sizePolicy)
-        self.ProgressGroupBox.setObjectName("ProgressGroupBox")
+        self.ProgressGroupBox.setObjectName(u'ProgressGroupBox')
         self.verticalLayout_4 = QtGui.QVBoxLayout(self.ProgressGroupBox)
         self.verticalLayout_4.setSpacing(8)
         self.verticalLayout_4.setContentsMargins(8, 0, 8, 8)
-        self.verticalLayout_4.setObjectName("verticalLayout_4")
+        self.verticalLayout_4.setObjectName(u'verticalLayout_4')
         self.ProgressLabel = QtGui.QLabel(self.ProgressGroupBox)
-        self.ProgressLabel.setObjectName("ProgressLabel")
+        self.ProgressLabel.setObjectName(u'ProgressLabel')
         self.verticalLayout_4.addWidget(self.ProgressLabel)
         self.ProgressBar = QtGui.QProgressBar(self.ProgressGroupBox)
-        self.ProgressBar.setProperty("value", QtCore.QVariant(24))
-        self.ProgressBar.setObjectName("ProgressBar")
+        self.ProgressBar.setProperty(u'value', QtCore.QVariant(24))
+        self.ProgressBar.setObjectName(u'ProgressBar')
         self.verticalLayout_4.addWidget(self.ProgressBar)
         self.verticalLayout_5.addWidget(self.ProgressGroupBox)
         self.ButtonBarWidget = QtGui.QWidget(self.OpenSongExportForm)
-        self.ButtonBarWidget.setObjectName("ButtonBarWidget")
+        self.ButtonBarWidget.setObjectName(u'ButtonBarWidget')
         self.horizontalLayout_7 = QtGui.QHBoxLayout(self.ButtonBarWidget)
         self.horizontalLayout_7.setSpacing(8)
         self.horizontalLayout_7.setMargin(0)
-        self.horizontalLayout_7.setObjectName("horizontalLayout_7")
+        self.horizontalLayout_7.setObjectName(u'horizontalLayout_7')
         spacerItem5 = QtGui.QSpacerItem(288, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_7.addItem(spacerItem5)
         self.ExportPushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ExportPushButton.setObjectName("ExportPushButton")
+        self.ExportPushButton.setObjectName(u'ExportPushButton')
         self.horizontalLayout_7.addWidget(self.ExportPushButton)
         self.ClosePushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ClosePushButton.setObjectName("ClosePushButton")
+        self.ClosePushButton.setObjectName(u'ClosePushButton')
         self.horizontalLayout_7.addWidget(self.ClosePushButton)
         self.verticalLayout_5.addWidget(self.ButtonBarWidget)
 
         self.retranslateUi()
-        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL("clicked()"), self.OpenSongExportForm.close)
-        QtCore.QObject.connect(self.ExportSelectAllPushButton, QtCore.SIGNAL("clicked()"), self.ExportListTable.selectAll)
-        QtCore.QObject.connect(self.SelectedSelectAllPushButton, QtCore.SIGNAL("clicked()"), self.SelectedListTable.selectAll)
-        QtCore.QObject.connect(self.SelectedRemoveSelectedButton, QtCore.SIGNAL("clicked()"), self.SelectedListTable.clear)
+        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL(u'clicked()'), self.OpenSongExportForm.close)
+        QtCore.QObject.connect(self.ExportSelectAllPushButton, QtCore.SIGNAL(u'clicked()'), self.ExportListTable.selectAll)
+        QtCore.QObject.connect(self.SelectedSelectAllPushButton, QtCore.SIGNAL(u'clicked()'), self.SelectedListTable.selectAll)
+        QtCore.QObject.connect(self.SelectedRemoveSelectedButton, QtCore.SIGNAL(u'clicked()'), self.SelectedListTable.clear)
         QtCore.QMetaObject.connectSlotsByName(self.OpenSongExportForm)
 
     def retranslateUi(self):
-        self.OpenSongExportForm.setWindowTitle(QtGui.QApplication.translate("OpenSongExportForm", "OpenSong Song Exporter", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFileLabel.setText(QtGui.QApplication.translate("OpenSongExportForm", "Select OpenSong song folder:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportListLabel.setText(QtGui.QApplication.translate("OpenSongExportForm", "Full Song List", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportListTable.horizontalHeaderItem(0).setText(QtGui.QApplication.translate("OpenSongExportForm", "Song Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportListTable.horizontalHeaderItem(1).setText(QtGui.QApplication.translate("OpenSongExportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportSelectAllPushButton.setText(QtGui.QApplication.translate("OpenSongExportForm", "Select All", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFilterComboBox.setItemText(0, QtGui.QApplication.translate("OpenSongExportForm", "Lyrics", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFilterComboBox.setItemText(1, QtGui.QApplication.translate("OpenSongExportForm", "Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportFilterComboBox.setItemText(2, QtGui.QApplication.translate("OpenSongExportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListLabel.setText(QtGui.QApplication.translate("OpenSongExportForm", "Song Export List", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListTable.horizontalHeaderItem(0).setText(QtGui.QApplication.translate("OpenSongExportForm", "Song Title", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedListTable.horizontalHeaderItem(1).setText(QtGui.QApplication.translate("OpenSongExportForm", "Author", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedSelectAllPushButton.setText(QtGui.QApplication.translate("OpenSongExportForm", "Select All", None, QtGui.QApplication.UnicodeUTF8))
-        self.SelectedRemoveSelectedButton.setText(QtGui.QApplication.translate("OpenSongExportForm", "Remove Selected", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressGroupBox.setTitle(QtGui.QApplication.translate("OpenSongExportForm", "Progress:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressLabel.setText(QtGui.QApplication.translate("OpenSongExportForm", "Ready to export", None, QtGui.QApplication.UnicodeUTF8))
-        self.ExportPushButton.setText(QtGui.QApplication.translate("OpenSongExportForm", "Export", None, QtGui.QApplication.UnicodeUTF8))
-        self.ClosePushButton.setText(QtGui.QApplication.translate("OpenSongExportForm", "Close", None, QtGui.QApplication.UnicodeUTF8))
+        self.OpenSongExportForm.setWindowTitle(translate(u'OpenSongExportForm', u'OpenSong Song Exporter'))
+        self.ExportFileLabel.setText(translate(u'OpenSongExportForm', u'Select OpenSong song folder:'))
+        self.ExportListLabel.setText(translate(u'OpenSongExportForm', u'Full Song List'))
+        self.ExportListTable.horizontalHeaderItem(0).setText(translate(u'OpenSongExportForm', u'Song Title'))
+        self.ExportListTable.horizontalHeaderItem(1).setText(translate(u'OpenSongExportForm', u'Author'))
+        self.ExportSelectAllPushButton.setText(translate(u'OpenSongExportForm', u'Select All'))
+        self.ExportFilterComboBox.setItemText(0, translate(u'OpenSongExportForm', u'Lyrics'))
+        self.ExportFilterComboBox.setItemText(1, translate(u'OpenSongExportForm', u'Title'))
+        self.ExportFilterComboBox.setItemText(2, translate(u'OpenSongExportForm', u'Author'))
+        self.SelectedListLabel.setText(translate(u'OpenSongExportForm', u'Song Export List'))
+        self.SelectedListTable.horizontalHeaderItem(0).setText(translate(u'OpenSongExportForm', u'Song Title'))
+        self.SelectedListTable.horizontalHeaderItem(1).setText(translate(u'OpenSongExportForm', u'Author'))
+        self.SelectedSelectAllPushButton.setText(translate(u'OpenSongExportForm', u'Select All'))
+        self.SelectedRemoveSelectedButton.setText(translate(u'OpenSongExportForm', u'Remove Selected'))
+        self.ProgressGroupBox.setTitle(translate(u'OpenSongExportForm', u'Progress:'))
+        self.ProgressLabel.setText(translate(u'OpenSongExportForm', u'Ready to export'))
+        self.ExportPushButton.setText(translate(u'OpenSongExportForm', u'Export'))
+        self.ClosePushButton.setText(translate(u'OpenSongExportForm', u'Close'))
 
     def show(self):
         self.OpenSongExportForm.show()

=== modified file 'openlp/plugins/songs/forms/opensongimportform.py'
--- openlp/plugins/songs/forms/opensongimportform.py	2009-05-01 22:26:43 +0000
+++ openlp/plugins/songs/forms/opensongimportform.py	2009-06-16 18:21:24 +0000
@@ -3,7 +3,7 @@
 """
 OpenLP - Open Source Lyrics Projection
 Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 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
 the terms of the GNU General Public License as published by the Free Software
@@ -17,10 +17,8 @@
 this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 Place, Suite 330, Boston, MA 02111-1307 USA
 """
-
 from PyQt4 import QtCore, QtGui
-
-from openlp.core.resources import *
+from openlp.core.lib import translate
 
 class OpenSongImportForm(object):
 
@@ -29,37 +27,37 @@
         self.setupUi()
 
     def setupUi(self):
-        self.OpenSongImportForm.setObjectName("OpenSongImportForm")
+        self.OpenSongImportForm.setObjectName(u'OpenSongImportForm')
         self.OpenSongImportForm.resize(481, 153)
         icon = QtGui.QIcon()
-        icon.addPixmap(QtGui.QPixmap(":/icon/openlp-logo-16x16.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon.addPixmap(QtGui.QPixmap(u':/icon/openlp-logo-16x16.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.OpenSongImportForm.setWindowIcon(icon)
         self.verticalLayout = QtGui.QVBoxLayout(self.OpenSongImportForm)
         self.verticalLayout.setSpacing(6)
         self.verticalLayout.setMargin(8)
-        self.verticalLayout.setObjectName("verticalLayout")
+        self.verticalLayout.setObjectName(u'verticalLayout')
         self.ImportFileWidget = QtGui.QWidget(self.OpenSongImportForm)
         sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ImportFileWidget.sizePolicy().hasHeightForWidth())
         self.ImportFileWidget.setSizePolicy(sizePolicy)
-        self.ImportFileWidget.setObjectName("ImportFileWidget")
+        self.ImportFileWidget.setObjectName(u'ImportFileWidget')
         self.horizontalLayout = QtGui.QHBoxLayout(self.ImportFileWidget)
         self.horizontalLayout.setSpacing(6)
         self.horizontalLayout.setMargin(0)
-        self.horizontalLayout.setObjectName("horizontalLayout")
+        self.horizontalLayout.setObjectName(u'horizontalLayout')
         self.ImportFileLabel = QtGui.QLabel(self.ImportFileWidget)
-        self.ImportFileLabel.setObjectName("ImportFileLabel")
+        self.ImportFileLabel.setObjectName(u'ImportFileLabel')
         self.horizontalLayout.addWidget(self.ImportFileLabel)
         self.ImportFileLineEdit = QtGui.QLineEdit(self.ImportFileWidget)
-        self.ImportFileLineEdit.setObjectName("ImportFileLineEdit")
+        self.ImportFileLineEdit.setObjectName(u'ImportFileLineEdit')
         self.horizontalLayout.addWidget(self.ImportFileLineEdit)
         self.ImportFileSelectPushButton = QtGui.QPushButton(self.ImportFileWidget)
         icon1 = QtGui.QIcon()
-        icon1.addPixmap(QtGui.QPixmap(":/imports/import_load.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
+        icon1.addPixmap(QtGui.QPixmap(u':/imports/import_load.png'), QtGui.QIcon.Normal, QtGui.QIcon.Off)
         self.ImportFileSelectPushButton.setIcon(icon1)
-        self.ImportFileSelectPushButton.setObjectName("ImportFileSelectPushButton")
+        self.ImportFileSelectPushButton.setObjectName(u'ImportFileSelectPushButton')
         self.horizontalLayout.addWidget(self.ImportFileSelectPushButton)
         self.verticalLayout.addWidget(self.ImportFileWidget)
         self.ProgressGroupBox = QtGui.QGroupBox(self.OpenSongImportForm)
@@ -68,46 +66,46 @@
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.ProgressGroupBox.sizePolicy().hasHeightForWidth())
         self.ProgressGroupBox.setSizePolicy(sizePolicy)
-        self.ProgressGroupBox.setObjectName("ProgressGroupBox")
+        self.ProgressGroupBox.setObjectName(u'ProgressGroupBox')
         self.verticalLayout_4 = QtGui.QVBoxLayout(self.ProgressGroupBox)
         self.verticalLayout_4.setSpacing(6)
         self.verticalLayout_4.setContentsMargins(6, 0, 8, 8)
-        self.verticalLayout_4.setObjectName("verticalLayout_4")
+        self.verticalLayout_4.setObjectName(u'verticalLayout_4')
         self.ProgressLabel = QtGui.QLabel(self.ProgressGroupBox)
-        self.ProgressLabel.setObjectName("ProgressLabel")
+        self.ProgressLabel.setObjectName(u'ProgressLabel')
         self.verticalLayout_4.addWidget(self.ProgressLabel)
         self.ProgressBar = QtGui.QProgressBar(self.ProgressGroupBox)
-        self.ProgressBar.setProperty("value", QtCore.QVariant(24))
-        self.ProgressBar.setObjectName("ProgressBar")
+        self.ProgressBar.setProperty(u'value', QtCore.QVariant(24))
+        self.ProgressBar.setObjectName(u'ProgressBar')
         self.verticalLayout_4.addWidget(self.ProgressBar)
         self.verticalLayout.addWidget(self.ProgressGroupBox)
         self.ButtonBarWidget = QtGui.QWidget(self.OpenSongImportForm)
-        self.ButtonBarWidget.setObjectName("ButtonBarWidget")
+        self.ButtonBarWidget.setObjectName(u'ButtonBarWidget')
         self.horizontalLayout_7 = QtGui.QHBoxLayout(self.ButtonBarWidget)
         self.horizontalLayout_7.setSpacing(8)
         self.horizontalLayout_7.setMargin(0)
-        self.horizontalLayout_7.setObjectName("horizontalLayout_7")
+        self.horizontalLayout_7.setObjectName(u'horizontalLayout_7')
         spacerItem = QtGui.QSpacerItem(288, 20, QtGui.QSizePolicy.Expanding, QtGui.QSizePolicy.Minimum)
         self.horizontalLayout_7.addItem(spacerItem)
         self.ImportPushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ImportPushButton.setObjectName("ImportPushButton")
+        self.ImportPushButton.setObjectName(u'ImportPushButton')
         self.horizontalLayout_7.addWidget(self.ImportPushButton)
         self.ClosePushButton = QtGui.QPushButton(self.ButtonBarWidget)
-        self.ClosePushButton.setObjectName("ClosePushButton")
+        self.ClosePushButton.setObjectName(u'ClosePushButton')
         self.horizontalLayout_7.addWidget(self.ClosePushButton)
         self.verticalLayout.addWidget(self.ButtonBarWidget)
 
         self.retranslateUi()
-        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL("clicked()"), self.OpenSongImportForm.close)
+        QtCore.QObject.connect(self.ClosePushButton, QtCore.SIGNAL(u'clicked()'), self.OpenSongImportForm.close)
         QtCore.QMetaObject.connectSlotsByName(self.OpenSongImportForm)
 
     def retranslateUi(self):
-        self.OpenSongImportForm.setWindowTitle(QtGui.QApplication.translate("OpenSongImportForm", "OpenSong Song Importer", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportFileLabel.setText(QtGui.QApplication.translate("OpenSongImportForm", "OpenSong Folder:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressGroupBox.setTitle(QtGui.QApplication.translate("OpenSongImportForm", "Progress:", None, QtGui.QApplication.UnicodeUTF8))
-        self.ProgressLabel.setText(QtGui.QApplication.translate("OpenSongImportForm", "Ready to import", None, QtGui.QApplication.UnicodeUTF8))
-        self.ImportPushButton.setText(QtGui.QApplication.translate("OpenSongImportForm", "Import", None, QtGui.QApplication.UnicodeUTF8))
-        self.ClosePushButton.setText(QtGui.QApplication.translate("OpenSongImportForm", "Close", None, QtGui.QApplication.UnicodeUTF8))
+        self.OpenSongImportForm.setWindowTitle(translate(u'OpenSongImportForm', u'OpenSong Song Importer'))
+        self.ImportFileLabel.setText(translate(u'OpenSongImportForm', u'OpenSong Folder:'))
+        self.ProgressGroupBox.setTitle(translate(u'OpenSongImportForm', u'Progress:'))
+        self.ProgressLabel.setText(translate(u'OpenSongImportForm', u'Ready to import'))
+        self.ImportPushButton.setText(translate(u'OpenSongImportForm', u'Import'))
+        self.ClosePushButton.setText(translate(u'OpenSongImportForm', u'Close'))
 
     def show(self):
         self.OpenSongImportForm.show()

=== modified file 'openlp/plugins/songs/lib/mediaitem.py'
--- openlp/plugins/songs/lib/mediaitem.py	2009-06-14 13:50:56 +0000
+++ openlp/plugins/songs/lib/mediaitem.py	2009-06-16 18:21:24 +0000
@@ -216,8 +216,9 @@
     def onSongDeleteClick(self):
         item = self.SongListWidget.currentItem()
         item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0]
-        self.parent.songmanager.delete_song(id)
-        self.SongListWidget.removeItem(item)
+        self.parent.songmanager.delete_song(item_id)
+        row = self.SongListWidget.row(item)
+        self.SongListWidget.takeItem(row)
 
     def onSongPreviewClick(self):
         service_item = ServiceItem(self.parent)
@@ -238,7 +239,8 @@
             songXML=SongXMLParser(song.lyrics)
             verseList = songXML.get_verses()
             for verse in verseList:
-                service_item.add_from_text(verse[1][:30], verse[1])
+                if verse[1] is not None:
+                    service_item.add_from_text(verse[1][:30], verse[1])
         else:
             verses = song.lyrics.split(u'\n\n')
             for slide in verses:

=== modified file 'openlp/plugins/songs/lib/songxml.py'
--- openlp/plugins/songs/lib/songxml.py	2009-01-06 20:10:03 +0000
+++ openlp/plugins/songs/lib/songxml.py	2009-06-16 18:21:24 +0000
@@ -1,663 +1,663 @@
-# -*- coding:iso-8859-1 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
-
-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
-"""
-
-import sys
-import os
-from types import StringType, ListType, NoneType
-
-sys.path.append(os.path.abspath("./../../../.."))
-
-from openlp.core.lib import XmlRootClass
-
-class SongException(Exception):
-    pass
-
-class SongTitleError(SongException):
-    pass
-
-class SongTypeError(SongException):
-    pass
-
-class SongSlideError(SongException):
-    pass
-
-class SongFeatureError(SongException):
-    pass
-
-# TODO: Song: Logging - not all, but enough
-# TODO: Song: Handle OpenLP2 format
-# TODO: Song: Import OpenLP1
-# TODO: Song: Export OpenLP1
-# TODO: Song: Export Song to CCLI
-# TODO: Song: Export Song to OpenSong
-# TODO: Song: Import ChangingSong
-# TODO: Song: Export ChangingSong
-
-_blankOpenSongXml = \
-'''<?xml version="1.0" encoding="UTF-8"?>
-<song>
-  <title></title>
-  <author></author>
-  <copyright></copyright>
-  <presentation></presentation>
-  <ccli></ccli>
-  <lyrics></lyrics>
-  <theme></theme>
-  <alttheme></alttheme>
-</song>
-'''
-
-class _OpenSong(XmlRootClass):
-    """Class for import of OpenSogn"""
-
-    def __init__(self,  xmlContent = None):
-        """Initialize from given xml content"""
-        super(_OpenSong, self).__init__()
-        self.from_buffer(xmlContent)
-
-    def _reset(self):
-        """Reset all song attributes"""
-        global _blankOpenSongXml
-        self._setFromXml(_blankOpenSongXml, "song")
-
-    def from_buffer(self,  xmlContent):
-        """Initialize from buffer(string) with xml content"""
-        self._reset()
-        if xmlContent != None :
-            self._setFromXml(xmlContent, "song")
-
-    def get_author_list(self):
-        """Convert author field to an authorlist
-
-        in OpenSong an author list may be separated by '/'
-        return as a string
-        """
-        res = []
-        if self.author != None :
-            lst = self.author.split(' and ')
-            for l in lst :
-                res.append(l.strip())
-        s = ", ".join(res)
-        return s
-
-    def get_category_array(self):
-        """Convert theme and alttheme into category_array
-
-        return as a string
-        """
-        res = []
-        if self.theme != None :
-            res.append(self.theme)
-        if self.alttheme != None :
-            res.append(self.alttheme)
-        s = ", ".join(res)
-        return s
-
-    def _reorder_verse(self, tag, tmpVerse):
-        """Reorder the verse in case of first char is a number
-
-        tag -- the tag of this verse / verse group
-        tmpVerse -- list of strings
-        """
-        res = []
-        for c in '1234567890 ':
-            tagPending = True
-            for l in tmpVerse :
-                if l.startswith(c) :
-                    if tagPending :
-                        tagPending = False
-                        t = tag.strip("[]").lower()
-                        if 'v' == t :
-                            newtag = "Verse"
-                        elif 'c' == t :
-                            newtag = "Chorus"
-                        elif 'b' == t :
-                            newtag = "Bridge"
-                        elif 'p' == t :
-                            newtag = "Pre-chorus"
-                        else :
-                            newtag = t
-                        s = ("# %s %s"%(newtag, c)).rstrip()
-                        res.append(s)
-                    res.append(l[1:])
-                if (len(l) == 0) and (not tagPending) :
-                    res.append(l)
-        return res
-
-    def get_lyrics(self):
-        """Convert the lyrics to openlp lyrics format
-
-        return as list of strings
-        """
-        lyrics = self.lyrics.split("\n")
-        tmpVerse = []
-        finalLyrics = []
-        tag = ""
-        for l in lyrics:
-            line = l.rstrip()
-            if not line.startswith('.') :
-                # drop all chords
-                tmpVerse.append(line)
-                if len(line) > 0 :
-                    if line.startswith('['):
-                        tag = line
-                else :
-                    r = self._reorder_verse(tag, tmpVerse)
-                    finalLyrics.extend(r)
-                    tag = ""
-                    tmpVerse = []
-        # catch up final verse
-        r = self._reorder_verse(tag, tmpVerse)
-        finalLyrics.extend(r)
-        return finalLyrics
-
-
-class Song(object) :
-    """Handling song properties and methods 
-    
-    handles all conversions between various input and output formats
-    
-    CCLI :
-        from_ccli_text_file
-        to_ccli_text_file
-        from_ccli_text_buffer
-        to_ccli_text_buffer
-        
-    OpenSong:
-        from_opensong_file
-        to_opensong_file
-        from_opensong_buffer
-        to_opensong_buffer
-        
-    presentation (screen):
-        get_number_of_slides
-        get_preview_slide
-        get_render_slide
-        
-    openlp1 :
-        from_openlp1_lyrics_buffer
-        to_openlp1_lyrics_buffer
-        set_author_list
-        get_author_list
-        
-    editing and openlp2 :
-        set_*
-        get_*
-    """
-
-    def __init__(self, songid = 0):
-        """Initialize song object
-
-        songid -- database id for this song
-        title -- title of the song
-        search_title -- title without punctuation chars
-        author_list -- list of authors
-        song_cclino -- CCLI number for this song
-        copyright -- copyright string
-        show_title -- 0: no show, 1: show
-        show_author_list -- 0: no show, 1: show
-        show_copyright -- 0: no show, 1: show
-        show_song_cclino -- 0: no show, 1: show
-        theme -- name of theme or blank
-        category_array -- list of user defined properties (hymn, gospel)
-        song_book -- name of originating book
-        song_number -- number of the song, related to a songbook
-        comments -- free comment
-        verse_order -- presentation order of the slides
-        lyrics -- text format
-        search_lyrics -- lowercase lyrics without punctuation
-        """
-        self.songid = songid
-        self._reset()
-
-    def _reset(self):
-        """Reset all song attributes"""
-        self.slideList = []
-        self.set_title("BlankSong")
-        self.author_list = None
-        self.song_cclino = ""
-        self.copyright = ""
-        self.show_author_list = 1
-        self.show_copyright = 1
-        self.show_song_cclino = 1
-        self.show_title = 1
-        self.theme = ""
-        self.category_array = None
-        self.song_book = ""
-        self.song_number = ""
-        self.comments = ""
-        self.verse_order = ""
-        self.set_lyrics("")
-        return
-
-    def set_songid(self, songid):
-        """Set the songid for the database"""
-        self.songid = songid
-        
-    def get_songid(self):
-        """Return the songid for the database"""
-        return self.songid
-    
-    def from_opensong_buffer(self,  xmlcontent):
-        """Initialize from buffer(string) of xml lines in opensong format"""
-        self._reset()
-        opensong = _OpenSong(xmlcontent)
-        if opensong.title != None:
-            self.set_title(opensong.title)
-        if opensong.copyright != None :
-            self.set_copyright(opensong.copyright)
-        if opensong.presentation != None:
-            self.set_verse_order(opensong.presentation)
-        if opensong.ccli != None:
-            self.set_song_cclino(opensong.ccli)
-        self.set_author_list(opensong.get_author_list())
-        self.set_category_array(opensong.get_category_array())
-        self.set_lyrics(opensong.get_lyrics())
-
-    def from_opensong_file(self,  xmlfilename):
-        """Initialize from file containing xml
-
-        xmlfilename -- path to xml file
-        """
-        lst = []
-        f = open(xmlfilename,  'r')
-        for line in f :
-            lst.append(line)
-        f.close()
-        xml = "".join(lst)
-        self.from_opensong_buffer(xml)
-
-    def _remove_punctuation(self,  title):
-        """Remove the puntuation chars from title
-
-        chars are: .,:;!?&%#/\@`$'|"^~*-
-        """
-        punctuation = ".,:;!?&%#'\"/\\@`$|^~*-"
-        s = title
-        for c in punctuation :
-            s = s.replace(c,  '')
-        return s
-
-    def set_title(self, title):
-        """Set the song title
-
-        title (string)
-        raises SongTitleError if the title is empty
-        raises SongTitleError if the seach_title is empty
-        """
-        self.title = title.strip()
-        self.search_title = self._remove_punctuation(title).strip()
-        if len(self.title) < 1 :
-            raise SongTitleError("The title is empty")
-        if len(self.search_title) < 1 :
-            raise SongTitleError("The searchable title is empty")
-
-    def get_title(self):
-        """Return title value"""
-        return self.title
-
-    def get_search_title(self):
-        """Return search_title"""
-        return self.search_title
-
-    def from_ccli_text_buffer(self, textList):
-        """Create song from a list of texts (strings) - CCLI text format expected
-
-        textList (list of strings) -- the song
-        """
-        self._reset()
-        # extract the following fields
-        # - name
-        # - author
-        # - CCLI no
-        sName = ""
-        sAuthor = ""
-        sCopyright = ""
-        sCcli = ""
-        lastpart = 0
-        n = 0
-        metMisc = False
-        lyrics = []
-        for l in textList :
-            n += 1
-            if lastpart > 0 :
-                lastpart += 1
-                if lastpart == 2 :
-                    sCopyright = l[1:].strip()
-                if lastpart == 3 :
-                    sAuthor = l
-            elif l.startswith('CCLI Song') :
-                sCcli = l[13:].strip()
-                lastpart = 1
-            else :
-                if metMisc :
-                    metMisc = False
-                    if l.upper().startswith("(BRIDGE)") :
-                        lyrics.append("# Bridge")
-                    # otherwise unknown misc keyword
-                elif l.startswith("Misc") :
-                    metMisc = True
-                elif l.startswith("Verse") or l.startswith("Chorus"):
-                    lyrics.append("# %s"%l)
-                else :
-                    # should we remove multiple blank lines?
-                    if n == 1 :
-                        sName = l
-                    else :
-                        lyrics.append(l)
-        # split on known separators
-        lst = sAuthor.split('/')
-        if len(lst) < 2:
-            lst = sAuthor.split('|')
-        author_list = ", ".join(lst)
-        self.set_title(sName)
-        self.set_author_list(author_list)
-        self.set_copyright(sCopyright)
-        self.set_song_cclino(sCcli)
-        self.set_lyrics(lyrics)
-
-    def from_ccli_text_file(self,  textFileName):
-        """Create song from a list of texts read from given file
-
-        textFileName -- path to text file
-        """
-        lines = []
-        f = open(textFileName,  'r')
-        for orgline in f:
-            lines.append(orgline.rstrip())
-        f.close()
-        self.from_ccli_text_buffer(lines)
-
-    def _assure_string(self, s):
-        """Force a string is returned"""
-        if s == None :
-            r = ""
-        else :
-            r = str(s)
-        return r
-
-    def _split_to_list(self, aString):
-        """Split a string into a list - comma separated"""
-        res = []
-        if aString != None :
-            lst = aString.split(',')
-            for l in lst :
-                # remove whitespace
-                res.append(l.strip())
-        return res
-
-    def _list_to_string(self, strOrList):
-        """Force a possibly list into a string"""
-        if type(strOrList) == StringType :
-            lst = self._split_to_list(strOrList)
-        elif type(strOrList) == ListType :
-            lst = strOrList
-        elif type(strOrList) == NoneType :
-            lst = []
-        else :
-            raise SongTypeError("Variable not String or List")
-        s = ", ".join(lst)
-        return s
-
-    def get_copyright(self):
-        """Return copyright info string"""
-        return self._assure_string(self.copyright)
-
-    def set_copyright(self,  copyright):
-        """Set the copyright string"""
-        self.copyright = copyright
-
-    def get_song_cclino(self):
-        """Return the songCclino"""
-        return self._assure_string(self.song_cclino)
-
-    def set_song_cclino(self,  song_cclino):
-        """Set the song_cclino"""
-        self.song_cclino = song_cclino
-
-    def get_theme(self):
-        """Return the theme name for the song"""
-        return self._assure_string(self.theme)
-
-    def set_theme(self,  theme):
-        """Set the theme name (string)"""
-        self.theme = theme
-
-    def get_song_book(self):
-        """Return the song_book (string)"""
-        return self._assure_string(self.song_book)
-
-    def set_song_book(self,  song_book):
-        """Set the song_book (string)"""
-        self.song_book = song_book
-
-    def get_song_number(self):
-        """Return the song_number (string)"""
-        return self._assure_string(self.song_number)
-
-    def set_song_number(self,  song_number):
-        """Set the song_number (string)"""
-        self.song_number = song_number
-
-    def get_comments(self):
-        """Return the comments (string)"""
-        return self._assure_string(self.comments)
-
-    def set_comments(self,  comments):
-        """Set the comments (string)"""
-        self.comments = comments
-
-    def get_verse_order(self):
-        """Get the verseOrder (string) - preferably space delimited"""
-        return self._assure_string(self.verse_order)
-
-    def set_verse_order(self,  verse_order):
-        """Set the verse order (string) - space delimited"""
-        self.verse_order = verse_order
-
-    def get_author_list(self,  asOneString = True):
-        """Return the list of authors as a string
-
-        asOneString
-        True -- string:
-          "John Newton, A Parker"
-        False -- list of strings
-          ["John Newton", "A Parker"]
-        """
-        if asOneString :
-            res = self._assure_string(self.author_list)
-        else :
-            res = self._split_to_list(self.author_list)
-        return res
-
-    def set_author_list(self,  author_list):
-        """Set the author_list
-
-        author_list -- a string or list of strings
-        """
-        if author_list == None :
-            self.author_list = None
-        else :
-            self.author_list = self._list_to_string(author_list)
-
-    def get_category_array(self,  asOneString = True):
-        """Return the list of categories as a string
-
-        asOneString
-        True -- string:
-          "Hymn, Gospel"
-        False -- list of strings
-          ["Hymn", "Gospel"]
-        """
-        if asOneString :
-            res = self._assure_string(self.category_array)
-        else :
-            res = self._split_to_list(self.category_array)
-        return res
-
-    def set_category_array(self,  category_array):
-        """Set the category_array
-
-        category_array -- a string or list of strings
-        """
-        if category_array == None :
-            self.category_array = None
-        else :
-            self.category_array = self._list_to_string(category_array)
-
-    def get_show_title(self):
-        """Return the show_title flag (bool)"""
-        return self.show_title
-
-    def set_show_title(self,  show_title):
-        """Set the show_title flag (bool)"""
-        self.show_title = show_title
-
-    def get_show_author_list(self):
-        """Return the show_author_list flag"""
-        return self.show_author_list
-
-    def set_show_author_list(self,  show_author_list):
-        """Set the show_author_list flag (bool)"""
-        self.show_author_list = show_author_list
-
-    def get_show_copyright(self):
-        """Return the show_copyright flag"""
-        return self.show_copyright
-
-    def set_show_copyright(self, show_copyright):
-        """Set the show_copyright flag (bool)"""
-        self.show_copyright = show_copyright
-
-    def get_show_song_cclino(self):
-        """Return the showSongCclino (string)"""
-        return self.show_song_cclino
-
-    def set_show_song_cclino(self,  show_song_cclino):
-        """Set the show_song_cclino flag (bool)"""
-        self.show_song_cclino = show_song_cclino
-
-    def get_lyrics(self):
-        """Return the lyrics as a list of strings
-
-        this will return all the strings in the song
-        """
-        return self.lyrics
-
-    def set_lyrics(self,  lyrics):
-        """Set the lyrics as a list of strings"""
-        self.lyrics = lyrics
-        self._parse_lyrics()
-
-    def _parse_lyrics(self):
-        """Parse lyrics into the slidelist"""
-        # TODO: check font formatting
-        self.slideList = []
-        tmpSlide = []
-        metContent = False
-        for l in self.lyrics :
-            if len(l) > 0 :
-                metContent = True
-                tmpSlide.append(l)
-            else :
-                if metContent :
-                    metContent = False
-                    self.slideList.append(tmpSlide)
-                    tmpSlide = []
-        #
-        if len(tmpSlide) > 0:
-            self.slideList.append(tmpSlide)
-
-    def get_number_of_slides(self):
-        """Return the number of slides in the song (int)"""
-        numOfSlides = len(self.slideList)
-        return numOfSlides
-
-    def get_preview_slide(self,  slideNumber):
-        """Return the preview text for specified slide number
-
-        slideNumber -- 0: all slides, 1..n : specific slide
-        a list of strings are returned
-        """
-        num = len(self.slideList)
-        if num < 1 :
-            raise SongSlideError("No slides in this song")
-        elif slideNumber > num :
-            raise SongSlideError("Slide number too high")
-        if slideNumber > 0 :
-            # return this slide
-            res = self.slideList[slideNumber-1]
-            # find theme in this slide
-        else :
-            res = []
-            for i in range(num):
-                if i > 0 :
-                    res.append("")
-                res.extend()
-        # remove formattingincluding themes
-        return res
-
-    def get_render_slide(self,  slideNumber):
-        """Return the slide to be rendered including the additional
-        properties
-
-        slideNumber -- 1 .. numberOfSlides
-        Returns a list as:
-        [theme (string),
-         title (string),
-         authorlist (string),
-         copyright (string),
-         cclino (string),
-         lyric-part as a list of strings]
-        """
-        num = len(self.slideList)
-        if num < 1 :
-            raise SongSlideError("No slides in this song")
-        elif slideNumber > num :
-            raise SongSlideError("Slide number too high")
-        res = []
-        if self.show_title :
-            title = self.get_title()
-        else :
-            title = ""
-        if self.show_author_list :
-            author = self.get_author_list(True)
-        else :
-            author = ""
-        if self.show_copyright :
-            cpright = self.get_copyright()
-        else :
-            cpright = ""
-        if self.show_song_cclino :
-            ccli = self.get_song_cclino()
-        else :
-            ccli = ""
-        theme = self.get_theme()
-        # examine the slide for a theme
-        res.append(theme)
-        res.append(title)
-        res.append(author)
-        res.append(cpright)
-        res.append(ccli)
-        # append the correct slide
-        return res
-
-__all__ = ['SongException', 'SongTitleError', 'SongSlideError', 'SongTypeError',
-           'SongFeatureError', 'Song']
+# -*- coding:iso-8859-1 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
+
+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
+"""
+
+import sys
+import os
+from types import StringType, ListType, NoneType
+
+sys.path.append(os.path.abspath(u'./../../../..'))
+
+from openlp.core.lib import XmlRootClass
+
+class SongException(Exception):
+    pass
+
+class SongTitleError(SongException):
+    pass
+
+class SongTypeError(SongException):
+    pass
+
+class SongSlideError(SongException):
+    pass
+
+class SongFeatureError(SongException):
+    pass
+
+# TODO: Song: Logging - not all, but enough
+# TODO: Song: Handle OpenLP2 format
+# TODO: Song: Import OpenLP1
+# TODO: Song: Export OpenLP1
+# TODO: Song: Export Song to CCLI
+# TODO: Song: Export Song to OpenSong
+# TODO: Song: Import ChangingSong
+# TODO: Song: Export ChangingSong
+
+_blankOpenSongXml = \
+'''<?xml version="1.0" encoding="UTF-8"?>
+<song>
+  <title></title>
+  <author></author>
+  <copyright></copyright>
+  <presentation></presentation>
+  <ccli></ccli>
+  <lyrics></lyrics>
+  <theme></theme>
+  <alttheme></alttheme>
+</song>
+'''
+
+class _OpenSong(XmlRootClass):
+    """Class for import of OpenSogn"""
+
+    def __init__(self,  xmlContent = None):
+        """Initialize from given xml content"""
+        super(_OpenSong, self).__init__()
+        self.from_buffer(xmlContent)
+
+    def _reset(self):
+        """Reset all song attributes"""
+        global _blankOpenSongXml
+        self._setFromXml(_blankOpenSongXml, "song')
+
+    def from_buffer(self,  xmlContent):
+        """Initialize from buffer(string) with xml content"""
+        self._reset()
+        if xmlContent != None :
+            self._setFromXml(xmlContent, "song')
+
+    def get_author_list(self):
+        """Convert author field to an authorlist
+
+        in OpenSong an author list may be separated by '/'
+        return as a string
+        """
+        res = []
+        if self.author != None :
+            lst = self.author.split(u' and ')
+            for l in lst :
+                res.append(l.strip())
+        s = ", u'.join(res)
+        return s
+
+    def get_category_array(self):
+        """Convert theme and alttheme into category_array
+
+        return as a string
+        """
+        res = []
+        if self.theme != None :
+            res.append(self.theme)
+        if self.alttheme != None :
+            res.append(self.alttheme)
+        s = ", u'.join(res)
+        return s
+
+    def _reorder_verse(self, tag, tmpVerse):
+        """Reorder the verse in case of first char is a number
+
+        tag -- the tag of this verse / verse group
+        tmpVerse -- list of strings
+        """
+        res = []
+        for c in '1234567890 ':
+            tagPending = True
+            for l in tmpVerse :
+                if l.startswith(c) :
+                    if tagPending :
+                        tagPending = False
+                        t = tag.strip(u'[]').lower()
+                        if 'v' == t :
+                            newtag = "Verse"
+                        elif 'c' == t :
+                            newtag = "Chorus"
+                        elif 'b' == t :
+                            newtag = "Bridge"
+                        elif 'p' == t :
+                            newtag = "Pre-chorus"
+                        else :
+                            newtag = t
+                        s = (u'# %s %s"%(newtag, c)).rstrip()
+                        res.append(s)
+                    res.append(l[1:])
+                if (len(l) == 0) and (not tagPending) :
+                    res.append(l)
+        return res
+
+    def get_lyrics(self):
+        """Convert the lyrics to openlp lyrics format
+
+        return as list of strings
+        """
+        lyrics = self.lyrics.split(u'\n')
+        tmpVerse = []
+        finalLyrics = []
+        tag = ""
+        for l in lyrics:
+            line = l.rstrip()
+            if not line.startswith(u'.') :
+                # drop all chords
+                tmpVerse.append(line)
+                if len(line) > 0 :
+                    if line.startswith(u'['):
+                        tag = line
+                else :
+                    r = self._reorder_verse(tag, tmpVerse)
+                    finalLyrics.extend(r)
+                    tag = ""
+                    tmpVerse = []
+        # catch up final verse
+        r = self._reorder_verse(tag, tmpVerse)
+        finalLyrics.extend(r)
+        return finalLyrics
+
+
+class Song(object) :
+    """Handling song properties and methods 
+    
+    handles all conversions between various input and output formats
+    
+    CCLI :
+        from_ccli_text_file
+        to_ccli_text_file
+        from_ccli_text_buffer
+        to_ccli_text_buffer
+        
+    OpenSong:
+        from_opensong_file
+        to_opensong_file
+        from_opensong_buffer
+        to_opensong_buffer
+        
+    presentation (screen):
+        get_number_of_slides
+        get_preview_slide
+        get_render_slide
+        
+    openlp1 :
+        from_openlp1_lyrics_buffer
+        to_openlp1_lyrics_buffer
+        set_author_list
+        get_author_list
+        
+    editing and openlp2 :
+        set_*
+        get_*
+    """
+
+    def __init__(self, songid = 0):
+        """Initialize song object
+
+        songid -- database id for this song
+        title -- title of the song
+        search_title -- title without punctuation chars
+        author_list -- list of authors
+        song_cclino -- CCLI number for this song
+        copyright -- copyright string
+        show_title -- 0: no show, 1: show
+        show_author_list -- 0: no show, 1: show
+        show_copyright -- 0: no show, 1: show
+        show_song_cclino -- 0: no show, 1: show
+        theme -- name of theme or blank
+        category_array -- list of user defined properties (hymn, gospel)
+        song_book -- name of originating book
+        song_number -- number of the song, related to a songbook
+        comments -- free comment
+        verse_order -- presentation order of the slides
+        lyrics -- text format
+        search_lyrics -- lowercase lyrics without punctuation
+        """
+        self.songid = songid
+        self._reset()
+
+    def _reset(self):
+        """Reset all song attributes"""
+        self.slideList = []
+        self.set_title(u'BlankSong')
+        self.author_list = None
+        self.song_cclino = ""
+        self.copyright = ""
+        self.show_author_list = 1
+        self.show_copyright = 1
+        self.show_song_cclino = 1
+        self.show_title = 1
+        self.theme = ""
+        self.category_array = None
+        self.song_book = ""
+        self.song_number = ""
+        self.comments = ""
+        self.verse_order = ""
+        self.set_lyrics(u'')
+        return
+
+    def set_songid(self, songid):
+        """Set the songid for the database"""
+        self.songid = songid
+        
+    def get_songid(self):
+        """Return the songid for the database"""
+        return self.songid
+    
+    def from_opensong_buffer(self,  xmlcontent):
+        """Initialize from buffer(string) of xml lines in opensong format"""
+        self._reset()
+        opensong = _OpenSong(xmlcontent)
+        if opensong.title != None:
+            self.set_title(opensong.title)
+        if opensong.copyright != None :
+            self.set_copyright(opensong.copyright)
+        if opensong.presentation != None:
+            self.set_verse_order(opensong.presentation)
+        if opensong.ccli != None:
+            self.set_song_cclino(opensong.ccli)
+        self.set_author_list(opensong.get_author_list())
+        self.set_category_array(opensong.get_category_array())
+        self.set_lyrics(opensong.get_lyrics())
+
+    def from_opensong_file(self,  xmlfilename):
+        """Initialize from file containing xml
+
+        xmlfilename -- path to xml file
+        """
+        lst = []
+        f = open(xmlfilename,  'r')
+        for line in f :
+            lst.append(line)
+        f.close()
+        xml = "".join(lst)
+        self.from_opensong_buffer(xml)
+
+    def _remove_punctuation(self,  title):
+        """Remove the puntuation chars from title
+
+        chars are: .,:;!?&%#/\@`$'|"^~*-
+        """
+        punctuation = ".,:;!?&%#'\"/\\@`$|^~*-"
+        s = title
+        for c in punctuation :
+            s = s.replace(c,  '')
+        return s
+
+    def set_title(self, title):
+        """Set the song title
+
+        title (string)
+        raises SongTitleError if the title is empty
+        raises SongTitleError if the seach_title is empty
+        """
+        self.title = title.strip()
+        self.search_title = self._remove_punctuation(title).strip()
+        if len(self.title) < 1 :
+            raise SongTitleError(u'The title is empty')
+        if len(self.search_title) < 1 :
+            raise SongTitleError(u'The searchable title is empty')
+
+    def get_title(self):
+        """Return title value"""
+        return self.title
+
+    def get_search_title(self):
+        """Return search_title"""
+        return self.search_title
+
+    def from_ccli_text_buffer(self, textList):
+        """Create song from a list of texts (strings) - CCLI text format expected
+
+        textList (list of strings) -- the song
+        """
+        self._reset()
+        # extract the following fields
+        # - name
+        # - author
+        # - CCLI no
+        sName = ""
+        sAuthor = ""
+        sCopyright = ""
+        sCcli = ""
+        lastpart = 0
+        n = 0
+        metMisc = False
+        lyrics = []
+        for l in textList :
+            n += 1
+            if lastpart > 0 :
+                lastpart += 1
+                if lastpart == 2 :
+                    sCopyright = l[1:].strip()
+                if lastpart == 3 :
+                    sAuthor = l
+            elif l.startswith(u'CCLI Song') :
+                sCcli = l[13:].strip()
+                lastpart = 1
+            else :
+                if metMisc :
+                    metMisc = False
+                    if l.upper().startswith(u'(BRIDGE)') :
+                        lyrics.append(u'# Bridge')
+                    # otherwise unknown misc keyword
+                elif l.startswith(u'Misc') :
+                    metMisc = True
+                elif l.startswith(u'Verse') or l.startswith(u'Chorus'):
+                    lyrics.append(u'# %s"%l)
+                else :
+                    # should we remove multiple blank lines?
+                    if n == 1 :
+                        sName = l
+                    else :
+                        lyrics.append(l)
+        # split on known separators
+        lst = sAuthor.split(u'/')
+        if len(lst) < 2:
+            lst = sAuthor.split(u'|')
+        author_list = ", u'.join(lst)
+        self.set_title(sName)
+        self.set_author_list(author_list)
+        self.set_copyright(sCopyright)
+        self.set_song_cclino(sCcli)
+        self.set_lyrics(lyrics)
+
+    def from_ccli_text_file(self,  textFileName):
+        """Create song from a list of texts read from given file
+
+        textFileName -- path to text file
+        """
+        lines = []
+        f = open(textFileName,  'r')
+        for orgline in f:
+            lines.append(orgline.rstrip())
+        f.close()
+        self.from_ccli_text_buffer(lines)
+
+    def _assure_string(self, s):
+        """Force a string is returned"""
+        if s == None :
+            r = ""
+        else :
+            r = unicode(s)
+        return r
+
+    def _split_to_list(self, aString):
+        """Split a string into a list - comma separated"""
+        res = []
+        if aString != None :
+            lst = aString.split(u',')
+            for l in lst :
+                # remove whitespace
+                res.append(l.strip())
+        return res
+
+    def _list_to_string(self, strOrList):
+        """Force a possibly list into a string"""
+        if type(strOrList) == StringType :
+            lst = self._split_to_list(strOrList)
+        elif type(strOrList) == ListType :
+            lst = strOrList
+        elif type(strOrList) == NoneType :
+            lst = []
+        else :
+            raise SongTypeError(u'Variable not String or List')
+        s = ", u'.join(lst)
+        return s
+
+    def get_copyright(self):
+        """Return copyright info string"""
+        return self._assure_string(self.copyright)
+
+    def set_copyright(self,  copyright):
+        """Set the copyright string"""
+        self.copyright = copyright
+
+    def get_song_cclino(self):
+        """Return the songCclino"""
+        return self._assure_string(self.song_cclino)
+
+    def set_song_cclino(self,  song_cclino):
+        """Set the song_cclino"""
+        self.song_cclino = song_cclino
+
+    def get_theme(self):
+        """Return the theme name for the song"""
+        return self._assure_string(self.theme)
+
+    def set_theme(self,  theme):
+        """Set the theme name (string)"""
+        self.theme = theme
+
+    def get_song_book(self):
+        """Return the song_book (string)"""
+        return self._assure_string(self.song_book)
+
+    def set_song_book(self,  song_book):
+        """Set the song_book (string)"""
+        self.song_book = song_book
+
+    def get_song_number(self):
+        """Return the song_number (string)"""
+        return self._assure_string(self.song_number)
+
+    def set_song_number(self,  song_number):
+        """Set the song_number (string)"""
+        self.song_number = song_number
+
+    def get_comments(self):
+        """Return the comments (string)"""
+        return self._assure_string(self.comments)
+
+    def set_comments(self,  comments):
+        """Set the comments (string)"""
+        self.comments = comments
+
+    def get_verse_order(self):
+        """Get the verseOrder (string) - preferably space delimited"""
+        return self._assure_string(self.verse_order)
+
+    def set_verse_order(self,  verse_order):
+        """Set the verse order (string) - space delimited"""
+        self.verse_order = verse_order
+
+    def get_author_list(self,  asOneString = True):
+        """Return the list of authors as a string
+
+        asOneString
+        True -- string:
+          "John Newton, A Parker"
+        False -- list of strings
+          ["John Newton", u'A Parker"]
+        """
+        if asOneString :
+            res = self._assure_string(self.author_list)
+        else :
+            res = self._split_to_list(self.author_list)
+        return res
+
+    def set_author_list(self,  author_list):
+        """Set the author_list
+
+        author_list -- a string or list of strings
+        """
+        if author_list == None :
+            self.author_list = None
+        else :
+            self.author_list = self._list_to_string(author_list)
+
+    def get_category_array(self,  asOneString = True):
+        """Return the list of categories as a string
+
+        asOneString
+        True -- string:
+          "Hymn, Gospel"
+        False -- list of strings
+          ["Hymn", u'Gospel"]
+        """
+        if asOneString :
+            res = self._assure_string(self.category_array)
+        else :
+            res = self._split_to_list(self.category_array)
+        return res
+
+    def set_category_array(self,  category_array):
+        """Set the category_array
+
+        category_array -- a string or list of strings
+        """
+        if category_array == None :
+            self.category_array = None
+        else :
+            self.category_array = self._list_to_string(category_array)
+
+    def get_show_title(self):
+        """Return the show_title flag (bool)"""
+        return self.show_title
+
+    def set_show_title(self,  show_title):
+        """Set the show_title flag (bool)"""
+        self.show_title = show_title
+
+    def get_show_author_list(self):
+        """Return the show_author_list flag"""
+        return self.show_author_list
+
+    def set_show_author_list(self,  show_author_list):
+        """Set the show_author_list flag (bool)"""
+        self.show_author_list = show_author_list
+
+    def get_show_copyright(self):
+        """Return the show_copyright flag"""
+        return self.show_copyright
+
+    def set_show_copyright(self, show_copyright):
+        """Set the show_copyright flag (bool)"""
+        self.show_copyright = show_copyright
+
+    def get_show_song_cclino(self):
+        """Return the showSongCclino (string)"""
+        return self.show_song_cclino
+
+    def set_show_song_cclino(self,  show_song_cclino):
+        """Set the show_song_cclino flag (bool)"""
+        self.show_song_cclino = show_song_cclino
+
+    def get_lyrics(self):
+        """Return the lyrics as a list of strings
+
+        this will return all the strings in the song
+        """
+        return self.lyrics
+
+    def set_lyrics(self,  lyrics):
+        """Set the lyrics as a list of strings"""
+        self.lyrics = lyrics
+        self._parse_lyrics()
+
+    def _parse_lyrics(self):
+        """Parse lyrics into the slidelist"""
+        # TODO: check font formatting
+        self.slideList = []
+        tmpSlide = []
+        metContent = False
+        for l in self.lyrics :
+            if len(l) > 0 :
+                metContent = True
+                tmpSlide.append(l)
+            else :
+                if metContent :
+                    metContent = False
+                    self.slideList.append(tmpSlide)
+                    tmpSlide = []
+        #
+        if len(tmpSlide) > 0:
+            self.slideList.append(tmpSlide)
+
+    def get_number_of_slides(self):
+        """Return the number of slides in the song (int)"""
+        numOfSlides = len(self.slideList)
+        return numOfSlides
+
+    def get_preview_slide(self,  slideNumber):
+        """Return the preview text for specified slide number
+
+        slideNumber -- 0: all slides, 1..n : specific slide
+        a list of strings are returned
+        """
+        num = len(self.slideList)
+        if num < 1 :
+            raise SongSlideError(u'No slides in this song')
+        elif slideNumber > num :
+            raise SongSlideError(u'Slide number too high')
+        if slideNumber > 0 :
+            # return this slide
+            res = self.slideList[slideNumber-1]
+            # find theme in this slide
+        else :
+            res = []
+            for i in range(num):
+                if i > 0 :
+                    res.append(u'')
+                res.extend()
+        # remove formattingincluding themes
+        return res
+
+    def get_render_slide(self,  slideNumber):
+        """Return the slide to be rendered including the additional
+        properties
+
+        slideNumber -- 1 .. numberOfSlides
+        Returns a list as:
+        [theme (string),
+         title (string),
+         authorlist (string),
+         copyright (string),
+         cclino (string),
+         lyric-part as a list of strings]
+        """
+        num = len(self.slideList)
+        if num < 1 :
+            raise SongSlideError(u'No slides in this song')
+        elif slideNumber > num :
+            raise SongSlideError(u'Slide number too high')
+        res = []
+        if self.show_title :
+            title = self.get_title()
+        else :
+            title = ""
+        if self.show_author_list :
+            author = self.get_author_list(True)
+        else :
+            author = ""
+        if self.show_copyright :
+            cpright = self.get_copyright()
+        else :
+            cpright = ""
+        if self.show_song_cclino :
+            ccli = self.get_song_cclino()
+        else :
+            ccli = ""
+        theme = self.get_theme()
+        # examine the slide for a theme
+        res.append(theme)
+        res.append(title)
+        res.append(author)
+        res.append(cpright)
+        res.append(ccli)
+        # append the correct slide
+        return res
+
+__all__ = ['SongException', 'SongTitleError', 'SongSlideError', 'SongTypeError',
+           'SongFeatureError', 'Song']
\ No newline at end of file

=== modified file 'openlp/plugins/songs/lib/tables.py'
--- openlp/plugins/songs/lib/tables.py	2009-06-13 16:15:55 +0000
+++ openlp/plugins/songs/lib/tables.py	2009-06-16 18:21:24 +0000
@@ -22,50 +22,50 @@
 from openlp.plugins.songs.lib.meta import metadata
 
 # Definition of the "authors" table
-authors_table = Table('authors', metadata,
-    Column('id', types.Integer,  primary_key=True),
-    Column('first_name', types.Unicode(128)),
-    Column('last_name', types.Unicode(128)),
-    Column('display_name', types.Unicode(255), nullable=False)
+authors_table = Table(u'authors', metadata,
+    Column(u'id', types.Integer,  primary_key=True),
+    Column(u'first_name', types.Unicode(128)),
+    Column(u'last_name', types.Unicode(128)),
+    Column(u'display_name', types.Unicode(255), nullable=False)
 )
 
 # Definition of the "song_books" table
-song_books_table = Table('song_books', metadata,
-    Column('id', types.Integer,  primary_key=True),
-    Column('name', types.Unicode(128), nullable=False),
-    Column('publisher', types.Unicode(128))
+song_books_table = Table(u'song_books', metadata,
+    Column(u'id', types.Integer,  primary_key=True),
+    Column(u'name', types.Unicode(128), nullable=False),
+    Column(u'publisher', types.Unicode(128))
 )
 
 # Definition of the "songs" table
-songs_table = Table('songs', metadata,
-    Column('id', types.Integer, primary_key=True),
-    Column('song_book_id', types.Integer, ForeignKey('song_books.id'), default=0),
-    Column('title', types.Unicode(255), nullable=False),
-    Column('lyrics', types.UnicodeText, nullable=False),
-    Column('verse_order', types.Unicode(128)),
-    Column('copyright', types.Unicode(255)),
-    Column('comments', types.UnicodeText),
-    Column('ccli_number', types.Unicode(64)),
-    Column('song_number', types.Unicode(64)),
-    Column('theme_name', types.Unicode(128)),
-    Column('search_title', types.Unicode(255), index=True, nullable=False),
-    Column('search_lyrics', types.UnicodeText, index=True, nullable=False)
+songs_table = Table(u'songs', metadata,
+    Column(u'id', types.Integer, primary_key=True),
+    Column(u'song_book_id', types.Integer, ForeignKey(u'song_books.id'), default=0),
+    Column(u'title', types.Unicode(255), nullable=False),
+    Column(u'lyrics', types.UnicodeText, nullable=False),
+    Column(u'verse_order', types.Unicode(128)),
+    Column(u'copyright', types.Unicode(255)),
+    Column(u'comments', types.UnicodeText),
+    Column(u'ccli_number', types.Unicode(64)),
+    Column(u'song_number', types.Unicode(64)),
+    Column(u'theme_name', types.Unicode(128)),
+    Column(u'search_title', types.Unicode(255), index=True, nullable=False),
+    Column(u'search_lyrics', types.UnicodeText, index=True, nullable=False)
 )
 
 # Definition of the "topics" table
-topics_table = Table('topics', metadata,
-    Column('id', types.Integer,  primary_key=True),
-    Column('name', types.Unicode(128), nullable=False)
+topics_table = Table(u'topics', metadata,
+    Column(u'id', types.Integer,  primary_key=True),
+    Column(u'name', types.Unicode(128), nullable=False)
 )
 
 # Definition of the "authors_songs" table
-authors_songs_table = Table('authors_songs', metadata,
-    Column('author_id', types.Integer, ForeignKey('authors.id'), primary_key=True),
-    Column('song_id', types.Integer, ForeignKey('songs.id'), primary_key=True)
+authors_songs_table = Table(u'authors_songs', metadata,
+    Column(u'author_id', types.Integer, ForeignKey(u'authors.id'), primary_key=True),
+    Column(u'song_id', types.Integer, ForeignKey(u'songs.id'), primary_key=True)
 )
 
 # Definition of the "songs_topics" table
-songs_topics_table = Table('songs_topics', metadata,
-    Column('song_id', types.Integer, ForeignKey('songs.id'), primary_key=True),
-    Column('topic_id', types.Integer, ForeignKey('topics.id'), primary_key=True)
-)
+songs_topics_table = Table(u'songs_topics', metadata,
+    Column(u'song_id', types.Integer, ForeignKey(u'songs.id'), primary_key=True),
+    Column(u'topic_id', types.Integer, ForeignKey(u'topics.id'), primary_key=True)
+)
\ No newline at end of file

=== modified file 'openlp/plugins/songs/songsplugin.py'
--- openlp/plugins/songs/songsplugin.py	2009-06-14 07:25:39 +0000
+++ openlp/plugins/songs/songsplugin.py	2009-06-16 18:21:24 +0000
@@ -43,7 +43,7 @@
         self.opensong_export_form = OpenSongExportForm()
         # Create the plugin icon
         self.icon = QtGui.QIcon()
-        self.icon.addPixmap(QtGui.QPixmap(':/media/media_song.png'),
+        self.icon.addPixmap(QtGui.QPixmap(u':/media/media_song.png'),
             QtGui.QIcon.Normal, QtGui.QIcon.Off)
 
     def get_media_manager_item(self):
@@ -136,4 +136,4 @@
             self.media_item.onSongLiveClick()
         if event.event_type == EventType.LoadSongList :
             log.debug(u'Load Load Song List Item received')
-            self.media_item.displayResults(self.songmanager.get_songs())
+            self.media_item.displayResults(self.songmanager.get_songs())
\ No newline at end of file

=== modified file 'openlp/plugins/songs/test/test_song_basic.py'
--- openlp/plugins/songs/test/test_song_basic.py	2009-01-06 20:10:03 +0000
+++ openlp/plugins/songs/test/test_song_basic.py	2009-06-16 18:21:24 +0000
@@ -1,174 +1,174 @@
-# -*- coding: utf-8 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
-
-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
-"""
-
-import py.test
-import os
-import sys
-
-__ThisDir__ = os.path.dirname(__file__)
-if "" == __ThisDir__ :
-    __ThisDir__ = os.path.abspath(".")
-
-sys.path.append(os.path.abspath("%s/../../../.."%__ThisDir__))
-
-from openlp.plugins.songs.lib.songxml import *
-
-class Test_Basic(object):
-    """Class for first initialization check
-    set-get functions
-    """
-
-    def test_Creation(self):
-        """Init: Create as empty"""
-        s = Song()
-        assert(True)
-
-    def test_Title1(self):
-        """Set an empty title - raises an exception"""
-        s = Song()
-        py.test.raises(SongTitleError, s.set_title, "")
-
-    def test_Title2(self):
-        """Set a normal title"""
-        s = Song()
-        t = "A normal title"
-        s.set_title(t)
-        assert(s.get_title() ==  t)
-        assert(s.get_search_title() ==  t)
-
-    def test_Title3(self):
-        """Set a titel with punctuation 1"""
-        s = Song()
-        t1 = "Hey! Come on, ya programmers*"
-        t2 = "Hey Come on ya programmers"
-        s.set_title(t1)
-        assert(s.get_title() ==  t1)
-        assert(s.get_search_title() ==  t2)
-
-    def test_Title4(self):
-        """Set a titel with punctuation 2"""
-        s = Song()
-        t1 = "??#Hey! Come on, ya programmers*"
-        t2 = "Hey Come on ya programmers"
-        s.set_title(t1)
-        assert(s.get_title() ==  t1)
-        assert(s.get_search_title() ==  t2)
-
-    def test_Title5(self):
-        """Set a title, where searchable title becomes empty - raises an exception"""
-        s = Song()
-        py.test.raises(SongTitleError, s.set_title, ",*")
-
-    def test_Copyright(self):
-        """Set a copyright string"""
-        s = Song()
-        assert(s.get_copyright() == "")
-        s.set_copyright("A B Car")
-        assert(s.get_copyright() == "A B Car")
-
-    def test_SongCclino(self):
-        """Set a SongCcliNo"""
-        s = Song()
-        assert(s.get_song_cclino() == "")
-        s.set_song_cclino(12345)
-        assert(s.get_song_cclino() == "12345")
-
-    def test_SongBook(self):
-        """Set a songbook value"""
-        s = Song()
-        assert(s.get_song_book() == "")
-        s.set_song_book("Hymns")
-        assert(s.get_song_book() == "Hymns")
-
-    def test_SongNumber(self):
-        """Set a song number"""
-        s = Song()
-        assert(s.get_song_number() == "")
-        s.set_song_number(278)
-        assert(s.get_song_number() == "278")
-
-    def test_Theme(self):
-        """Set a theme name"""
-        s = Song()
-        assert(s.get_theme() == "")
-        s.set_theme("Red")
-        assert(s.get_theme() == "Red")
-
-    def test_VerseOrder(self):
-        """Set a verse order"""
-        s = Song()
-        assert(s.get_verse_order() == "")
-        s.set_verse_order("V1 C V2")
-        assert(s.get_verse_order() == "V1 C V2")
-
-    def test_Comments(self):
-        """Set a comment"""
-        s = Song()
-        assert(s.get_comments() == "")
-        s.set_comments("a comment")
-        assert(s.get_comments() == "a comment")
-
-    def test_AuthorList(self):
-        """Set author lists"""
-        s = Song()
-        assert(s.get_author_list(True) == "")
-        assert(s.get_author_list(False) == [])
-        t1 = "John Newton"
-        s.set_author_list(t1)
-        assert(s.get_author_list(True) == t1)
-        assert(s.get_author_list(False) == [t1])
-        s.set_author_list("  Peter Done  , John Newton")
-        assert(s.get_author_list(True)== "Peter Done, John Newton")
-        assert(s.get_author_list(False) == ["Peter Done", "John Newton"])
-        s.set_author_list(None)
-        assert(s.get_author_list(True) == "")
-        assert(s.get_author_list(False) == [])
-        s.set_author_list("")
-        assert(s.get_author_list(True) == "")
-        assert(s.get_author_list(False) == [""])
-        s.set_author_list([])
-        assert(s.get_author_list(True) == "")
-        assert(s.get_author_list(False) == [""])
-
-    def test_CategoryArray(self):
-        """Set categories"""
-        s = Song()
-        assert(s.get_category_array(True) == "")
-        assert(s.get_category_array(False) == [])
-        t1 = "Gospel"
-        s.set_category_array(t1)
-        assert(s.get_category_array(True) == t1)
-        assert(s.get_category_array(False) == [t1])
-        s.set_category_array(" Gospel,  Hymns  ")
-        assert(s.get_category_array(True) == "Gospel, Hymns")
-        assert(s.get_category_array(False) == ["Gospel", "Hymns"])
-        s.set_category_array(None)
-        assert(s.get_category_array(True) == "")
-        assert(s.get_category_array(False) == [])
-        s.set_category_array("")
-        assert(s.get_category_array(True) == "")
-        assert(s.get_category_array(False) == [""])
-        s.set_category_array([])
-        assert(s.get_category_array(True) == "")
-        assert(s.get_category_array(False) == [""])
-
-if '__main__' == __name__:
-    r = Test_Basic()
-    r.test_asString()
+# -*- coding: utf-8 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
+
+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
+"""
+
+import py.test
+import os
+import sys
+
+__ThisDir__ = os.path.dirname(__file__)
+if "" == __ThisDir__ :
+    __ThisDir__ = os.path.abspath(u'.')
+
+sys.path.append(os.path.abspath(u'%s/../../../.."%__ThisDir__))
+
+from openlp.plugins.songs.lib.songxml import *
+
+class Test_Basic(object):
+    """Class for first initialization check
+    set-get functions
+    """
+
+    def test_Creation(self):
+        """Init: Create as empty"""
+        s = Song()
+        assert(True)
+
+    def test_Title1(self):
+        """Set an empty title - raises an exception"""
+        s = Song()
+        py.test.raises(SongTitleError, s.set_title, "')
+
+    def test_Title2(self):
+        """Set a normal title"""
+        s = Song()
+        t = "A normal title"
+        s.set_title(t)
+        assert(s.get_title() ==  t)
+        assert(s.get_search_title() ==  t)
+
+    def test_Title3(self):
+        """Set a titel with punctuation 1"""
+        s = Song()
+        t1 = "Hey! Come on, ya programmers*"
+        t2 = "Hey Come on ya programmers"
+        s.set_title(t1)
+        assert(s.get_title() ==  t1)
+        assert(s.get_search_title() ==  t2)
+
+    def test_Title4(self):
+        """Set a titel with punctuation 2"""
+        s = Song()
+        t1 = "??#Hey! Come on, ya programmers*"
+        t2 = "Hey Come on ya programmers"
+        s.set_title(t1)
+        assert(s.get_title() ==  t1)
+        assert(s.get_search_title() ==  t2)
+
+    def test_Title5(self):
+        """Set a title, where searchable title becomes empty - raises an exception"""
+        s = Song()
+        py.test.raises(SongTitleError, s.set_title, ",*')
+
+    def test_Copyright(self):
+        """Set a copyright string"""
+        s = Song()
+        assert(s.get_copyright() == "')
+        s.set_copyright(u'A B Car')
+        assert(s.get_copyright() == "A B Car')
+
+    def test_SongCclino(self):
+        """Set a SongCcliNo"""
+        s = Song()
+        assert(s.get_song_cclino() == "')
+        s.set_song_cclino(12345)
+        assert(s.get_song_cclino() == "12345')
+
+    def test_SongBook(self):
+        """Set a songbook value"""
+        s = Song()
+        assert(s.get_song_book() == "')
+        s.set_song_book(u'Hymns')
+        assert(s.get_song_book() == "Hymns')
+
+    def test_SongNumber(self):
+        """Set a song number"""
+        s = Song()
+        assert(s.get_song_number() == "')
+        s.set_song_number(278)
+        assert(s.get_song_number() == "278')
+
+    def test_Theme(self):
+        """Set a theme name"""
+        s = Song()
+        assert(s.get_theme() == "')
+        s.set_theme(u'Red')
+        assert(s.get_theme() == "Red')
+
+    def test_VerseOrder(self):
+        """Set a verse order"""
+        s = Song()
+        assert(s.get_verse_order() == "')
+        s.set_verse_order(u'V1 C V2')
+        assert(s.get_verse_order() == "V1 C V2')
+
+    def test_Comments(self):
+        """Set a comment"""
+        s = Song()
+        assert(s.get_comments() == "')
+        s.set_comments(u'a comment')
+        assert(s.get_comments() == "a comment')
+
+    def test_AuthorList(self):
+        """Set author lists"""
+        s = Song()
+        assert(s.get_author_list(True) == "')
+        assert(s.get_author_list(False) == [])
+        t1 = "John Newton"
+        s.set_author_list(t1)
+        assert(s.get_author_list(True) == t1)
+        assert(s.get_author_list(False) == [t1])
+        s.set_author_list(u'  Peter Done  , John Newton')
+        assert(s.get_author_list(True)== "Peter Done, John Newton')
+        assert(s.get_author_list(False) == ["Peter Done", u'John Newton"])
+        s.set_author_list(None)
+        assert(s.get_author_list(True) == "')
+        assert(s.get_author_list(False) == [])
+        s.set_author_list(u'')
+        assert(s.get_author_list(True) == "')
+        assert(s.get_author_list(False) == [""])
+        s.set_author_list([])
+        assert(s.get_author_list(True) == "')
+        assert(s.get_author_list(False) == [""])
+
+    def test_CategoryArray(self):
+        """Set categories"""
+        s = Song()
+        assert(s.get_category_array(True) == "')
+        assert(s.get_category_array(False) == [])
+        t1 = "Gospel"
+        s.set_category_array(t1)
+        assert(s.get_category_array(True) == t1)
+        assert(s.get_category_array(False) == [t1])
+        s.set_category_array(u' Gospel,  Hymns  ')
+        assert(s.get_category_array(True) == "Gospel, Hymns')
+        assert(s.get_category_array(False) == ["Gospel", u'Hymns"])
+        s.set_category_array(None)
+        assert(s.get_category_array(True) == "')
+        assert(s.get_category_array(False) == [])
+        s.set_category_array(u'')
+        assert(s.get_category_array(True) == "')
+        assert(s.get_category_array(False) == [""])
+        s.set_category_array([])
+        assert(s.get_category_array(True) == "')
+        assert(s.get_category_array(False) == [""])
+
+if '__main__' == __name__:
+    r = Test_Basic()
+    r.test_asString()
\ No newline at end of file

=== modified file 'openlp/plugins/songs/test/test_song_opensong.py'
--- openlp/plugins/songs/test/test_song_opensong.py	2009-01-06 20:10:03 +0000
+++ openlp/plugins/songs/test/test_song_opensong.py	2009-06-16 18:21:24 +0000
@@ -1,187 +1,186 @@
-# -*- coding:iso-8859-1 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
-
-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
-"""
-import os
-import sys
-
-__ThisDir__ = os.path.dirname(__file__)
-if "" == __ThisDir__ :
-    __ThisDir__ = os.path.abspath(".")
-
-sys.path.append(os.path.abspath("%s/../../../.."%__ThisDir__))
-
-from openlp.plugins.songs.lib.songxml import *
-
-
-_sample1 = \
-'''<?xml version="1.0" encoding="UTF-8"?>
-<song>
-  <title></title>
-  <author></author>
-  <copyright></copyright>
-  <presentation></presentation>
-  <ccli></ccli>
-  <theme></theme>
-  <lyrics>[V1]
-. chord line 1
- verse 1 line 1
-. chord line 2
- verse 1 line 2
-
-[V2]
- verse 2 line 1
- verse 2 line 2
-
-[V3]
- verse 3 line 1
- verse 3 line 2
-
-[C]
-. chorus chord line 1
- chorus line 1
-. chorus chord line 2
- chorus line 2</lyrics>
-</song>
-'''
-
-_sample2 = \
-'''<?xml version="1.0" encoding="UTF-8"?>
-<song>
-  <title></title>
-  <author></author>
-  <copyright></copyright>
-  <presentation></presentation>
-  <ccli></ccli>
-  <theme></theme>
-  <lyrics>[V]
-1verse 1 line 1
-2verse 2 line 1
-3verse 3 line 1
-1verse 1 line 2
-2verse 2 line 2
-3verse 3 line 2
-
-[C]
- chorus line 1
- chorus line 2</lyrics>
-</song>
-'''
-
-_sample3 = \
-'''<?xml version="1.0" encoding="UTF-8"?>
-<song>
-  <title></title>
-  <author></author>
-  <copyright></copyright>
-  <presentation></presentation>
-  <ccli></ccli>
-  <theme></theme>
-  <lyrics>[V]
-1verse 1 line 1
-2verse 2 line 1
-3verse 3 line 1
-1verse 1 line 2
-2verse 2 line 2
-3verse 3 line 2
-
-[C]
- chorus line 1
- chorus line 2
-
-[P]
- pre-chorus line 1
- pre-chorus line 2
- pre-chorus line 3
- 
-[B]
- bridge line 1
- bridge line 2
-</lyrics>
-</song>
-'''
-
-class Test_OpenSong(object):
-    """Test cases for converting from OpenSong xml format to Song"""
-    
-    def test_sample1(self):
-        """OpenSong: handwritten sample1"""
-        s = Song()
-        s.from_opensong_buffer(_sample1)
-        l = s.get_lyrics()
-        assert(len(l) == (4*3+3))
-        assert(s.get_number_of_slides() == 4)
-        
-    def test_sample2(self):
-        """OpenSong: handwritten sample2 - with verses and chorus"""
-        s = Song()
-        s.from_opensong_buffer(_sample2)
-        l = s.get_lyrics()
-        assert(len(l) == (4*3+3))
-        assert(s.get_number_of_slides() == 4)
-        
-    def test_sample3(self):
-        """OpenSong: handwritten sample3 - with verses, chorus, bridge and pre-chorus"""
-        s = Song()
-        s.from_opensong_buffer(_sample3)
-        l = s.get_lyrics()
-        assert(len(l) == (4*3+4+5+4))
-        assert(s.get_number_of_slides() == 6)
-        
-    def test_file1(self):
-        """OpenSong: parse Amazing Grace"""
-        global __ThisDir__
-        s = Song()
-        s.from_opensong_file("%s/data_opensong/Amazing Grace"%(__ThisDir__))
-        assert(s.get_title() == "Amazing Grace")
-        assert(s.get_copyright() == "1982 Jubilate Hymns Limited")
-        assert(s.get_song_cclino() == "1037882")
-        assert(s.get_category_array(True) == "God: Attributes")
-        assert(s.get_author_list(True) == "John Newton")
-        assert(s.get_verse_order() == "")
-        assert(s.get_number_of_slides() == 4)
-        
-    def test_file2(self):
-        """OpenSong: parse The Solid Rock"""
-        s = Song()
-        s.from_opensong_file("%s/data_opensong/The Solid Rock"%(__ThisDir__))
-        assert(s.get_title() == "The Solid Rock")
-        assert(s.get_copyright() == "Public Domain")
-        assert(s.get_song_cclino() == "101740")
-        assert(s.get_category_array(True) == "Christ: Victory, Fruit: Peace/Comfort")
-        assert(s.get_author_list(True) == "Edward Mote, John B. Dykes")
-        assert(s.get_verse_order() == "V1 C V2 C V3 C V4 C")
-        assert(s.get_number_of_slides() == 5)
-        
-    def test_file3(self):
-        """OpenSong: parse 'På en fjern ensom høj' (danish)"""
-        #FIXME: problem with XML convert and danish characters
-        s = Song()
-        s.from_opensong_file("%s/data_opensong/På en fjern ensom høj"%(__ThisDir__))
-        assert(s.get_title() == u"På en fjern ensom høj")
-        assert(s.get_copyright() == "")
-        assert(s.get_song_cclino() == "")
-        assert(s.get_category_array(True) == "")
-        assert(s.get_author_list(True) == "")
-        assert(s.get_verse_order() == "V1 C1 V2 C2 V3 C3 V4 C4")
-        assert(s.get_number_of_slides() == 8)
-        
-if '__main__' == __name__:
-    r = Test_OpenSong()
-    r.test_file3()
-
+# -*- coding:iso-8859-1 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
+
+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
+"""
+import os
+import sys
+
+__ThisDir__ = os.path.dirname(__file__)
+if "" == __ThisDir__ :
+    __ThisDir__ = os.path.abspath(u'.')
+
+sys.path.append(os.path.abspath(u'%s/../../../.."%__ThisDir__))
+
+from openlp.plugins.songs.lib.songxml import *
+
+
+_sample1 = \
+'''<?xml version="1.0" encoding="UTF-8"?>
+<song>
+  <title></title>
+  <author></author>
+  <copyright></copyright>
+  <presentation></presentation>
+  <ccli></ccli>
+  <theme></theme>
+  <lyrics>[V1]
+. chord line 1
+ verse 1 line 1
+. chord line 2
+ verse 1 line 2
+
+[V2]
+ verse 2 line 1
+ verse 2 line 2
+
+[V3]
+ verse 3 line 1
+ verse 3 line 2
+
+[C]
+. chorus chord line 1
+ chorus line 1
+. chorus chord line 2
+ chorus line 2</lyrics>
+</song>
+'''
+
+_sample2 = \
+'''<?xml version="1.0" encoding="UTF-8"?>
+<song>
+  <title></title>
+  <author></author>
+  <copyright></copyright>
+  <presentation></presentation>
+  <ccli></ccli>
+  <theme></theme>
+  <lyrics>[V]
+1verse 1 line 1
+2verse 2 line 1
+3verse 3 line 1
+1verse 1 line 2
+2verse 2 line 2
+3verse 3 line 2
+
+[C]
+ chorus line 1
+ chorus line 2</lyrics>
+</song>
+'''
+
+_sample3 = \
+'''<?xml version="1.0" encoding="UTF-8"?>
+<song>
+  <title></title>
+  <author></author>
+  <copyright></copyright>
+  <presentation></presentation>
+  <ccli></ccli>
+  <theme></theme>
+  <lyrics>[V]
+1verse 1 line 1
+2verse 2 line 1
+3verse 3 line 1
+1verse 1 line 2
+2verse 2 line 2
+3verse 3 line 2
+
+[C]
+ chorus line 1
+ chorus line 2
+
+[P]
+ pre-chorus line 1
+ pre-chorus line 2
+ pre-chorus line 3
+ 
+[B]
+ bridge line 1
+ bridge line 2
+</lyrics>
+</song>
+'''
+
+class Test_OpenSong(object):
+    """Test cases for converting from OpenSong xml format to Song"""
+    
+    def test_sample1(self):
+        """OpenSong: handwritten sample1"""
+        s = Song()
+        s.from_opensong_buffer(_sample1)
+        l = s.get_lyrics()
+        assert(len(l) == (4*3+3))
+        assert(s.get_number_of_slides() == 4)
+        
+    def test_sample2(self):
+        """OpenSong: handwritten sample2 - with verses and chorus"""
+        s = Song()
+        s.from_opensong_buffer(_sample2)
+        l = s.get_lyrics()
+        assert(len(l) == (4*3+3))
+        assert(s.get_number_of_slides() == 4)
+        
+    def test_sample3(self):
+        """OpenSong: handwritten sample3 - with verses, chorus, bridge and pre-chorus"""
+        s = Song()
+        s.from_opensong_buffer(_sample3)
+        l = s.get_lyrics()
+        assert(len(l) == (4*3+4+5+4))
+        assert(s.get_number_of_slides() == 6)
+        
+    def test_file1(self):
+        """OpenSong: parse Amazing Grace"""
+        global __ThisDir__
+        s = Song()
+        s.from_opensong_file(u'%s/data_opensong/Amazing Grace"%(__ThisDir__))
+        assert(s.get_title() == "Amazing Grace')
+        assert(s.get_copyright() == "1982 Jubilate Hymns Limited')
+        assert(s.get_song_cclino() == "1037882')
+        assert(s.get_category_array(True) == "God: Attributes')
+        assert(s.get_author_list(True) == "John Newton')
+        assert(s.get_verse_order() == "')
+        assert(s.get_number_of_slides() == 4)
+        
+    def test_file2(self):
+        """OpenSong: parse The Solid Rock"""
+        s = Song()
+        s.from_opensong_file(u'%s/data_opensong/The Solid Rock"%(__ThisDir__))
+        assert(s.get_title() == "The Solid Rock')
+        assert(s.get_copyright() == "Public Domain')
+        assert(s.get_song_cclino() == "101740')
+        assert(s.get_category_array(True) == "Christ: Victory, Fruit: Peace/Comfort')
+        assert(s.get_author_list(True) == "Edward Mote, John B. Dykes')
+        assert(s.get_verse_order() == "V1 C V2 C V3 C V4 C')
+        assert(s.get_number_of_slides() == 5)
+        
+    def test_file3(self):
+        """OpenSong: parse 'På en fjern ensom høj' (danish)"""
+        #FIXME: problem with XML convert and danish characters
+        s = Song()
+        s.from_opensong_file(u'%s/data_opensong/På en fjern ensom høj"%(__ThisDir__))
+        assert(s.get_title() == u"På en fjern ensom høj')
+        assert(s.get_copyright() == "')
+        assert(s.get_song_cclino() == "')
+        assert(s.get_category_array(True) == "')
+        assert(s.get_author_list(True) == "')
+        assert(s.get_verse_order() == "V1 C1 V2 C2 V3 C3 V4 C4')
+        assert(s.get_number_of_slides() == 8)
+        
+if '__main__' == __name__:
+    r = Test_OpenSong()
+    r.test_file3()
\ No newline at end of file

=== modified file 'openlp/plugins/songs/test/test_song_text.py'
--- openlp/plugins/songs/test/test_song_text.py	2009-01-06 20:10:03 +0000
+++ openlp/plugins/songs/test/test_song_text.py	2009-06-16 18:21:24 +0000
@@ -1,61 +1,60 @@
-# -*- coding:iso-8859-1 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
-
-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
-"""
-import os
-import sys
-
-__ThisDir__ = os.path.dirname(__file__)
-if "" == __ThisDir__ :
-    __ThisDir__ = os.path.abspath(".")
-
-sys.path.append(os.path.abspath("%s/../../../.."%__ThisDir__))
-
-from openlp.plugins.songs.lib.songxml import *
-
-class Test_Text(object):
-    """Test cases for converting from text format to Song"""
-    
-    def test_file1(self):
-        """OpenSong: parse CCLI example"""
-        global __ThisDir__
-        s = Song()
-        s.from_ccli_text_file("%s/data_text/CCLI example.txt"%(__ThisDir__))
-        assert(s.get_title() == "Song Title Here")
-        assert(s.get_author_list(True) == "Author, artist name")
-        assert(s.get_copyright() == "1996 Publisher Info")
-        assert(s.get_song_cclino() == "1234567")
-        assert(s.get_number_of_slides() == 4)
-        
-    def test_file2(self):
-        """OpenSong: parse PåEnFjern (danish)"""
-        global __ThisDir__
-        s = Song()
-        s.from_ccli_text_file("%s/data_text/PåEnFjern.txt"%(__ThisDir__))
-        assert(s.get_title() == "På en fjern ensom høj")
-        assert(s.get_author_list(True) == "Georg Bennard")
-        assert(s.get_copyright() == "")
-        assert(s.get_song_cclino() == "")
-        assert(s.get_number_of_slides() == 8)
-
-if '__main__' == __name__:
-    # for local debugging
-    r = Test_Text()
-    r.test_file1()
-    r.test_file2()
-
+# -*- coding:iso-8859-1 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
+
+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
+"""
+import os
+import sys
+
+__ThisDir__ = os.path.dirname(__file__)
+if "" == __ThisDir__ :
+    __ThisDir__ = os.path.abspath(u'.')
+
+sys.path.append(os.path.abspath(u'%s/../../../.."%__ThisDir__))
+
+from openlp.plugins.songs.lib.songxml import *
+
+class Test_Text(object):
+    """Test cases for converting from text format to Song"""
+    
+    def test_file1(self):
+        """OpenSong: parse CCLI example"""
+        global __ThisDir__
+        s = Song()
+        s.from_ccli_text_file(u'%s/data_text/CCLI example.txt"%(__ThisDir__))
+        assert(s.get_title() == "Song Title Here')
+        assert(s.get_author_list(True) == "Author, artist name')
+        assert(s.get_copyright() == "1996 Publisher Info')
+        assert(s.get_song_cclino() == "1234567')
+        assert(s.get_number_of_slides() == 4)
+        
+    def test_file2(self):
+        """OpenSong: parse PåEnFjern (danish)"""
+        global __ThisDir__
+        s = Song()
+        s.from_ccli_text_file(u'%s/data_text/PåEnFjern.txt"%(__ThisDir__))
+        assert(s.get_title() == "På en fjern ensom høj')
+        assert(s.get_author_list(True) == "Georg Bennard')
+        assert(s.get_copyright() == "')
+        assert(s.get_song_cclino() == "')
+        assert(s.get_number_of_slides() == 8)
+
+if '__main__' == __name__:
+    # for local debugging
+    r = Test_Text()
+    r.test_file1()
+    r.test_file2()
\ No newline at end of file

=== modified file 'openlp/plugins/songs/test/test_song_verse.py'
--- openlp/plugins/songs/test/test_song_verse.py	2009-01-06 20:10:03 +0000
+++ openlp/plugins/songs/test/test_song_verse.py	2009-06-16 18:21:24 +0000
@@ -1,152 +1,152 @@
-# -*- coding:iso-8859-1 -*-
-# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
-"""
-OpenLP - Open Source Lyrics Projection
-Copyright (c) 2008 Raoul Snyman
-Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
-
-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
-"""
-import py.test
-import os
-import sys
-
-__ThisDir__ = os.path.dirname(__file__)
-if "" == __ThisDir__ :
-    __ThisDir__ = os.path.abspath(".")
-
-sys.path.append(os.path.abspath("%s/../../../.."%__ThisDir__))
-
-from openlp.plugins.songs.lib.songxml import *
-
-class Test_Verse(object):
-    """Class for testing verses for preview and review"""
-    
-    def stdSong(self):
-        """Definition of a standard song"""
-        s = Song()
-        self.title = "A song"
-        self.author = "John Newton"
-        self.copyright = "Peter Hamil"
-        self.ccli = "123456"
-        s.set_lyrics(["# verse","a single line"])
-        s.set_title(self.title)
-        s.set_copyright(self.copyright)
-        s.set_author_list(self.author)
-        s.set_song_cclino(self.ccli)
-        return s
-    
-    def check_allfields(self, r, isblank = 0):
-        #[theme, title, author, cpright, ccli, lyrics]
-        if isblank == 1 :
-            assert(r[1] == "")
-        else :
-            assert(r[1] == self.title)
-        if isblank == 2 :
-            assert(r[2] == "")
-        else :
-            assert(r[2] == self.author)
-        if isblank == 3 :
-            assert(r[3] == "")
-        else :
-            assert(r[3] == self.copyright)
-        if isblank == 4 :
-            assert(r[4] == "")
-        else :
-            assert(r[4] == self.ccli)
-        
-    
-    def test_title_show_noshow(self):
-        """Test the show title flag"""
-        s = self.stdSong()
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-        s.set_show_title(False)
-        r = s.get_render_slide(1)
-        self.check_allfields(r, 1)
-        s.set_show_title(True)
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-    
-    def test_author_show_noshow(self):
-        """Test the show author flag"""
-        s = self.stdSong()
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-        s.set_show_author_list(False)
-        r = s.get_render_slide(1)
-        self.check_allfields(r, 2)
-        s.set_show_author_list(True)
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-    
-    def test_copyright_show_noshow(self):
-        """Test the show copyright flag"""
-        s = self.stdSong()
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-        s.set_show_copyright(False)
-        r = s.get_render_slide(1)
-        self.check_allfields(r, 3)
-        s.set_show_copyright(True)
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-    
-    def test_ccli_show_noshow(self):
-        """Test the show copyright flag"""
-        s = self.stdSong()
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-        s.set_show_song_cclino(False)
-        r = s.get_render_slide(1)
-        self.check_allfields(r, 4)
-        s.set_show_song_cclino(True)
-        r = s.get_render_slide(1)
-        self.check_allfields(r)
-        
-    def test_verse1(self):
-        """Test an empty verse list"""
-        s = Song()
-        s.set_lyrics([])
-        assert(s.get_number_of_slides() == 0)
-        
-    def test_verse2(self):
-        """Test a list with an empty string"""
-        s = Song()
-        s.set_lyrics([""])
-        assert(s.get_number_of_slides() == 0)
-        
-    def test_verse3a(self):
-        """Test a one liner song"""
-        s = Song()
-        s.set_lyrics(["Single verse"])
-        assert(s.get_number_of_slides() == 1)
-        
-    def test_verse3b(self):
-        """Test a one liner song"""
-        s = Song()
-        s.set_lyrics(["", "Single verse"])
-        assert(s.get_number_of_slides() == 1)
-        
-    def test_verse3c(self):
-        """Test a one liner song"""
-        s = Song()
-        s.set_lyrics(["", "Single verse", "", ""])
-        assert(s.get_number_of_slides() == 1)
-
-    def test_verse3d(self):
-        """Test a one liner song"""
-        s = Song()
-        s.set_lyrics(["", "# Verse", "", ""])
-        assert(s.get_number_of_slides() == 1)
+# -*- coding:iso-8859-1 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+"""
+OpenLP - Open Source Lyrics Projection
+Copyright (c) 2008 Raoul Snyman
+Portions copyright (c) 2008 Martin Thompson, Tim Bentley, Carsten Tinggaard
+
+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
+"""
+import py.test
+import os
+import sys
+
+__ThisDir__ = os.path.dirname(__file__)
+if "" == __ThisDir__ :
+    __ThisDir__ = os.path.abspath(u'.')
+
+sys.path.append(os.path.abspath(u'%s/../../../.."%__ThisDir__))
+
+from openlp.plugins.songs.lib.songxml import *
+
+class Test_Verse(object):
+    """Class for testing verses for preview and review"""
+    
+    def stdSong(self):
+        """Definition of a standard song"""
+        s = Song()
+        self.title = "A song"
+        self.author = "John Newton"
+        self.copyright = "Peter Hamil"
+        self.ccli = "123456"
+        s.set_lyrics(["# verse","a single line"])
+        s.set_title(self.title)
+        s.set_copyright(self.copyright)
+        s.set_author_list(self.author)
+        s.set_song_cclino(self.ccli)
+        return s
+    
+    def check_allfields(self, r, isblank = 0):
+        #[theme, title, author, cpright, ccli, lyrics]
+        if isblank == 1 :
+            assert(r[1] == "')
+        else :
+            assert(r[1] == self.title)
+        if isblank == 2 :
+            assert(r[2] == "')
+        else :
+            assert(r[2] == self.author)
+        if isblank == 3 :
+            assert(r[3] == "')
+        else :
+            assert(r[3] == self.copyright)
+        if isblank == 4 :
+            assert(r[4] == "')
+        else :
+            assert(r[4] == self.ccli)
+        
+    
+    def test_title_show_noshow(self):
+        """Test the show title flag"""
+        s = self.stdSong()
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+        s.set_show_title(False)
+        r = s.get_render_slide(1)
+        self.check_allfields(r, 1)
+        s.set_show_title(True)
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+    
+    def test_author_show_noshow(self):
+        """Test the show author flag"""
+        s = self.stdSong()
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+        s.set_show_author_list(False)
+        r = s.get_render_slide(1)
+        self.check_allfields(r, 2)
+        s.set_show_author_list(True)
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+    
+    def test_copyright_show_noshow(self):
+        """Test the show copyright flag"""
+        s = self.stdSong()
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+        s.set_show_copyright(False)
+        r = s.get_render_slide(1)
+        self.check_allfields(r, 3)
+        s.set_show_copyright(True)
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+    
+    def test_ccli_show_noshow(self):
+        """Test the show copyright flag"""
+        s = self.stdSong()
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+        s.set_show_song_cclino(False)
+        r = s.get_render_slide(1)
+        self.check_allfields(r, 4)
+        s.set_show_song_cclino(True)
+        r = s.get_render_slide(1)
+        self.check_allfields(r)
+        
+    def test_verse1(self):
+        """Test an empty verse list"""
+        s = Song()
+        s.set_lyrics([])
+        assert(s.get_number_of_slides() == 0)
+        
+    def test_verse2(self):
+        """Test a list with an empty string"""
+        s = Song()
+        s.set_lyrics([""])
+        assert(s.get_number_of_slides() == 0)
+        
+    def test_verse3a(self):
+        """Test a one liner song"""
+        s = Song()
+        s.set_lyrics(["Single verse"])
+        assert(s.get_number_of_slides() == 1)
+        
+    def test_verse3b(self):
+        """Test a one liner song"""
+        s = Song()
+        s.set_lyrics(["", u'Single verse"])
+        assert(s.get_number_of_slides() == 1)
+        
+    def test_verse3c(self):
+        """Test a one liner song"""
+        s = Song()
+        s.set_lyrics(["", u'Single verse", u'", u'"])
+        assert(s.get_number_of_slides() == 1)
+
+    def test_verse3d(self):
+        """Test a one liner song"""
+        s = Song()
+        s.set_lyrics(["", u'# Verse", u'", u'"])
+        assert(s.get_number_of_slides() == 1)
         
\ No newline at end of file

=== modified file 'openlpcnv.pyw'
--- openlpcnv.pyw	2009-05-02 19:32:15 +0000
+++ openlpcnv.pyw	2009-06-16 18:21:24 +0000
@@ -22,8 +22,8 @@
         """
         """
         self.display = Display()        
-        self.stime =  time.strftime("%Y-%m-%d-%H%M%S", time.localtime())
-        self.display.output("OpenLp v1.9.0 Migration Utility Started" )
+        self.stime =  time.strftime(u'%Y-%m-%d-%H%M%S", time.localtime())
+        self.display.output(u'OpenLp v1.9.0 Migration Utility Started" )
         
     def process(self):
         MigrateFiles(self.display).process()
@@ -33,13 +33,13 @@
     def move_log_file(self):
         fname = 'openlp-migration.log'
         c = os.path.splitext(fname)
-        b = (c[0]+'-'+ str(self.stime) + c[1])
-        self.display.output("Logfile " +b + " generated")       
-        self.display.output("Migration Utility Finished ")
+        b = (c[0]+'-'+ unicode(self.stime) + c[1])
+        self.display.output(u'Logfile " +b + " generated')       
+        self.display.output(u'Migration Utility Finished ')
         os.rename(fname, b)        
 
         
 if __name__ == '__main__':
     mig = Migration()
     mig.process()
-    #mig.move_log_file()
+    #mig.move_log_file()
\ No newline at end of file


Follow ups