Java tutorial
/******************************************************************************* * 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 } }