Browse Source

Merge branch 'improve-output' into test-v6

(@see https://fs.golderweb.de/index.php?do=details&task_id=20)
develop
Jonathan Golder 9 years ago
parent
commit
2076932cbf
  1. 3
      .gitmodules
  2. 45
      chartsbot.py
  3. 1
      jogobot

3
.gitmodules

@ -0,0 +1,3 @@
[submodule "jogobot"]
path = jogobot
url = ../jogobot

45
chartsbot.py

@ -50,6 +50,8 @@ import locale
import pywikibot
from pywikibot import pagegenerators
import jogobot
from summarypage import SummaryPage
# This is required for the text that is shown when you run this script
@ -87,6 +89,9 @@ class ChartsBot( ):
# Force parsing of countrylist
self.force_reload = force_reload
# Output Information
jogobot.output( "Chartsbot invoked" )
# Set the edit summary message
self.site = pywikibot.Site()
self.summary = "Bot: Aktualisiere Übersichtsseite Nummer-eins-Hits"
@ -126,7 +131,7 @@ class ChartsBot( ):
text = sumpage.get_new_text()
if not self.save(text, page, self.summary, False):
pywikibot.output(u'Page %s not saved.' % page.title(asLink=True))
jogobot.output(u'Page %s not saved.' % page.title(asLink=True))
def load(self, page):
"""Load the text of the given page."""
@ -134,11 +139,11 @@ class ChartsBot( ):
# Load the page
text = page.get()
except pywikibot.NoPage:
pywikibot.output(u"Page %s does not exist; skipping."
% page.title(asLink=True))
jogobot.output( u"Page %s does not exist; skipping."
% page.title(asLink=True), "ERROR" )
except pywikibot.IsRedirectPage:
pywikibot.output(u"Page %s is a redirect; skipping."
% page.title(asLink=True))
jogobot.output( u"Page %s is a redirect; skipping."
% page.title(asLink=True), "ERROR" )
else:
return text
return None
@ -148,13 +153,17 @@ class ChartsBot( ):
"""Update the given page with new text."""
# only save if something was changed (and not just revision)
if text != page.get():
# Show the title of the page we're working on.
# Highlight the title in purple.
pywikibot.output(u"\n\n>>> \03{lightpurple}%s\03{default} <<<"
% page.title())
# show what was changed
pywikibot.showDiff(page.get(), text)
pywikibot.output(u'Comment: %s' % comment)
# Show diff only in interactive mode or in verbose mode
if not self.always or pywikibot.config.verbose_output:
# Show the title of the page we're working on.
# Highlight the title in purple.
jogobot.output( u">>> \03{lightpurple}%s\03{default} <<<"
% page.title())
# show what was changed
pywikibot.showDiff(page.get(), text)
jogobot.output(u'Comment: %s' % comment)
if self.always or pywikibot.input_yn(
u'Do you want to accept these changes?',
@ -165,17 +174,17 @@ class ChartsBot( ):
page.save(summary=comment or self.comment,
minor=minorEdit, botflag=botflag)
except pywikibot.LockedPage:
pywikibot.output(u"Page %s is locked; skipping."
% page.title(asLink=True))
jogobot.output( u"Page %s is locked; skipping."
% page.title(asLink=True), "ERROR" )
except pywikibot.EditConflict:
pywikibot.output(
jogobot.output(
u'Skipping %s because of edit conflict'
% (page.title()))
% (page.title()), "ERROR")
except pywikibot.SpamfilterError as error:
pywikibot.output(
jogobot.output(
u'Cannot change %s because of spam blacklist \
entry %s'
% (page.title(), error.url))
% (page.title(), error.url), "ERROR")
else:
return True
return False

1
jogobot

@ -0,0 +1 @@
Subproject commit 0daf72b625bc84a6029f74b37978e57e42237c82
Loading…
Cancel
Save