tikhomirov@373: /* tikhomirov@626: * Copyright (c) 2012-2013 TMate Software Ltd tikhomirov@373: * tikhomirov@373: * This program is free software; you can redistribute it and/or modify tikhomirov@373: * it under the terms of the GNU General Public License as published by tikhomirov@373: * the Free Software Foundation; version 2 of the License. tikhomirov@373: * tikhomirov@373: * This program is distributed in the hope that it will be useful, tikhomirov@373: * but WITHOUT ANY WARRANTY; without even the implied warranty of tikhomirov@373: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the tikhomirov@373: * GNU General Public License for more details. tikhomirov@373: * tikhomirov@373: * For information on how to redistribute this software under tikhomirov@373: * the terms of a license other than GNU General Public License tikhomirov@373: * contact TMate Software at support@hg4j.com tikhomirov@373: */ tikhomirov@373: package org.tmatesoft.hg.repo; tikhomirov@373: tikhomirov@373: tikhomirov@373: /** tikhomirov@442: * Names of some Mercurial configuration/service files. tikhomirov@442: * tikhomirov@373: * @author Artem Tikhomirov tikhomirov@373: * @author TMate Software Ltd. tikhomirov@373: */ tikhomirov@373: public enum HgRepositoryFiles { tikhomirov@373: tikhomirov@647: HgIgnore(Home.Root, ".hgignore"), HgTags(Home.Root, ".hgtags"), HgEol(Home.Root, ".hgeol"), tikhomirov@647: Dirstate(Home.Repo, "dirstate"), HgLocalTags(Home.Repo, "localtags"), tikhomirov@647: HgSub(Home.Root, ".hgsub"), HgSubstate(Home.Root, ".hgsubstate"), tikhomirov@647: LastMessage(Home.Repo, "last-message.txt"), tikhomirov@647: Bookmarks(Home.Repo, "bookmarks"), BookmarksCurrent(Home.Repo, "bookmarks.current"), tikhomirov@647: Branch(Home.Repo, "branch"), tikhomirov@647: UndoBranch(Home.Repo, "undo.branch"), UndoDirstate(Home.Repo, "undo.dirstate"), tikhomirov@647: Phaseroots(Home.Store, "phaseroots"), FNCache(Home.Store, "fncache"), tikhomirov@647: WorkingCopyLock(Home.Repo, "wlock"), StoreLock(Home.Store, "lock"); tikhomirov@647: tikhomirov@647: /** tikhomirov@647: * Possible file locations tikhomirov@647: */ tikhomirov@647: public enum Home { tikhomirov@647: Root, Repo, Store tikhomirov@647: } tikhomirov@373: tikhomirov@482: private final String fname; tikhomirov@647: private final Home residesIn; tikhomirov@373: tikhomirov@647: private HgRepositoryFiles(Home home, String filename) { tikhomirov@482: fname = filename; tikhomirov@647: residesIn = home; tikhomirov@482: } tikhomirov@482: tikhomirov@482: /** tikhomirov@647: * Path to the file, relative to the repository root. tikhomirov@482: * tikhomirov@482: * For repository files that reside in working directory, return their location relative to the working dir. tikhomirov@647: * For files that reside under repository root, path returned includes '.hg/' prefix. tikhomirov@647: * For files from {@link Home#Store} storage area, path starts with '.hg/store/', although actual use of 'store' folder tikhomirov@647: * is controlled by repository requirements. Returned value shall be deemed as 'most likely' path in a general environment. tikhomirov@482: * @return file location, never null tikhomirov@482: */ tikhomirov@373: public String getPath() { tikhomirov@647: switch (residesIn) { tikhomirov@647: case Store : return ".hg/store/" + getName(); tikhomirov@647: case Repo : return ".hg/" + getName(); tikhomirov@647: default : return getName(); tikhomirov@647: } tikhomirov@482: } tikhomirov@482: tikhomirov@482: /** tikhomirov@482: * File name without any path information tikhomirov@482: * @return file name, never null tikhomirov@482: */ tikhomirov@482: public String getName() { tikhomirov@373: return fname; tikhomirov@373: } tikhomirov@482: tikhomirov@482: /** tikhomirov@482: * Files that reside under working directory may be accessed like: tikhomirov@482: *
tikhomirov@482: 	 *   HgRepository hgRepo = ...;
tikhomirov@482: 	 *   File f = new File(hgRepo.getWorkingDir(), HgRepositoryFiles.HgIgnore.getPath())
tikhomirov@482: 	 * 
tikhomirov@482: * @return true if file lives in working tree tikhomirov@482: */ tikhomirov@482: public boolean residesUnderWorkingDir() { tikhomirov@647: return residesIn == Home.Root; tikhomirov@482: } tikhomirov@482: tikhomirov@482: /** tikhomirov@482: * @return true if file lives under '.hg/' tikhomirov@482: */ tikhomirov@482: public boolean residesUnderRepositoryRoot() { tikhomirov@647: return residesIn == Home.Repo; tikhomirov@647: } tikhomirov@647: tikhomirov@647: /** tikhomirov@647: * Identify a root the file lives under tikhomirov@647: */ tikhomirov@647: public Home getHome() { tikhomirov@647: return residesIn; tikhomirov@482: } tikhomirov@373: }