blob: caf807b7eb062c3b5f079db66e57e8bf0df22235 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2010 AGETO Service GmbH and others.
* All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html.
*
* Contributors:
* IBM Corporation - initial API and implementation of CVS adapter
* Gunnar Wagenknecht - initial API and implementation
*******************************************************************************/
package org.eclipse.egit.internal.relengtools;
import java.io.IOException;
import java.util.Calendar;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.IResource;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
import org.eclipse.egit.core.project.RepositoryMapping;
import org.eclipse.jgit.lib.Constants;
import org.eclipse.jgit.lib.ObjectId;
import org.eclipse.jgit.lib.Repository;
import org.eclipse.jgit.revwalk.RevCommit;
import org.eclipse.jgit.revwalk.RevWalk;
import org.eclipse.jgit.treewalk.filter.PathFilter;
import org.eclipse.osgi.util.NLS;
import org.eclipse.releng.tools.RepositoryProviderCopyrightAdapter;
public class GitCopyrightAdapter extends RepositoryProviderCopyrightAdapter {
private static String filterString = "copyright"; // lowercase //$NON-NLS-1$
public GitCopyrightAdapter(IResource[] resources) {
super(resources);
}
@Override
public int getLastModifiedYear(IFile file, IProgressMonitor monitor)
throws CoreException {
try {
monitor.beginTask("Fetching logs from Git", 100); //$NON-NLS-1$
final RepositoryMapping mapping = RepositoryMapping
.getMapping(file);
if (mapping != null) {
final Repository repo = mapping.getRepository();
if (repo != null) {
RevWalk walk = null;
try {
final ObjectId start = repo.resolve(Constants.HEAD);
walk = new RevWalk(repo);
walk.setTreeFilter(PathFilter.create(mapping
.getRepoRelativePath(file)));
walk.markStart(walk.lookupCommit(start));
final RevCommit commit = walk.next();
if (commit != null) {
if (filterString != null
&& commit.getFullMessage().toLowerCase()
.indexOf(filterString) != -1) {
// the last update was a copyright checkin -
// ignore
return 0;
}
final Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(0);
calendar.add(Calendar.SECOND,
commit.getCommitTime());
return calendar.get(Calendar.YEAR);
}
} catch (final IOException e) {
throw new CoreException(new Status(IStatus.ERROR,
"org.eclipse.egit.relengtools", 0, NLS.bind(
"An error occured when processing {0}",
file.getName()), e));
} finally {
if (walk != null)
walk.release();
}
}
}
} finally {
monitor.done();
}
return -1;
}
@Override
public void initialize(IProgressMonitor monitor) throws CoreException {
// TODO We should perform a bulk "log" command to get the last modified
// year
}
}