###
# mw - VCS-like nonsense for MediaWiki websites
-# Copyright (C) 2009 Ian Weller <ian@ianweller.org>
+# Copyright (C) 2010 Ian Weller <ian@ianweller.org>
#
# 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
# with this program. If not, see <http://www.gnu.org/licenses/>.
###
-import codecs
import getpass
import mw.api
import mw.metadir
import os
import sys
+
class CommandBase(object):
+
def __init__(self, name, description, usage=None):
self.me = os.path.basename(sys.argv[0])
self.description = description
if usage is None:
usage = '%prog ' + name
+ else:
+ usage = '%%prog %s %s' % (name, usage)
self.parser = OptionParser(usage=usage, description=description)
self.name = name
self.metadir = mw.metadir.Metadir()
self.args = self.args[1:] # don't need the first thing
self._do_command()
+ def _do_command(self):
+ pass
+
def _login(self):
user = raw_input('Username: ')
passwd = getpass.getpass()
+ result = self.api.call({'action': 'login',
+ 'lgname': user,
+ 'lgpassword': passwd})
+ if result['login']['result'] != 'Success':
+ raise Exception('Login error: %s' % result['login']['result'])
def _die_if_no_init(self):
if self.metadir.config is None:
class InitCommand(CommandBase):
+
def __init__(self):
- usage = '%prog init API_URL'
+ usage = 'API_URL'
CommandBase.__init__(self, 'init', 'start a mw repo', usage)
def _do_command(self):
self.metadir.create(self.args[0])
-class FetchCommand(CommandBase):
+class PullCommand(CommandBase):
+
def __init__(self):
- usage = '%prog fetch [options] PAGENAME ...'
- CommandBase.__init__(self, 'fetch', 'fetch remote pages', usage)
- self.shortcuts.append('ft')
+ usage = '[options] PAGENAME ...'
+ CommandBase.__init__(self, 'pull', 'add remote pages to repo', usage)
def _do_command(self):
self._die_if_no_init()
self._api_setup()
pages = []
pages += self.args
- for these_pages in [pages[i:i+25] for i in range(0, len(pages), 25)]:
+ for these_pages in [pages[i:i + 25] for i in range(0, len(pages), 25)]:
data = {
'action': 'query',
'titles': '|'.join(these_pages),
print '%s: %s: page does not exist, file not created' % \
(self.me, pagename)
continue
- revid = [x['revid'] for x in response[pageid]['revisions']]
- self.metadir.pagedict_add(pagename, int(pageid))
+ revids = [x['revid'] for x in response[pageid]['revisions']]
+ revids.sort()
+ self.metadir.pagedict_add(pagename, pageid, revids[-1])
self.metadir.pages_add_rv(int(pageid),
response[pageid]['revisions'][0])
filename = mw.api.pagename_to_filename(pagename)
class StatusCommand(CommandBase):
+
def __init__(self):
CommandBase.__init__(self, 'status', 'check repo status')
self.shortcuts.append('st')
def _do_command(self):
self._die_if_no_init()
- check = []
- for root, dirs, files in os.walk(self.metadir.root):
- if root == self.metadir.root:
- dirs.remove('.mw')
- for name in files:
- check.append(os.path.join(root, name))
- check.sort()
- for full in check:
- name = os.path.split(full)[1]
- if name[-5:] == '.wiki':
- pagename = mw.api.filename_to_pagename(name[:-5])
- pageid = self.metadir.get_pageid_from_pagename(pagename)
- if not pageid:
- print '? %s' % os.path.relpath(full, self.metadir.root)
- else:
- rvid = self.metadir.pages_get_rv_list(pageid)[-1]
- rv = self.metadir.pages_get_rv(pageid, rvid)
- cur_content = codecs.open(full, 'r', 'utf-8').read()
- if cur_content != rv['content']:
- print 'U %s' % os.path.relpath(full, self.metadir.root)
+ status = self.metadir.working_dir_status()
+ for file in status:
+ print '%s %s' % (status[file], file)
+
+
+class DiffCommand(CommandBase):
+
+ def __init__(self):
+ CommandBase.__init__(self, 'diff', 'diff wiki to working directory')
+
+ def _do_command(self):
+ self._die_if_no_init()
+ status = self.metadir.working_dir_status()
+ for file in status:
+ if status[file] == 'U':
+ print self.metadir.diff_rv_to_working(
+ mw.api.filename_to_pagename(file[:-5])
+ ),