changeset 256:b61ed0f2c4da

Yet another slight perf/mem improvement for the tags per file sample
author Artem Tikhomirov <tikhomirov.artem@gmail.com>
date Tue, 16 Aug 2011 15:45:47 +0200 (2011-08-16)
parents 5a6ab50b4cbf
children f39fb6b3cc76
files test/org/tmatesoft/hg/test/MapTagsToFileRevisions.java
diffstat 1 files changed, 16 insertions(+), 5 deletions(-) [+]
line wrap: on
line diff
--- a/test/org/tmatesoft/hg/test/MapTagsToFileRevisions.java	Tue Aug 16 14:33:11 2011 +0200
+++ b/test/org/tmatesoft/hg/test/MapTagsToFileRevisions.java	Tue Aug 16 15:45:47 2011 +0200
@@ -2,6 +2,7 @@
 
 import java.io.File;
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.HashMap;
 import java.util.LinkedList;
 import java.util.List;
@@ -62,19 +63,26 @@
 		System.out.printf("Prepared tag revisions to analyze: %d ms\n", System.currentTimeMillis() - start);
 		//
 		repository.getManifest().walk(new HgManifest.Inspector() {
-			private final ArrayList<Integer> tagIndexAtRev = new ArrayList<Integer>();
+			private int[] tagIndexAtRev = new int[4]; // it's unlikely there would be a lot of tags associated with a given cset
 			private final Pool<String> filenamePool = new Pool<String>();
 			private final Pool<Nodeid> nodeidPool = new Pool<Nodeid>();
 
 			public boolean begin(int mainfestRevision, Nodeid nid, int changelogRevision) {
 				Nodeid cset = clogrmap.revision(changelogRevision);
-				tagIndexAtRev.clear();
-				for (int i = 0; i < allTags.length; i++) {
+				Arrays.fill(tagIndexAtRev, -1);
+				for (int i = 0, x = 0; i < allTags.length; i++) {
 					if (cset.equals(allTags[i].revision())) {
-						tagIndexAtRev.add(i);
+						tagIndexAtRev[x++] = i;
+						if (x == tagIndexAtRev.length) {
+							// expand twice as much
+							int[] expanded = new int[x << 1];
+							System.arraycopy(tagIndexAtRev, 0, expanded, 0, x);
+							expanded[x] = -1; // just in case there'd be no more tags associated with this cset
+							tagIndexAtRev = expanded;
+						}
 					}
 				}
-				if (tagIndexAtRev.isEmpty()) {
+				if (tagIndexAtRev[0] == -1) {
 					System.out.println("Can't happen, provided we iterate over revisions with tags only");
 				}
 				return true;
@@ -88,6 +96,9 @@
 					file2rev2tag.put(fname, m = new Nodeid[allTags.length]);
 				}
 				for (int tagIndex : tagIndexAtRev) {
+					if (tagIndex == -1) {
+						break;
+					}
 					if (m[tagIndex] != null) {
 						System.out.printf("There's another revision (%s) associated with tag %s already while we try to associate %s\n", m[tagIndex].shortNotation(), allTags[tagIndex].name(), nid.shortNotation());
 					}