All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.conqat.engine.index.shared.GitRefUtils Maven / Gradle / Ivy

/*
 * Copyright (c) CQSE GmbH
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.conqat.engine.index.shared;

import java.util.regex.Pattern;

/**
 * Utility methods for working with Git refs.
 */
public class GitRefUtils {

	/**
	 * The Git ref name for the HEAD ref. Note that it's very important to distinguish the meaning of
	 * this ref for different kinds of Git repositories when determining the default branch (i.e. branch
	 * checked out upon cloning the repository).
*
* For a regular local Git clone, which doesn't use the {@code --bare} or {@code --mirror} command * line flags, the HEAD ref points to the revision of the currently checked out branch, tag or * specific revision.
*
* For a Git checkout with the command line flags {@code --bare} or {@code --mirror} the HEAD points * to the revision of the default branch.
*
* If refs are loaded from a remote Git using the JGit LsRemoteCommand the (remote) HEAD points to * the revision of the default branch.
*
* However, for any of the different kinds of Git repositories there may be multiple branch head * refs, pointing to the same revision as the HEAD ref. Hence the ref for the default branch isn't * always uniquely defined and there may be multiple options for choosing it for a Git * repository.
*
* There exists a Git capability (see * StackOverFlow, * Official * Github Release Notes) for determining the branch head ref to which the remote HEAD also * points. However JGit doesn't support this capability and we're currently limited to guessing the * default branch names. */ public static final String HEAD_REF_NAME = "HEAD"; /** Prefix for the ref name for Git branch heads. */ public static final String BRANCH_HEAD_REF_PREFIX = "refs/heads/"; /** Prefix for refs to remote branches */ public static final String REFERENCE_REMOTES_PREFIX = "refs/remotes/origin/"; /** Name of the master branch. */ public static final String MASTER_BRANCH = "master"; /** Pattern for a SHA-1 hash which identifies a Git commit uniquely. */ private static final Pattern COMMIT_HASH_PATTERN = Pattern.compile("^[\\da-f]{40}$"); /** Base name for anonymous branches. */ private static final String ANONYMOUS_BRANCH_NAME = "_anonymous_"; /** * Returns whether the given revision is a valid commit hash or the HEAD ref. * * @see #HEAD_REF_NAME */ public static boolean isCommitHashOrHeadRef(String revision) { return revision.equals(HEAD_REF_NAME) || COMMIT_HASH_PATTERN.matcher(revision).matches(); } /** * Returns true, if and only if the branch name starts with the {@link #ANONYMOUS_BRANCH_NAME}. */ public static boolean isAnonymousBranchName(String branchName) { return branchName != null && branchName.startsWith(ANONYMOUS_BRANCH_NAME); } /** Creates the name of a ref for a branch name. */ public static String createBranchHeadRefName(String branchName) { return BRANCH_HEAD_REF_PREFIX + branchName; } /** Creates an anonymous branch name based on the given commit hash. */ public static String createAnonymousBranchName(String commitHash) { return ANONYMOUS_BRANCH_NAME + commitHash; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy