Mercurial > hg4j
diff src/org/tmatesoft/hg/repo/ext/HgExtensionsManager.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 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/org/tmatesoft/hg/repo/ext/HgExtensionsManager.java Mon Oct 29 19:04:13 2012 +0100 @@ -0,0 +1,69 @@ +/* + * 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 org.tmatesoft.hg.internal.Internals; +import org.tmatesoft.hg.repo.HgRepoConfig; + +/** + * + * @author Artem Tikhomirov + * @author TMate Software Ltd. + */ +public abstract class HgExtensionsManager { + + public enum HgExt { + MQ ("mq"), Rebase("rebase"); + + private final String mercurialExtName; + + private HgExt(String nativeName) { + mercurialExtName = nativeName; + } + + String getNativeName() { + return mercurialExtName; + } + } + + private final Internals repo; + private MqManager mqExt; + private Rebase rebaseExt; + + protected HgExtensionsManager(Internals internalRepo) { + repo = internalRepo; + } + + public boolean isEnabled(HgExt e) { + HgRepoConfig cfg = repo.getRepo().getConfiguration(); + return cfg.getExtensions().isEnabled(e.getNativeName()); + } + + public Rebase getRebaseExtension() { + if (rebaseExt == null && isEnabled(HgExt.Rebase)) { + rebaseExt = new Rebase(repo); + } + return rebaseExt; + } + + public MqManager getMQ() { + if (mqExt == null && isEnabled(HgExt.MQ)) { + mqExt = new MqManager(repo); + } + return mqExt; + } +}