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. */ 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