import mercurial.hg
import mercurial.revlog
import mercurial.util
+from mercurial.context import workingctx
from vstorage.hgui import SilentUI
self.repo = mercurial.hg.repository(self.ui, self.repo_path)
def _file_path(self, title, type='.xml'):
- return os.path.join(self.path, urlquote(title, safe='')) + type
+ """ Return plain version if exists in repo, add extension otherwise. """
+ path = os.path.join(self.path, urlquote(title, safe=''))
+ if type and self._title_to_file(title, '') not in self.repo['tip']:
+ path += type
+ return path
def _title_to_file(self, title, type=".xml"):
- return os.path.join(self.repo_prefix, urlquote(title, safe='')) + type
+ """ Return plain version if exists in repo, add extension otherwise. """
+ path = os.path.join(self.repo_prefix, urlquote(title, safe=''))
+ if type and path not in self.repo['tip']:
+ path += type
+ return path
def _file_to_title(self, filename):
assert filename.startswith(self.repo_prefix)
filectx_tip = changectx[repo_file]
current_page_rev = filectx_tip.filerev()
except mercurial.revlog.LookupError:
- self.repo.add([repo_file])
+ workingctx(self.repo).add([repo_file])
current_page_rev = -1
if parent is not None and current_page_rev != parent:
os.unlink(file_path)
except OSError:
pass
- self.repo.remove([repo_file])
+ workingctx(self.repo).remove([repo_file])
self._commit([repo_file], text, user)
def page_text(self, title, revision=None):