Improved update checking
Former-commit-id: 66d9959e9190f49c4d1bbc38261e847c846cae59
This commit is contained in:
parent
30cb4926b9
commit
2662f20c09
@ -2,4 +2,5 @@
|
||||
pyuic4 ui/about.ui -o yomi_base/gen/about_ui.py
|
||||
pyuic4 ui/preferences.ui -o yomi_base/gen/preferences_ui.py
|
||||
pyuic4 ui/reader.ui -o yomi_base/gen/reader_ui.py
|
||||
pyuic4 ui/updates.ui -o yomi_base/gen/updates_ui.py
|
||||
pyrcc4 ui/resources.qrc -o yomi_base/gen/resources_rc.py
|
||||
|
84
ui/updates.ui
Normal file
84
ui/updates.ui
Normal file
@ -0,0 +1,84 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<ui version="4.0">
|
||||
<class>DialogUpdates</class>
|
||||
<widget class="QDialog" name="DialogUpdates">
|
||||
<property name="geometry">
|
||||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>500</width>
|
||||
<height>400</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
<string>Update Checker</string>
|
||||
</property>
|
||||
<layout class="QVBoxLayout" name="verticalLayout">
|
||||
<item>
|
||||
<widget class="QLabel" name="labelUpdates">
|
||||
<property name="text">
|
||||
<string><p>A new version of Yomichan is available for download!</p>
|
||||
|
||||
<p>You can download this update (version {0} to version {1}) from the add-ons section on <a href="https://ankiweb.net/shared/info/934748696">Anki Online</a> or directly from the <a href="http://foosoft.net/projects/yomichan">Yomichan homepage</a>.</p>
|
||||
|
||||
<p>Changes from your version are listed below:</p></string>
|
||||
</property>
|
||||
<property name="wordWrap">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="openExternalLinks">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QTextBrowser" name="textBrowser"/>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QDialogButtonBox" name="buttonBox">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="standardButtons">
|
||||
<set>QDialogButtonBox::Ok</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<resources/>
|
||||
<connections>
|
||||
<connection>
|
||||
<sender>buttonBox</sender>
|
||||
<signal>accepted()</signal>
|
||||
<receiver>DialogUpdates</receiver>
|
||||
<slot>accept()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>248</x>
|
||||
<y>254</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>157</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
<connection>
|
||||
<sender>buttonBox</sender>
|
||||
<signal>rejected()</signal>
|
||||
<receiver>DialogUpdates</receiver>
|
||||
<slot>reject()</slot>
|
||||
<hints>
|
||||
<hint type="sourcelabel">
|
||||
<x>316</x>
|
||||
<y>260</y>
|
||||
</hint>
|
||||
<hint type="destinationlabel">
|
||||
<x>286</x>
|
||||
<y>274</y>
|
||||
</hint>
|
||||
</hints>
|
||||
</connection>
|
||||
</connections>
|
||||
</ui>
|
@ -2,7 +2,7 @@
|
||||
|
||||
# Form implementation generated from reading ui file 'ui/about.ui'
|
||||
#
|
||||
# Created: Sun Feb 15 13:27:51 2015
|
||||
# Created: Sun Feb 15 15:01:20 2015
|
||||
# by: PyQt4 UI code generator 4.10.4
|
||||
#
|
||||
# WARNING! All changes made in this file will be lost!
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
# Form implementation generated from reading ui file 'ui/preferences.ui'
|
||||
#
|
||||
# Created: Sun Feb 15 13:27:51 2015
|
||||
# Created: Sun Feb 15 15:01:20 2015
|
||||
# by: PyQt4 UI code generator 4.10.4
|
||||
#
|
||||
# WARNING! All changes made in this file will be lost!
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
# Form implementation generated from reading ui file 'ui/reader.ui'
|
||||
#
|
||||
# Created: Sun Feb 15 13:27:51 2015
|
||||
# Created: Sun Feb 15 15:01:20 2015
|
||||
# by: PyQt4 UI code generator 4.10.4
|
||||
#
|
||||
# WARNING! All changes made in this file will be lost!
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
# Resource object code
|
||||
#
|
||||
# Created: Sun Feb 15 13:27:51 2015
|
||||
# Created: Sun Feb 15 15:01:20 2015
|
||||
# by: The Resource Compiler for PyQt (Qt v4.8.6)
|
||||
#
|
||||
# WARNING! All changes made in this file will be lost!
|
||||
|
58
yomi_base/gen/updates_ui.py
Normal file
58
yomi_base/gen/updates_ui.py
Normal file
@ -0,0 +1,58 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Form implementation generated from reading ui file 'ui/updates.ui'
|
||||
#
|
||||
# Created: Sun Feb 15 15:01:20 2015
|
||||
# by: PyQt4 UI code generator 4.10.4
|
||||
#
|
||||
# WARNING! All changes made in this file will be lost!
|
||||
|
||||
from PyQt4 import QtCore, QtGui
|
||||
|
||||
try:
|
||||
_fromUtf8 = QtCore.QString.fromUtf8
|
||||
except AttributeError:
|
||||
def _fromUtf8(s):
|
||||
return s
|
||||
|
||||
try:
|
||||
_encoding = QtGui.QApplication.UnicodeUTF8
|
||||
def _translate(context, text, disambig):
|
||||
return QtGui.QApplication.translate(context, text, disambig, _encoding)
|
||||
except AttributeError:
|
||||
def _translate(context, text, disambig):
|
||||
return QtGui.QApplication.translate(context, text, disambig)
|
||||
|
||||
class Ui_DialogUpdates(object):
|
||||
def setupUi(self, DialogUpdates):
|
||||
DialogUpdates.setObjectName(_fromUtf8("DialogUpdates"))
|
||||
DialogUpdates.resize(500, 400)
|
||||
self.verticalLayout = QtGui.QVBoxLayout(DialogUpdates)
|
||||
self.verticalLayout.setObjectName(_fromUtf8("verticalLayout"))
|
||||
self.labelUpdates = QtGui.QLabel(DialogUpdates)
|
||||
self.labelUpdates.setWordWrap(True)
|
||||
self.labelUpdates.setOpenExternalLinks(True)
|
||||
self.labelUpdates.setObjectName(_fromUtf8("labelUpdates"))
|
||||
self.verticalLayout.addWidget(self.labelUpdates)
|
||||
self.textBrowser = QtGui.QTextBrowser(DialogUpdates)
|
||||
self.textBrowser.setObjectName(_fromUtf8("textBrowser"))
|
||||
self.verticalLayout.addWidget(self.textBrowser)
|
||||
self.buttonBox = QtGui.QDialogButtonBox(DialogUpdates)
|
||||
self.buttonBox.setOrientation(QtCore.Qt.Horizontal)
|
||||
self.buttonBox.setStandardButtons(QtGui.QDialogButtonBox.Ok)
|
||||
self.buttonBox.setObjectName(_fromUtf8("buttonBox"))
|
||||
self.verticalLayout.addWidget(self.buttonBox)
|
||||
|
||||
self.retranslateUi(DialogUpdates)
|
||||
QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(_fromUtf8("accepted()")), DialogUpdates.accept)
|
||||
QtCore.QObject.connect(self.buttonBox, QtCore.SIGNAL(_fromUtf8("rejected()")), DialogUpdates.reject)
|
||||
QtCore.QMetaObject.connectSlotsByName(DialogUpdates)
|
||||
|
||||
def retranslateUi(self, DialogUpdates):
|
||||
DialogUpdates.setWindowTitle(_translate("DialogUpdates", "Update Checker", None))
|
||||
self.labelUpdates.setText(_translate("DialogUpdates", "<p>A new version of Yomichan is available for download!</p>\n"
|
||||
"\n"
|
||||
"<p>You can download this update (version {0} to version {1}) from the add-ons section on <a href=\"https://ankiweb.net/shared/info/934748696\">Anki Online</a> or directly from the <a href=\"http://foosoft.net/projects/yomichan\">Yomichan homepage</a>.</p>\n"
|
||||
"\n"
|
||||
"<p>Changes from your version are listed below:</p>", None))
|
||||
|
@ -24,7 +24,7 @@ import japanese.util
|
||||
import os
|
||||
import preferences
|
||||
import reader_util
|
||||
import update
|
||||
import updates
|
||||
|
||||
|
||||
class MainWindowReader(QtGui.QMainWindow, gen.reader_ui.Ui_MainWindowReader):
|
||||
@ -52,7 +52,7 @@ class MainWindowReader(QtGui.QMainWindow, gen.reader_ui.Ui_MainWindowReader):
|
||||
self.language = language
|
||||
self.preferences = preferences
|
||||
self.state = self.State()
|
||||
self.updater = update.UpdateFinder()
|
||||
self.updates = updates.UpdateFinder()
|
||||
self.zoom = 0
|
||||
|
||||
self.applyPreferences()
|
||||
@ -90,10 +90,10 @@ class MainWindowReader(QtGui.QMainWindow, gen.reader_ui.Ui_MainWindowReader):
|
||||
self.textKanjiSearch.returnPressed.connect(self.onKanjiDefSearchReturn)
|
||||
self.textVocabDefs.anchorClicked.connect(self.onVocabDefsAnchorClicked)
|
||||
self.textVocabSearch.returnPressed.connect(self.onVocabDefSearchReturn)
|
||||
self.updater.updateResult.connect(self.onUpdaterSearchResult)
|
||||
self.updates.updateResult.connect(self.onUpdaterSearchResult)
|
||||
|
||||
if self.preferences['checkForUpdates']:
|
||||
self.updater.start()
|
||||
self.updates.start()
|
||||
|
||||
|
||||
def applyPreferences(self):
|
||||
@ -323,14 +323,10 @@ class MainWindowReader(QtGui.QMainWindow, gen.reader_ui.Ui_MainWindowReader):
|
||||
self.actionToggleKanji.setChecked(self.dockKanji.isVisible())
|
||||
|
||||
|
||||
def onUpdaterSearchResult(self, result):
|
||||
if result and unicode(result) > constants.c['appVersion']:
|
||||
QtGui.QMessageBox.information(
|
||||
self,
|
||||
'Yomichan',
|
||||
'A new version of Yomichan is available for download!\n\nYou can download this update ({0} > {1}) ' \
|
||||
'from "Shared Plugins" in Anki or directly from the Yomichan homepage.'.format(constants.c['appVersion'], result)
|
||||
)
|
||||
def onUpdaterSearchResult(self, versions):
|
||||
if versions['latest'] > constants.c['appVersion']:
|
||||
dialog = updates.DialogUpdates(self, versions)
|
||||
dialog.exec_()
|
||||
|
||||
|
||||
def onContentMouseMove(self, event):
|
||||
|
@ -1,40 +0,0 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright (C) 2013 Alex Yatskov
|
||||
#
|
||||
# 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, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# 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, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
|
||||
from PyQt4 import QtCore
|
||||
from xml.dom import minidom
|
||||
import constants
|
||||
import urllib2
|
||||
|
||||
|
||||
class UpdateFinder(QtCore.QThread):
|
||||
updateResult = QtCore.pyqtSignal(str)
|
||||
|
||||
def run(self):
|
||||
latest = None
|
||||
try:
|
||||
fp = urllib2.urlopen('http://foosoft.net/pub/projects/yomichan/updates.xml')
|
||||
data = fp.read()
|
||||
doc = minidom.parseString(data)
|
||||
root = doc.documentElement
|
||||
if root.nodeName == 'updates':
|
||||
latest = root.getAttribute('latest') or None
|
||||
except:
|
||||
pass
|
||||
finally:
|
||||
self.updateResult.emit(latest or constants.c['appVersion'])
|
72
yomi_base/updates.py
Normal file
72
yomi_base/updates.py
Normal file
@ -0,0 +1,72 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright (C) 2013 Alex Yatskov
|
||||
#
|
||||
# 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, either version 3 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# 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, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
|
||||
from PyQt4 import QtCore, QtGui
|
||||
import constants
|
||||
import gen.updates_ui
|
||||
import json
|
||||
import urllib2
|
||||
|
||||
|
||||
class DialogUpdates(QtGui.QDialog, gen.updates_ui.Ui_DialogUpdates):
|
||||
def __init__(self, parent, versions):
|
||||
QtGui.QDialog.__init__(self, parent)
|
||||
self.setupUi(self)
|
||||
|
||||
self.updateHtml(versions)
|
||||
self.labelUpdates.setText(
|
||||
unicode(self.labelUpdates.text()).format(
|
||||
constants.c['appVersion'],
|
||||
versions['latest']
|
||||
)
|
||||
)
|
||||
|
||||
|
||||
def updateHtml(self, versions):
|
||||
html = '<html><body>'
|
||||
|
||||
for update in versions['updates']:
|
||||
version = update.get('version')
|
||||
if version > constants.c['appVersion']:
|
||||
html += '<strong>Version {0}</strong>'.format(version)
|
||||
html += '<ul>'
|
||||
for feature in update['features']:
|
||||
html += '<li>{0}</li>'.format(feature)
|
||||
html += '</ul>'
|
||||
|
||||
self.textBrowser.setHtml(html)
|
||||
|
||||
|
||||
class UpdateFinder(QtCore.QThread):
|
||||
updateResult = QtCore.pyqtSignal(dict)
|
||||
|
||||
def run(self):
|
||||
latest = constants.c['appVersion']
|
||||
updates = list()
|
||||
|
||||
try:
|
||||
fp = urllib2.urlopen('http://foosoft.net/projects/yomichan/index/updates.json')
|
||||
updates = json.loads(fp.read())
|
||||
fp.close()
|
||||
|
||||
for update in updates:
|
||||
latest = max(latest, update.get('version'))
|
||||
except:
|
||||
pass
|
||||
finally:
|
||||
self.updateResult.emit({ 'latest': latest, 'updates': updates })
|
Loading…
Reference in New Issue
Block a user