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. */
public static final Pattern COMMIT_HASH_PATTERN = Pattern.compile("^[\\da-f]{40}$");
/** Base name for anonymous branches. */
public static final String ANONYMOUS_BRANCH_NAME = "_anonymous_";
/** Head refs used for merge requests. */
public static final String MERGE_REQUEST_REFS_PREFIX = "refs/merge-requests/";
/**
* 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;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy