/******************************************************************************* * Copyright (c) 2006-2012 * Software Technology Group, Dresden University of Technology * DevBoost GmbH, Berlin, Amtsgericht Charlottenburg, HRB 140026 * * 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: * Software Technology Group - TU Dresden, Germany; * DevBoost GmbH - Berlin, Germany * - initial API and implementation ******************************************************************************/ package org.reuseware.coconut.compositionprogram.resource; import java.util.Map; import org.eclipse.core.resources.IFile; import org.eclipse.core.resources.ResourcesPlugin; import org.eclipse.emf.ecore.EObject; import org.eclipse.emf.ecore.resource.Resource; /** * A default implementation of the <code>CompositionProblemReporter</code> interface * that creates a default marker for a file without further information about * the location of the problem <i>inside</i> the file. */ public class DefaultCompositionProblemReporter implements CompositionProblemReporter { /** * Default marker type: * <i>org.eclipse.core.resources.problemmarker</i>. */ public static final String DEFAULT_MARKER_TYPE = "org.eclipse.core.resources.problemmarker"; /** * Returns the file in the workspace that corresponds to the resource * that contains the given EObject. * * @param problemSource the EObject causing the problem * * @return file holding the problem source EObject */ public IFile getFile(EObject problemSource) { Resource resource = problemSource.eResource(); if (resource == null || !resource.getURI().isPlatformResource()) { return null; } IFile file = (IFile) ResourcesPlugin.getWorkspace().getRoot().findMember( resource.getURI().toPlatformString(true)); return file; } /** * @param problemSource the EObject causing the problem * * @return <code>DEFAULT_MARKER_TYPE</code> */ public String getMarkerType(EObject problemSource) { return DEFAULT_MARKER_TYPE; } /** * This implementation does nothing. * * @param problemSource the EObject causing the problem * @param attributes the attributes for the marker that can be extended by this methods */ public void getAttributes(EObject problemSource, Map<String, Object> attributes) { // } }