can edit several pages at the same time (use vim -p)
This commit is contained in:
parent
241179665d
commit
47ed403fb9
1 changed files with 45 additions and 31 deletions
|
|
@ -32,53 +32,67 @@ class WebContentEdit(ReplApplication):
|
||||||
COPYRIGHT = 'Copyright(C) 2010 Romain Bignon'
|
COPYRIGHT = 'Copyright(C) 2010 Romain Bignon'
|
||||||
CAPS = ICapContent
|
CAPS = ICapContent
|
||||||
|
|
||||||
def do_edit(self, id):
|
def do_edit(self, line):
|
||||||
"""
|
"""
|
||||||
edit ID
|
edit ID
|
||||||
|
|
||||||
Edit a content with $EDITOR, then push it on the website.
|
Edit a content with $EDITOR, then push it on the website.
|
||||||
"""
|
"""
|
||||||
_id, backend_name = self.parse_id(id)
|
contents = []
|
||||||
backend_names = (backend_name,) if backend_name is not None else self.enabled_backends
|
for id in line.split():
|
||||||
|
_id, backend_name = self.parse_id(id)
|
||||||
|
backend_names = (backend_name,) if backend_name is not None else self.enabled_backends
|
||||||
|
|
||||||
contents = [content for backend, content in self.do('get_content', _id, backends=backend_names) if content]
|
contents += [content for backend, content in self.do('get_content', _id, backends=backend_names) if content]
|
||||||
|
|
||||||
if len(contents) == 0:
|
if len(contents) == 0:
|
||||||
print >>sys.stderr, 'No content for the ID "%s"' % id
|
print >>sys.stderr, 'No content for the ID "%s"' % id
|
||||||
return 1
|
return 1
|
||||||
elif len(contents) > 1:
|
|
||||||
print >>sys.stderr, 'Too much replies'
|
|
||||||
return 1
|
|
||||||
|
|
||||||
content = contents[0]
|
paths = {}
|
||||||
|
for content in contents:
|
||||||
|
tmpdir = os.path.join(tempfile.gettempdir(), "weboob")
|
||||||
|
if not os.path.isdir(tmpdir):
|
||||||
|
os.makedirs(tmpdir)
|
||||||
|
fd, path = tempfile.mkstemp(prefix='%s_' % content.id.replace(os.path.sep, '_'), dir=tmpdir)
|
||||||
|
with os.fdopen(fd, 'w') as f:
|
||||||
|
data = content.content
|
||||||
|
if isinstance(data, unicode):
|
||||||
|
data = data.encode('utf-8')
|
||||||
|
f.write(data)
|
||||||
|
paths[path] = content
|
||||||
|
os.system("$EDITOR -p %s" % ' '.join(paths.iterkeys()))
|
||||||
|
|
||||||
tmpdir = os.path.join(tempfile.gettempdir(), "weboob")
|
for path, content in paths.iteritems():
|
||||||
if not os.path.isdir(tmpdir):
|
with open(path, 'r') as f:
|
||||||
os.makedirs(tmpdir)
|
data = f.read()
|
||||||
fd, path = tempfile.mkstemp(prefix='%s_' % content.id.replace(os.path.sep, '_'), dir=tmpdir)
|
try:
|
||||||
with os.fdopen(fd, 'w') as f:
|
data = data.decode('utf-8')
|
||||||
data = content.content
|
except UnicodeError:
|
||||||
if isinstance(data, unicode):
|
pass
|
||||||
data = data.encode('utf-8')
|
if content.content != data:
|
||||||
f.write(data)
|
content.content = data
|
||||||
os.system("$EDITOR %s" % path)
|
else:
|
||||||
|
contents.remove(content)
|
||||||
|
|
||||||
with open(path, 'r') as f:
|
if len(contents) == 0:
|
||||||
data = f.read()
|
|
||||||
try:
|
|
||||||
data = data.decode('utf-8')
|
|
||||||
except UnicodeError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
if data == content.content:
|
|
||||||
print 'No changes. Abort.'
|
print 'No changes. Abort.'
|
||||||
return
|
return
|
||||||
|
|
||||||
message = self.ask('Enter a commit message', default='')
|
message = self.ask('Enter a commit message')
|
||||||
|
|
||||||
|
print 'Contents changed:\n%s' % ('\n'.join([' * %s' % content.id for content in contents]))
|
||||||
|
|
||||||
if not self.ask('Do you want to push?', default=True):
|
if not self.ask('Do you want to push?', default=True):
|
||||||
return
|
return
|
||||||
|
|
||||||
content.content = data
|
for content in contents:
|
||||||
backend = self.weboob.get_backend(content.backend)
|
sys.stdout.write('Pushing %s...' % content.id)
|
||||||
backend.push_content(content, message)
|
sys.stdout.flush()
|
||||||
|
try:
|
||||||
|
backend = self.weboob.get_backend(content.backend)
|
||||||
|
backend.push_content(content, message)
|
||||||
|
except Exception:
|
||||||
|
sys.stdout.write(' error\n')
|
||||||
|
raise
|
||||||
|
sys.stdout.write(' done\n')
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue