Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
tree: 02e581bb92
Fetching contributors…

Cannot retrieve contributors at this time

151 lines (124 sloc) 4.864 kb
import json
import hashlib
from sys import exit
from os import path, makedirs
from datetime import datetime
from time import time
from ConfigParser import RawConfigParser
from whatidid.objects import Command, BaseUpdateCommand, BaseTodoCommand
class InitCommand(Command):
''' Implements a command for setting everything up.
'''
def __init__(self, **kwargs):
super(InitCommand, self).__init__(**kwargs)
def run(self):
configrc = '%s/.widrc' % (path.expanduser('~'))
if not path.exists(configrc):
print u'There is no ~/.widrc file, createing one.'
config = RawConfigParser()
config.add_section('storage')
config.set('storage', 'path', path.expanduser('~'))
config.add_section('formats')
config.set('formats', 'update-show-format', '%A')
with open(configrc, 'wb') as configfile:
config.write(configfile)
class UpdateCommand(BaseUpdateCommand):
''' Implements a class for the update command.
'''
def __init__(self, **kwargs):
self.message = kwargs.get('message', None)
self.tags = kwargs.get('tags', [])
super(UpdateCommand, self).__init__(**kwargs)
def run(self):
data_path = self.get_data_path(self.type)
try:
with open(data_path, 'rb') as fp:
existing_data = json.load(fp)
except ValueError:
existing_data = []
if self.message:
m = hashlib.md5()
created = int(time())
m.update(str(created) + self.message)
existing_data.append({
'id': m.hexdigest(),
'created': created,
'tags': self.tags,
'message': self.message}
)
with open(data_path, 'wb') as fp:
data = json.dump(existing_data, fp, sort_keys=True, indent=4)
else:
print u'No message specified'
exit(1)
class UpdateShowCommand(BaseUpdateCommand):
''' Implements a class for the update-show command.
'''
def __init__(self, **kwargs):
year, current_week, weekday = datetime.now().isocalendar()
week = kwargs.get('week', None)
if week is None:
week = current_week
self.week = int(week)
super(UpdateShowCommand, self).__init__(**kwargs)
def run(self):
data_path = self.get_data_path(self.type, self.week)
try:
with open(data_path, 'rb') as fp:
existing_data = json.load(fp)
for update in existing_data:
out = u'%s' % (datetime.fromtimestamp(int(update['created'])).strftime(self.update_show_format))
if update['tags']:
print u'%s: %s: %s' % (out, ','.join(update['tags']), update['message'])
else:
print u'%s: %s' % (out, update['message'])
except ValueError:
print u'There are no messages.'
class TodoCommand(BaseTodoCommand):
''' Implements a class for the todo command.
'''
def __init__(self, **kwargs):
self.message = kwargs.get('message', None)
self.tags = kwargs.get('tags', [])
super(TodoCommand, self).__init__(**kwargs)
def run(self):
data_path = self.get_data_path(self.type)
try:
with open(data_path, 'rb') as fp:
existing_data = json.load(fp)
except ValueError:
existing_data = []
if self.message:
m = hashlib.md5()
created = int(time())
m.update(str(created) + self.message)
existing_data.append({
'id': m.hexdigest(),
'created': created,
'tags': self.tags,
'message': self.message}
)
with open(data_path, 'wb') as fp:
data = json.dump(existing_data, fp, sort_keys=True, indent=4)
else:
print u'No todo item specified'
exit(1)
class TodoShowCommand(BaseTodoCommand):
''' Impelments a class for the todo-show command.
'''
def __init__(self, **kwargs):
year, current_week, weekday = datetime.now().isocalendar()
week = kwargs.get('week', None)
if week is None:
week = current_week
self.week = int(week)
super(TodoShowCommand, self).__init__(**kwargs)
def run(self):
data_path = self.get_data_path(self.type, self.week)
try:
with open(data_path, 'rb') as fp:
existing_data = json.load(fp)
for update in existing_data:
print u'%s: %s' % (update['id'], update['message'],)
except ValueError:
print u'There are no todo items.'
Jump to Line
Something went wrong with that request. Please try again.