openlp-core team mailing list archive
-
openlp-core team
-
Mailing list archive
-
Message #03030
[Merge] lp:~phill-ridout/openlp/wow_import into lp:openlp
phill has proposed merging lp:~phill-ridout/openlp/wow_import into lp:openlp.
Requested reviews:
Raoul Snyman (raoul-snyman): minor changes
--
https://code.launchpad.net/~phill-ridout/openlp/wow_import/+merge/33959
Your team OpenLP Core is subscribed to branch lp:openlp.
=== modified file 'openlp/plugins/songs/forms/songimportform.py'
--- openlp/plugins/songs/forms/songimportform.py 2010-08-27 15:25:29 +0000
+++ openlp/plugins/songs/forms/songimportform.py 2010-08-27 20:26:41 +0000
@@ -160,7 +160,7 @@
self.openSongAddButton.setFocus()
return False
elif source_format == SongFormat.WordsOfWorship:
- if self.wordsOfWorshipListWidget.count() == 0:
+ if self.wordsOfWorshipFileListWidget.count() == 0:
QtGui.QMessageBox.critical(self,
translate('SongsPlugin.ImportWizardForm',
'No Words of Worship Files Selected'),
@@ -315,6 +315,7 @@
pass
def setDefaults(self):
+ self.restart()
self.formatComboBox.setCurrentIndex(0)
self.openLP2FilenameEdit.setText(u'')
self.openLP1FilenameEdit.setText(u'')
=== modified file 'openlp/plugins/songs/lib/importer.py'
--- openlp/plugins/songs/lib/importer.py 2010-08-23 17:36:42 +0000
+++ openlp/plugins/songs/lib/importer.py 2010-08-27 20:26:41 +0000
@@ -29,6 +29,7 @@
try:
from sofimport import SofImport
from oooimport import OooImport
+ from wowimport import WowImport
except ImportError:
pass
@@ -63,6 +64,8 @@
return OpenSongImport
elif format == SongFormat.SongsOfFellowship:
return SofImport
+ elif format == SongFormat.WordsOfWorship:
+ return WowImport
elif format == SongFormat.Generic:
return OooImport
# else:
=== modified file 'openlp/plugins/songs/lib/songimport.py'
--- openlp/plugins/songs/lib/songimport.py 2010-08-27 15:25:29 +0000
+++ openlp/plugins/songs/lib/songimport.py 2010-08-27 20:26:41 +0000
@@ -52,6 +52,13 @@
"""
self.manager = manager
self.stop_import_flag = False
+ self.copyright_string = unicode(translate(
+ 'SongsPlugin.SongImport', 'copyright'))
+ self.copyright_symbol = unicode(translate(
+ 'SongsPlugin.SongImport', '\xa9'))
+ self.setDefaults()
+
+ def setDefaults(self):
self.title = u''
self.song_number = u''
self.alternate_title = u''
@@ -67,13 +74,7 @@
self.verses = []
self.versecount = 0
self.choruscount = 0
- self.copyright_string = unicode(translate(
- 'SongsPlugin.SongImport', 'copyright'))
- self.copyright_symbol = unicode(translate(
- 'SongsPlugin.SongImport', '\xa9'))
- QtCore.QObject.connect(Receiver.get_receiver(),
- QtCore.SIGNAL(u'songs_stop_import'), self.stop_import)
-
+
def stop_import(self):
"""
Sets the flag for importers to stop their import
@@ -298,6 +299,7 @@
topic = Topic.populate(name=topictext)
song.topics.append(topic)
self.manager.save_object(song)
+ self.setDefaults()
def print_song(self):
"""
=== added file 'openlp/plugins/songs/lib/wowimport.py'
--- openlp/plugins/songs/lib/wowimport.py 1970-01-01 00:00:00 +0000
+++ openlp/plugins/songs/lib/wowimport.py 2010-08-27 20:26:41 +0000
@@ -0,0 +1,173 @@
+# -*- coding: utf-8 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=80 tabstop=4 softtabstop=4
+
+###############################################################################
+# OpenLP - Open Source Lyrics Projection #
+# --------------------------------------------------------------------------- #
+# Copyright (c) 2008-2010 Raoul Snyman #
+# Portions copyright (c) 2008-2010 Tim Bentley, Jonathan Corwin, Michael #
+# Gorven, Scott Guerrieri, Meinert Jordan, Andreas Preikschat, Christian #
+# Richter, Philip Ridout, Maikel Stuivenberg, Martin Thompson, Jon Tibble, #
+# Carsten Tinggaard, Frode Woldsund #
+# --------------------------------------------------------------------------- #
+# 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 #
+###############################################################################
+"""
+The :mod:`wowimport` module provides the functionality for importing Words of
+Worship songs into the OpenLP database.
+"""
+import os
+import logging
+
+from openlp.plugins.songs.lib.songimport import SongImport
+
+BLOCK_TYPES = (u'V', u'C', u'B')
+
+log = logging.getLogger(__name__)
+
+class WowImport(SongImport):
+ """
+ The :class:`WowImport` class provides the ability to import song files from
+ Words of Worship.
+
+ Words Of Worship Song File Format
+ `````````````````````````````````
+
+ The Words Of Worship song file format is as follows:
+
+ * The song title is the file name minus the extension.
+ * The song has a header, a number of blocks, followed by footer containing
+ the author and the copyright.
+ * A block can be a verse, chorus or bridge.
+
+ File Header:
+ Bytes are counted from one, i.e. the first byte is byte 1. These bytes,
+ up to the 56 byte, can change but no real meaning has been found. The
+ 56th byte specifies how many blocks there are. The first block starts
+ with byte 83 after the "CSongDoc::CBlock" declaration.
+
+ Blocks:
+ Each block has a starting header, some lines of text, and an ending
+ footer. Each block starts with 4 bytes, the first byte specifies how
+ many lines are in that block, the next three bytes are null bytes.
+
+ Each block ends with 4 bytes, the first of which defines what type of
+ block it is, and the rest which are null bytes:
+
+ * ``NUL`` (\x00) - Verse
+ * ``SOH`` (\x01) - Chorus
+ * ``STX`` (\x02) - Bridge
+
+ Blocks are seperated by two bytes. The first byte is ``SOH`` (\x01),
+ and the second byte is ``â¬`` (\x80).
+
+ Lines:
+ Each line starts with a byte which specifies how long that line is,
+ the line text, and ends with a null byte.
+
+
+ Footer:
+ The footer follows on after the last block, the first byte specifies
+ the length of the author text, followed by the author text, if
+ this byte is null, then there is no author text. The byte after the
+ author text specifies the length of the copyright text, followed
+ by the copyright text.
+
+ The file is ended with four null bytes.
+
+ Valid extensions for a Words of Worship song file are:
+
+ * .wsg
+ * .wow-song
+ """
+
+ def __init__(self, master_manager, **kwargs):
+ """
+ Initialise the import.
+
+ ``master_manager``
+ The song manager for the running OpenLP installation.
+ """
+ SongImport.__init__(self, master_manager)
+ self.master_manager = master_manager
+ if kwargs.has_key(u'filename'):
+ self.import_source = kwargs[u'filename']
+ if kwargs.has_key(u'filenames'):
+ self.import_source = kwargs[u'filenames']
+ log.debug(self.import_source)
+
+ def do_import(self):
+ """
+ Recieve a single file, or a list of files to import.
+ """
+
+ if isinstance(self.import_source, list):
+ self.import_wizard.importProgressBar.setMaximum(
+ len(self.import_source))
+ for file in self.import_source:
+ # TODO: check that it is a valid words of worship file (could
+ # check header for WoW File Song Word)
+ self.author = u''
+ self.copyright= u''
+ # Get the song title
+ self.file_name = os.path.split(file)[1]
+ self.import_wizard.incrementProgressBar(
+ "Importing %s" % (self.file_name), 0)
+ self.title = self.file_name.rpartition(u'.')[0]
+ self.songData = open(file, 'rb')
+ # Seek to byte which stores number of blocks in the song
+ self.songData.seek(56)
+ self.no_of_blocks = ord(self.songData.read(1))
+ # Seek to the beging of the first block
+ self.songData.seek(82)
+ for block in range(self.no_of_blocks):
+ self.lines_to_read = ord(self.songData.read(1))
+ # Skip 3 nulls to the beginnig of the 1st line
+ self.songData.seek(3, os.SEEK_CUR)
+ self.block_text = u''
+ while self.lines_to_read:
+ self.length_of_line = ord(self.songData.read(1))
+ self.line_text = unicode(
+ self.songData.read(self.length_of_line), u'cp1252')
+ self.songData.seek(1, os.SEEK_CUR)
+ if self.block_text != u'':
+ self.block_text += u'\n'
+ self.block_text += self.line_text
+ self.lines_to_read -= 1
+ self.block_type = BLOCK_TYPES[ord(self.songData.read(1))]
+ # Skip 3 nulls at the end of the block
+ self.songData.seek(3, os.SEEK_CUR)
+ # Blocks are seperated by 2 bytes, skip them, but not if
+ # this is the last block!
+ if (block + 1) < self.no_of_blocks:
+ self.songData.seek(2, os.SEEK_CUR)
+ self.add_verse(self.block_text, self.block_type)
+ # Now to extact the author
+ self.author_length = ord(self.songData.read(1))
+ if self.author_length != 0:
+ self.author = unicode(
+ self.songData.read(self.author_length), u'cp1252')
+ # Finally the copyright
+ self.copyright_length = ord(self.songData.read(1))
+ if self.copyright_length != 0:
+ self.copyright = unicode(
+ self.songData.read(self.copyright_length), u'cp1252')
+ self.parse_author(self.author)
+ self.add_copyright(self.copyright)
+ self.songData.close()
+ self.finish()
+ self.import_wizard.incrementProgressBar(
+ "Importing %s" % (self.file_name))
+ return True
+
Follow ups