You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

100 lines
2.8 KiB

11 years ago
import copy
import collections
11 years ago
import datetime
11 years ago
from . import bibstruct
11 years ago
#DEFAULT_META = collections.OrderedDict([('docfile', None), ('tags', set()), ('added', )])
DEFAULT_META = {'docfile': None, 'tags': set(), 'added': None}
class Paper(object):
11 years ago
""" Paper class.
11 years ago
The object is not responsible of any disk I/O.
self.bibdata is a dictionary of bibligraphic fields
11 years ago
self.metadata is a dictionary
11 years ago
The paper class provides methods to access the fields for its metadata
in a pythonic manner.
"""
11 years ago
def __init__(self, bibdata, citekey=None, metadata=None):
self.citekey = citekey
self.metadata = metadata
11 years ago
self.bibdata = bibdata
_, self.bibentry = bibstruct.get_entry(self.bibdata)
if 'id' in self.bibentry:
self.bibentry.pop('id')
11 years ago
if self.metadata is None:
self.metadata = copy.deepcopy(DEFAULT_META)
if self.citekey is None:
self.citekey = bibstruct.extract_citekey(self.bibdata)
11 years ago
bibstruct.check_citekey(self.citekey)
self.metadata['tags'] = set(self.metadata.get('tags', []))
def __eq__(self, other):
return (isinstance(self, Paper) and type(other) is type(self)
11 years ago
and self.bibdata == other.bibdata
and self.metadata == other.metadata
11 years ago
and self.citekey == other.citekey)
def __repr__(self):
return 'Paper(%s, %s, %s)' % (
self.citekey, self.bibentry, self.metadata)
def __deepcopy__(self, memo):
return Paper(citekey =self.citekey,
metadata=copy.deepcopy(self.metadata, memo),
bibdata=copy.deepcopy(self.bibdata, memo))
def __copy__(self):
11 years ago
return Paper(citekey =self.citekey,
metadata=self.metadata,
bibdata=self.bibdata)
def deepcopy(self):
return self.__deepcopy__({})
11 years ago
# docpath
11 years ago
@property
def docpath(self):
return self.metadata.get('docfile', '')
11 years ago
@docpath.setter
def docpath(self, path):
"""Does not verify if the path exists."""
self.metadata['docfile'] = path
11 years ago
# tags
@property
def tags(self):
return self.metadata['tags']
@tags.setter
def tags(self, value):
if not hasattr(value, '__iter__'):
raise ValueError('tags must be iterables')
self.metadata['tags'] = set(value)
def add_tag(self, tag):
self.tags.add(tag)
def remove_tag(self, tag):
"""Remove a tag from a paper if present."""
self.tags.discard(tag)
11 years ago
# added date
@property
def added(self):
datetime.datetime.strptime(self.metadata['added'], '%Y-%m-%d %H:%M:%S')
@added.setter
def added(self, value):
self.metadata['added'] = value.strftime('%Y-%m-%d %H:%M:%S')