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

org.apache.maven.scm.provider.ScmUrlUtils Maven / Gradle / Ivy

There is a newer version: 2.1.0
Show newest version
package org.apache.maven.scm.provider;

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.
 */

import java.util.ArrayList;
import java.util.List;

/**
 * A utility class that validates and parses scm url:s. The code here is
 * not scm provider specific.
 * 

* If you need methods that work for a specific scm provider, please create a * similar class for that provider. E.g. create the class CvsScmUrlUtils if * you need cvs specific checking/parsing. *

* * @author Dennis Lundberg * */ public abstract class ScmUrlUtils { private static final String ILLEGAL_SCM_URL = "The scm url must be on the form 'scm:' " + "where can be either ':' or '|'."; /** * Get the delimiter used in the scm url. * * @param scmUrl A valid scm url to parse * @return The delimiter used in the scm url */ public static String getDelimiter( String scmUrl ) { scmUrl = scmUrl.substring( 4 ); int index = scmUrl.indexOf( '|' ); if ( index == -1 ) { index = scmUrl.indexOf( ':' ); if ( index == -1 ) { throw new IllegalArgumentException( "The scm url does not contain a valid delimiter." ); } } return scmUrl.substring( index, index + 1 ); } /** * Get the scm provider from the scm url. * * @param scmUrl A valid scm url to parse * @return The scm provider from the scm url */ public static String getProvider( String scmUrl ) { String delimiter = getDelimiter( scmUrl ); scmUrl = scmUrl.substring( 4 ); int firstDelimiterIndex = scmUrl.indexOf( delimiter ); return scmUrl.substring( 0, firstDelimiterIndex ); } /** * Get the provider specific part of the scm url. * * @param scmUrl A valid scm url to parse * @return The provider specific part of the scm url */ public static String getProviderSpecificPart( String scmUrl ) { String delimiter = getDelimiter( scmUrl ); scmUrl = scmUrl.substring( 4 ); int firstDelimiterIndex = scmUrl.indexOf( delimiter ); return scmUrl.substring( firstDelimiterIndex + 1 ); } /** * Validate that the scm url is in the correct format. *

* Note: does not validate scm provider specific format. *

* * @param scmUrl The scm url to validate * @return true if the scm url is in the correct format, * otherwise false */ public static boolean isValid( String scmUrl ) { List messages = validate( scmUrl ); return messages.isEmpty(); } /** * Validate that the scm url is in the correct format. *

* Note: does not validate scm provider specific format. *

* * @param scmUrl The scm url to validate * @return A List that contains the errors that occured */ public static List validate( String scmUrl ) { List messages = new ArrayList(); if ( scmUrl == null ) { messages.add( "The scm url cannot be null." ); return messages; } if ( !scmUrl.startsWith( "scm:" ) ) { messages.add( "The scm url must start with 'scm:'." ); return messages; } if ( scmUrl.length() < 6 ) { messages.add( ILLEGAL_SCM_URL ); return messages; } try { getDelimiter( scmUrl ); } catch ( IllegalArgumentException e ) { messages.add( e.getMessage() ); } return messages; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy