fnp
/
redakcja.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Ignore compressed statics.
[redakcja.git]
/
apps
/
wiki
/
models.py
diff --git
a/apps/wiki/models.py
b/apps/wiki/models.py
index
2809dbc
..
8ec4d32
100644
(file)
--- a/
apps/wiki/models.py
+++ b/
apps/wiki/models.py
@@
-1,44
+1,71
@@
+import re
import vstorage
from vstorage import DocumentNotFound
from wiki import settings
import vstorage
from vstorage import DocumentNotFound
from wiki import settings
-
class DocumentStorage(object):
def __init__(self, path):
self.vstorage = vstorage.VersionedStorage(path)
class DocumentStorage(object):
def __init__(self, path):
self.vstorage = vstorage.VersionedStorage(path)
-
- def get(self, name, revision
=
None):
+
+ def get(self, name, revision
=
None):
if revision is None:
text = self.vstorage.page_text(name)
else:
text = self.vstorage.revision_text(name, revision)
if revision is None:
text = self.vstorage.page_text(name)
else:
text = self.vstorage.revision_text(name, revision)
- return Document(self, name
=name, text=
text)
-
+ return Document(self, name
= name, text =
text)
+
def put(self, document, author, comment, parent):
def put(self, document, author, comment, parent):
- self.vstorage.save_text(document.name, document.text, author, comment, parent)
+ self.vstorage.save_text(
+ title = document.name,
+ text = document.text,
+ author = author,
+ comment = comment,
+ parent = parent)
def delete(self, name, author, comment):
self.vstorage.delete_page(name, author, comment)
def all(self):
return list(self.vstorage.all_pages())
def delete(self, name, author, comment):
self.vstorage.delete_page(name, author, comment)
def all(self):
return list(self.vstorage.all_pages())
+
+ def history(self, title):
+ return list(self.vstorage.page_history(title))
def _info(self, name):
return self.vstorage.page_meta(name)
class Document(object):
def _info(self, name):
return self.vstorage.page_meta(name)
class Document(object):
+ META_REGEX = re.compile(r'\s*<!--\s(.*?)-->', re.DOTALL | re.MULTILINE)
+
def __init__(self, storage, **kwargs):
self.storage = storage
for attr, value in kwargs.iteritems():
setattr(self, attr, value)
def __init__(self, storage, **kwargs):
self.storage = storage
for attr, value in kwargs.iteritems():
setattr(self, attr, value)
-
+
def revision(self):
try:
return self.storage._info(self.name)[0]
except DocumentNotFound:
def revision(self):
try:
return self.storage._info(self.name)[0]
except DocumentNotFound:
- return -1
+ return - 1
+
+ @property
+ def plain_text(self):
+ return re.sub(self.META_REGEX, '', self.text, 1)
+
+ def meta(self):
+ result = {}
+ m = re.match(self.META_REGEX, self.text)
+ if m:
+ for line in m.group(1).split('\n'):
+ try:
+ k, v = line.split(':', 1)
+ result[k.strip()] = v.strip()
+ except ValueError:
+ continue
-storage = DocumentStorage(settings.REPOSITORY_PATH)
+ return result
+def getstorage():
+ return DocumentStorage(settings.REPOSITORY_PATH)