/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License (the "License").
* You may not use this file except in compliance with the License.
*
* See LICENSE.txt included in this distribution for the specific
* language governing permissions and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at LICENSE.txt.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved.
*/
package org.opensolaris.opengrok.history;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.opensolaris.opengrok.configuration.RuntimeEnvironment;
import org.opensolaris.opengrok.logger.LoggerFactory;
/**
* This is a factory class for the different repositories.
*
* @author austvik
*/
public final class RepositoryFactory {
private static final Logger LOGGER = LoggerFactory.getLogger(RepositoryFactory.class);
private static final Repository repositories[] = {
new MercurialRepository(),
new AccuRevRepository(),
new BazaarRepository(),
new GitRepository(),
new MonotoneRepository(),
new SubversionRepository(),
new SCCSRepository(),
new RazorRepository(),
new ClearCaseRepository(),
new PerforceRepository(),
new RCSRepository(),
new CVSRepository(),
new RepoRepository(),
new SSCMRepository(),};
private RepositoryFactory() {
// Factory class, should not be constructed
}
/**
* Get a list of all available repository handlers.
*
* @return a list which contains none-{@code null} values, only.
*/
public static List<Class<? extends Repository>> getRepositoryClasses() {
ArrayList<Class<? extends Repository>> list
= new ArrayList<>(repositories.length);
for (int i = repositories.length - 1; i >= 0; i--) {
list.add(repositories[i].getClass());
}
return list;
}
/**
* Returns a repository for the given file, or null if no repository was
* found.
*
* @param file File that might contain a repository
* @return Correct repository for the given file
* @throws java.lang.InstantiationException in case we cannot create the
* repo object
* @throws java.lang.IllegalAccessException in case no permissions to repo
* file
*/
public static Repository getRepository(File file) throws InstantiationException, IllegalAccessException {
RuntimeEnvironment env = RuntimeEnvironment.getInstance();
Repository res = null;
for (Repository rep : repositories) {
if (rep.isRepositoryFor(file)) {
res = rep.getClass().newInstance();
try {
res.setDirectoryName(file.getCanonicalPath());
} catch (IOException e) {
LOGGER.log(Level.SEVERE,
"Failed to get canonical path name for "
+ file.getAbsolutePath(), e);
}
if (!res.isWorking()) {
LOGGER.log(
Level.WARNING,
"{0} not working (missing binaries?): {1}",
new Object[]{
res.getClass().getSimpleName(),
file.getPath()
});
}
if (res.getType() == null || res.getType().length() == 0) {
res.setType(res.getClass().getSimpleName());
}
if (res.getParent() == null || res.getParent().length() == 0) {
try {
res.setParent(res.determineParent());
} catch (IOException ex) {
LOGGER.log(Level.WARNING,
"Failed to get parent for {0}: {1}",
new Object[]{file.getAbsolutePath(), ex});
}
}
if (res.getBranch() == null || res.getBranch().length() == 0) {
try {
res.setBranch(res.determineBranch());
} catch (IOException ex) {
LOGGER.log(Level.WARNING,
"Failed to get branch for {0}: {1}",
new Object[]{file.getAbsolutePath(), ex});
}
}
if (res.getCurrentVersion() == null || res.getCurrentVersion().length() == 0) {
try {
res.setCurrentVersion(res.determineCurrentVersion());
} catch (IOException ex) {
LOGGER.log(Level.WARNING,
"Failed to determineCurrentVersion for {0}: {1}",
new Object[]{file.getAbsolutePath(), ex});
}
}
// If this repository displays tags only for files changed by tagged
// revision, we need to prepare list of all tags in advance.
if (env.isTagsEnabled() && res.hasFileBasedTags()) {
res.buildTagList(file);
}
break;
}
}
return res;
}
/**
* Returns a repository for the given file, or null if no repository was
* found.
*
* @param info Information about the repository
* @return Correct repository for the given file
* @throws java.lang.InstantiationException in case we cannot create the
* repo object
* @throws java.lang.IllegalAccessException in case no permissions to repo
*/
public static Repository getRepository(RepositoryInfo info) throws InstantiationException, IllegalAccessException {
return getRepository(new File(info.getDirectoryName()));
}
}