Mercurial > jhg
view src/com/tmate/hgkit/ll/HgManifest.java @ 55:05829a70b30b
Status operation extracted into separate, cache-friendly class
| author | Artem Tikhomirov <tikhomirov.artem@gmail.com> | 
|---|---|
| date | Mon, 17 Jan 2011 04:45:09 +0100 | 
| parents | b2251b7a9823 | 
| children | 9429c7bd1920 | 
line wrap: on
 line source
/* * Copyright (c) 2010, 2011 Artem Tikhomirov */ package com.tmate.hgkit.ll; /** * * @author artem */ public class HgManifest extends Revlog { /*package-local*/ HgManifest(HgRepository hgRepo, RevlogStream content) { super(hgRepo, content); } public void walk(int start, int end, final Inspector inspector) { Revlog.Inspector insp = new Revlog.Inspector() { private boolean gtg = true; // good to go public void next(int revisionNumber, int actualLen, int baseRevision, int linkRevision, int parent1Revision, int parent2Revision, byte[] nodeid, byte[] data) { if (!gtg) { return; } gtg = gtg && inspector.begin(revisionNumber, new Nodeid(nodeid, true)); int i; String fname = null; String flags = null; Nodeid nid = null; for (i = 0; gtg && i < actualLen; i++) { int x = i; for( ; data[i] != '\n' && i < actualLen; i++) { if (fname == null && data[i] == 0) { fname = new String(data, x, i - x); x = i+1; } } if (i < actualLen) { assert data[i] == '\n'; int nodeidLen = i - x < 40 ? i-x : 40; nid = Nodeid.fromAscii(data, x, nodeidLen); if (nodeidLen + x < i) { // 'x' and 'l' for executable bits and symlinks? // hg --debug manifest shows 644 for each regular file in my repo flags = new String(data, x + nodeidLen, i-x-nodeidLen); } gtg = gtg && inspector.next(nid, fname, flags); } nid = null; fname = flags = null; } gtg = gtg && inspector.end(revisionNumber); } }; content.iterate(start, end, true, insp); } public interface Inspector { boolean begin(int revision, Nodeid nid); boolean next(Nodeid nid, String fname, String flags); boolean end(int revision); } }
