diff src/org/tmatesoft/hg/repo/ext/Rebase.java @ 501:d2f6ab541330

Change the way extensions are accessed (with ExtensionsManager now), add preliminary Rebase extension support
author Artem Tikhomirov <tikhomirov.artem@gmail.com>
date Mon, 29 Oct 2012 19:04:13 +0100 (2012-10-29)
parents
children 6526d8adbc0f
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/org/tmatesoft/hg/repo/ext/Rebase.java	Mon Oct 29 19:04:13 2012 +0100
@@ -0,0 +1,140 @@
+/*
+ * Copyright (c) 2012 TMate Software Ltd
+ *  
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; version 2 of the License.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * For information on how to redistribute this software under
+ * the terms of a license other than GNU General Public License
+ * contact TMate Software at support@hg4j.com
+ */
+package org.tmatesoft.hg.repo.ext;
+
+import java.io.File;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.NoSuchElementException;
+
+import org.tmatesoft.hg.core.HgBadNodeidFormatException;
+import org.tmatesoft.hg.core.HgIOException;
+import org.tmatesoft.hg.core.Nodeid;
+import org.tmatesoft.hg.internal.Internals;
+import org.tmatesoft.hg.internal.LineReader;
+import org.tmatesoft.hg.repo.HgInvalidFileException;
+import org.tmatesoft.hg.repo.HgInvalidStateException;
+
+/**
+ * Support for standard Rebase extension.
+ * 
+ * @see http://mercurial.selenic.com/wiki/RebaseExtension
+ * @since 1.1
+ * @author Artem Tikhomirov
+ * @author TMate Software Ltd.
+ */
+public class Rebase {
+	private Internals repo;
+	private Nodeid workingDirParent;
+	private Nodeid destRevision;
+	private Nodeid externalParent;
+	private Map<Nodeid, Nodeid> state;
+	private boolean collapse;
+	private boolean keepOriginalRevisions;
+	private boolean keepBranchNames;
+	
+	/*package-local*/ Rebase(Internals internalRepo) {
+		repo = internalRepo;
+	}
+
+	public Rebase refresh() throws HgIOException {
+		workingDirParent = null;
+		destRevision = null;
+		externalParent = null;
+		state = null;
+		File f = repo.getFileFromRepoDir("rebasestate");
+		if (!f.exists()) {
+			return this;
+		}
+		state = new HashMap<Nodeid, Nodeid>();
+		try {
+			LineReader lr = new LineReader(f, repo.getSessionContext().getLog());
+			ArrayList<String> contents = new ArrayList<String>();
+			lr.read(new LineReader.SimpleLineCollector(), contents);
+			Iterator<String> it = contents.iterator();
+			workingDirParent = Nodeid.fromAscii(it.next());
+			destRevision = Nodeid.fromAscii(it.next());
+			externalParent = Nodeid.fromAscii(it.next());
+			collapse = "1".equals(it.next());
+			keepOriginalRevisions = "1".equals(it.next());
+			keepBranchNames = "1".equals(it.next());
+			final String nullmerge = "-2";
+			while (it.hasNext()) {
+				String line = it.next();
+				int x = line.indexOf(':');
+				if (x == -1) {
+					throw new HgInvalidStateException(line);
+				}
+				Nodeid oldRev = Nodeid.fromAscii(line.substring(0, x));
+				Nodeid newRev;
+				if (line.regionMatches(x+1, nullmerge, 0, nullmerge.length())) {
+					newRev = null;
+				} else {
+					newRev = Nodeid.fromAscii(line.substring(x+1));
+				}
+				state.put(oldRev, newRev);
+			}
+		} catch (NoSuchElementException ex) {
+			throw new HgIOException("Bad format of rebase state file", f);
+		} catch (HgBadNodeidFormatException ex) {
+			throw new HgIOException("Bad format of rebase state file", ex, f);
+		} catch (HgInvalidFileException ex) {
+			throw new HgIOException("Bad format of rebase state file", ex, f);
+		}
+		return this;
+	}
+	
+	/**
+	 * Tells whether rebase process was interrupted to manually resolve a merge 
+	 * and can be resumed or aborted.
+	 * 
+	 * @return <code>true</code> when rebase is in progress 
+	 */
+	public boolean isRebaseInProgress() {
+		return state != null;
+	}
+
+	public Nodeid getWorkingDirParent() {
+		assert isRebaseInProgress();
+		return workingDirParent;
+	}
+	
+	public Nodeid getTarget() {
+		assert isRebaseInProgress();
+		return destRevision;
+	}
+	
+	public Nodeid getExternalParent() {
+		assert isRebaseInProgress();
+		assert collapse;
+		return externalParent;
+	}
+	
+	public boolean isCollapse() {
+		return collapse;
+	}
+	
+	public boolean isKeepOriginalRevisions() {
+		return keepOriginalRevisions;
+	}
+
+	public boolean isKeepBranchNames() {
+		return keepBranchNames;
+	}
+}