forked from openlp/openlp
restore not upgraded bibles; clean ups
This commit is contained in:
parent
11f3a9e13a
commit
6c96794af1
@ -37,7 +37,7 @@ from openlp.core.lib import Receiver, SettingsManager, translate, \
|
|||||||
check_directory_exists
|
check_directory_exists
|
||||||
from openlp.core.lib.ui import UiStrings, critical_error_message_box
|
from openlp.core.lib.ui import UiStrings, critical_error_message_box
|
||||||
from openlp.core.ui.wizard import OpenLPWizard, WizardStrings
|
from openlp.core.ui.wizard import OpenLPWizard, WizardStrings
|
||||||
from openlp.core.utils import AppLocation
|
from openlp.core.utils import AppLocation, delete_file
|
||||||
from openlp.plugins.bibles.lib.db import BibleDB, BibleMeta, OldBibleDB, \
|
from openlp.plugins.bibles.lib.db import BibleDB, BibleMeta, OldBibleDB, \
|
||||||
BiblesResourcesDB
|
BiblesResourcesDB
|
||||||
from openlp.plugins.bibles.lib.http import BSExtract, BGExtract, CWExtract
|
from openlp.plugins.bibles.lib.http import BSExtract, BGExtract, CWExtract
|
||||||
@ -254,23 +254,22 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
for number, filename in enumerate(self.files):
|
for number, filename in enumerate(self.files):
|
||||||
bible = OldBibleDB(self.mediaItem, path=self.path, file=filename[0])
|
bible = OldBibleDB(self.mediaItem, path=self.path, file=filename[0])
|
||||||
self.checkBox[number] = QtGui.QCheckBox(self.scrollAreaContents)
|
self.checkBox[number] = QtGui.QCheckBox(self.scrollAreaContents)
|
||||||
checkBoxName = u'checkBox[%d]' % number
|
self.checkBox[number].setObjectName(u'checkBox[%d]' % number)
|
||||||
self.checkBox[number].setObjectName(checkBoxName)
|
|
||||||
self.checkBox[number].setText(bible.get_name())
|
self.checkBox[number].setText(bible.get_name())
|
||||||
self.checkBox[number].setCheckState(QtCore.Qt.Checked)
|
self.checkBox[number].setCheckState(QtCore.Qt.Checked)
|
||||||
self.formLayout.addWidget(self.checkBox[number])
|
self.formLayout.addWidget(self.checkBox[number])
|
||||||
self.verticalWidget[number] = QtGui.QWidget(self.scrollAreaContents)
|
self.verticalWidget[number] = QtGui.QWidget(self.scrollAreaContents)
|
||||||
verticalWidgetName = u'verticalWidget[%d]' % number
|
self.verticalWidget[number].setObjectName(
|
||||||
self.verticalWidget[number].setObjectName(verticalWidgetName)
|
u'verticalWidget[%d]' % number)
|
||||||
self.horizontalLayout[number] = QtGui.QHBoxLayout(
|
self.horizontalLayout[number] = QtGui.QHBoxLayout(
|
||||||
self.verticalWidget[number])
|
self.verticalWidget[number])
|
||||||
self.horizontalLayout[number].setContentsMargins(25, 0, 0, 0)
|
self.horizontalLayout[number].setContentsMargins(25, 0, 0, 0)
|
||||||
horizontalLayoutName = u'horizontalLayout[%d]' % number
|
self.horizontalLayout[number].setObjectName(
|
||||||
self.horizontalLayout[number].setObjectName(horizontalLayoutName)
|
u'horizontalLayout[%d]' % number)
|
||||||
self.versionInfoPixmap[number] = QtGui.QLabel(
|
self.versionInfoPixmap[number] = QtGui.QLabel(
|
||||||
self.verticalWidget[number])
|
self.verticalWidget[number])
|
||||||
versionInfoPixmapName = u'versionInfoPixmap[%d]' % number
|
self.versionInfoPixmap[number].setObjectName(
|
||||||
self.versionInfoPixmap[number].setObjectName(versionInfoPixmapName)
|
u'versionInfoPixmap[%d]' % number)
|
||||||
self.versionInfoPixmap[number].setPixmap(QtGui.QPixmap(
|
self.versionInfoPixmap[number].setPixmap(QtGui.QPixmap(
|
||||||
u':/bibles/bibles_upgrade_alert.png'))
|
u':/bibles/bibles_upgrade_alert.png'))
|
||||||
self.versionInfoPixmap[number].setAlignment(QtCore.Qt.AlignRight)
|
self.versionInfoPixmap[number].setAlignment(QtCore.Qt.AlignRight)
|
||||||
@ -278,8 +277,8 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
self.versionInfoPixmap[number])
|
self.versionInfoPixmap[number])
|
||||||
self.versionInfoLabel[number] = QtGui.QLabel(
|
self.versionInfoLabel[number] = QtGui.QLabel(
|
||||||
self.verticalWidget[number])
|
self.verticalWidget[number])
|
||||||
versionInfoLabelName = u'versionInfoLabel[%d]' % number
|
self.versionInfoLabel[number].setObjectName(
|
||||||
self.versionInfoLabel[number].setObjectName(versionInfoLabelName)
|
u'versionInfoLabel[%d]' % number)
|
||||||
sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Expanding,
|
sizePolicy = QtGui.QSizePolicy(QtGui.QSizePolicy.Expanding,
|
||||||
QtGui.QSizePolicy.Preferred)
|
QtGui.QSizePolicy.Preferred)
|
||||||
sizePolicy.setHorizontalStretch(0)
|
sizePolicy.setHorizontalStretch(0)
|
||||||
@ -291,14 +290,12 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
self.versionInfoLabel[number])
|
self.versionInfoLabel[number])
|
||||||
self.formLayout.addWidget(self.verticalWidget[number])
|
self.formLayout.addWidget(self.verticalWidget[number])
|
||||||
self.formWidget[number] = QtGui.QWidget(self.scrollAreaContents)
|
self.formWidget[number] = QtGui.QWidget(self.scrollAreaContents)
|
||||||
formWidgetName = u'formWidget[%d]' % number
|
self.formWidget[number].setObjectName(u'formWidget[%d]' % number)
|
||||||
self.formWidget[number].setObjectName(formWidgetName)
|
|
||||||
self.formLayoutAttention[number] = QtGui.QFormLayout(
|
self.formLayoutAttention[number] = QtGui.QFormLayout(
|
||||||
self.formWidget[number])
|
self.formWidget[number])
|
||||||
self.formLayoutAttention[number].setContentsMargins(25, 0, 0, 5)
|
self.formLayoutAttention[number].setContentsMargins(25, 0, 0, 5)
|
||||||
formLayoutAttentionName = u'formLayoutAttention[%d]' % number
|
|
||||||
self.formLayoutAttention[number].setObjectName(
|
self.formLayoutAttention[number].setObjectName(
|
||||||
formLayoutAttentionName)
|
u'formLayoutAttention[%d]' % number)
|
||||||
self.versionNameLabel[number] = QtGui.QLabel(
|
self.versionNameLabel[number] = QtGui.QLabel(
|
||||||
self.formWidget[number])
|
self.formWidget[number])
|
||||||
self.versionNameLabel[number].setObjectName(u'VersionNameLabel')
|
self.versionNameLabel[number].setObjectName(u'VersionNameLabel')
|
||||||
@ -431,7 +428,10 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
if not self.checkBox[number].checkState() == QtCore.Qt.Checked:
|
if not self.checkBox[number].checkState() == QtCore.Qt.Checked:
|
||||||
continue
|
continue
|
||||||
# Move bibles to temp dir.
|
# Move bibles to temp dir.
|
||||||
shutil.move(os.path.join(self.path, filename[0]), temp_dir)
|
if not os.path.exists(os.path.join(temp_dir, filename[0])):
|
||||||
|
shutil.move(os.path.join(self.path, filename[0]), temp_dir)
|
||||||
|
else:
|
||||||
|
delete_file(os.path.join(self.path, filename[0]))
|
||||||
return True
|
return True
|
||||||
if self.currentPage() == self.progressPage:
|
if self.currentPage() == self.progressPage:
|
||||||
return True
|
return True
|
||||||
@ -684,20 +684,24 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
'Upgrading Bible %s of %s: "%s"\nFailed')) %
|
'Upgrading Bible %s of %s: "%s"\nFailed')) %
|
||||||
(number + 1, max_bibles, name),
|
(number + 1, max_bibles, name),
|
||||||
self.progressBar.maximum() - self.progressBar.value())
|
self.progressBar.maximum() - self.progressBar.value())
|
||||||
# Remove old bibles.
|
|
||||||
shutil.rmtree(temp_dir, True)
|
|
||||||
|
|
||||||
def postWizard(self):
|
def postWizard(self):
|
||||||
"""
|
"""
|
||||||
Clean up the UI after the import has finished.
|
Clean up the UI after the import has finished.
|
||||||
"""
|
"""
|
||||||
|
temp_dir = os.path.join(gettempdir(), u'openlp')
|
||||||
successful_import = 0
|
successful_import = 0
|
||||||
failed_import = 0
|
failed_import = 0
|
||||||
for number, filename in enumerate(self.files):
|
for number, filename in enumerate(self.files):
|
||||||
if self.success.has_key(number) and self.success[number]:
|
if self.success.has_key(number) and self.success[number]:
|
||||||
successful_import += 1
|
successful_import += 1
|
||||||
elif self.checkBox[number].checkState() == QtCore.Qt.Checked:
|
else:
|
||||||
failed_import += 1
|
# Delete upgraded (but not complete, corrupted, ...) bible.
|
||||||
|
delete_file(os.path.join(self.path, filename[0]))
|
||||||
|
# Copy not upgraded bible back.
|
||||||
|
shutil.move(os.path.join(temp_dir, filename[0]), self.path)
|
||||||
|
if self.checkBox[number].checkState() == QtCore.Qt.Checked:
|
||||||
|
failed_import += 1
|
||||||
if failed_import > 0:
|
if failed_import > 0:
|
||||||
failed_import_text = unicode(translate(
|
failed_import_text = unicode(translate(
|
||||||
'BiblesPlugin.UpgradeWizardForm',
|
'BiblesPlugin.UpgradeWizardForm',
|
||||||
@ -720,4 +724,6 @@ class BibleUpgradeForm(OpenLPWizard):
|
|||||||
else:
|
else:
|
||||||
self.progressLabel.setText(translate(
|
self.progressLabel.setText(translate(
|
||||||
'BiblesPlugin.UpgradeWizardForm', 'Upgrade failed.'))
|
'BiblesPlugin.UpgradeWizardForm', 'Upgrade failed.'))
|
||||||
|
# Remove old bibles.
|
||||||
|
shutil.rmtree(temp_dir, True)
|
||||||
OpenLPWizard.postWizard(self)
|
OpenLPWizard.postWizard(self)
|
||||||
|
@ -73,8 +73,7 @@ class OpenLyricsExport(object):
|
|||||||
tree = etree.ElementTree(etree.fromstring(xml))
|
tree = etree.ElementTree(etree.fromstring(xml))
|
||||||
filename = u'%s (%s)' % (song.title,
|
filename = u'%s (%s)' % (song.title,
|
||||||
u', '.join([author.display_name for author in song.authors]))
|
u', '.join([author.display_name for author in song.authors]))
|
||||||
filename = re.sub(
|
filename = clean_filename(filename)
|
||||||
r'[/\\?*|<>\[\]":<>+%]+', u'_', filename).strip(u'_')
|
|
||||||
# Ensure the filename isn't too long for some filesystems
|
# Ensure the filename isn't too long for some filesystems
|
||||||
filename = u'%s.xml' % filename[0:250 - len(self.save_path)]
|
filename = u'%s.xml' % filename[0:250 - len(self.save_path)]
|
||||||
# Pass a file object, because lxml does not cope with some special
|
# Pass a file object, because lxml does not cope with some special
|
||||||
|
Loading…
Reference in New Issue
Block a user