Mercurial > python-hglib
changeset 90:b894c2222dff
client: replace usage of namedtuple for python 2.4 compatibility
author | Idan Kamara <idankk86@gmail.com> |
---|---|
date | Thu, 22 Dec 2011 19:12:39 +0200 |
parents | 351d2799f145 |
children | 0383fc37102b |
files | hglib/client.py |
diffstat | 1 files changed, 30 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/hglib/client.py Wed Nov 23 09:57:37 2011 -0500 +++ b/hglib/client.py Thu Dec 22 19:12:39 2011 +0200 @@ -1,17 +1,42 @@ -import subprocess, os, struct, cStringIO, collections, re +import subprocess, os, struct, cStringIO, re import hglib, error, util, templates, merge from util import cmdbuilder +class revision(tuple): + def __new__(cls, rev, node, tags, branch, author, desc): + return tuple.__new__(cls, (rev, node, tags, branch, author, desc)) + + @property + def rev(self): + return self[0] + + @property + def node(self): + return self[1] + + @property + def tags(self): + return self[2] + + @property + def branch(self): + return self[3] + + @property + def author(self): + return self[4] + + @property + def desc(self): + return self[5] + class hgclient(object): inputfmt = '>I' outputfmt = '>cI' outputfmtsize = struct.calcsize(outputfmt) retfmt = '>i' - revision = collections.namedtuple('revision', 'rev, node, tags, ' - 'branch, author, desc') - def __init__(self, path, encoding, configs): args = [hglib.HGPATH, 'serve', '--cmdserver', 'pipe', '--config', 'ui.interactive=True'] @@ -68,7 +93,7 @@ def _parserevs(self, splitted): ''' splitted is a list of fields according to our rev.style, where each 6 fields compose one revision. ''' - return [self.revision._make(rev) for rev in util.grouper(6, splitted)] + return [revision(*rev) for rev in util.grouper(6, splitted)] def runcommand(self, args, inchannels, outchannels): def writeblock(data):