blob: 5e0f1439d0c5e838c69b455c4ae77553e9dc4fe4 [file] [log] [blame]
/**
* Copyright (c) 2009-2010 Thales Corporate Services S.A.S.
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-v2.0
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Thales Corporate Services S.A.S - initial API and implementation
*/
package org.eclipse.egf.common.internal.registry;
import org.eclipse.core.internal.registry.Handle;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IConfigurationElement;
import org.eclipse.core.runtime.IExtension;
import org.eclipse.egf.common.EGFCommonPlugin;
import org.eclipse.egf.common.l10n.EGFCommonMessages;
import org.eclipse.egf.common.log.IEGFLogger;
import org.eclipse.egf.common.log.IEGFLoggerFactory;
import org.eclipse.osgi.util.NLS;
/**
* @author Xavier Maysonnave
*
*/
public class EGFLoggerProxy {
private IConfigurationElement _element;
private String _uniqueIdentifier;
private int _handleId = -1;
private String _class;
private IEGFLogger _executable;
/**
* @return the _uniqueIdentifier
*/
public String getUniqueIdentifier() {
return _uniqueIdentifier;
}
/**
* @return the _handleId
*/
public int getHandleId() {
return _handleId;
}
/**
* @return the _executable
*/
public IEGFLogger getEGFLogger() {
if (_executable == null && _element.isValid()) {
try {
Object object = _element.createExecutableExtension(EGFLoggerRegistry.INVOKER_ATT_CLASS);
if (object == null) {
return null;
}
if (object instanceof IEGFLoggerFactory == false) {
EGFCommonPlugin.getDefault().logError(NLS.bind(EGFCommonMessages.Wrong_Class_Message, object.getClass().getName()));
EGFCommonPlugin.getDefault().logInfo(NLS.bind(EGFCommonMessages.Wrong_Class_Sub_Type_Message, IEGFLoggerFactory.class.getName()), 1);
EGFCommonPlugin.getDefault().logInfo(NLS.bind(EGFCommonMessages.Bundle_Message, _element.getContributor().getName()), 1);
EGFCommonPlugin.getDefault().logInfo(NLS.bind(EGFCommonMessages.Extension_Point_Message, _element.getName()), 1);
EGFCommonPlugin.getDefault().logInfo(NLS.bind(EGFCommonMessages.Attribute_Message, _class), 1);
return null;
}
_executable = ((IEGFLoggerFactory) object).getLogger();
} catch (CoreException e) {
EGFCommonPlugin.getDefault().logError(e);
}
}
return _executable;
}
/**
* Creates a new EGFLoggerProxy proxy based on the given configuration element.
* Returns the new proxy, or null if the element could not be created.
*/
public static EGFLoggerProxy createProxy(IConfigurationElement element) {
if (element == null || element.isValid() == false) {
return null;
}
// Store identifier
IExtension declaringExtension = element.getDeclaringExtension();
String uniqueIdentifier = declaringExtension.getUniqueIdentifier();
int handleId = -1;
if (declaringExtension instanceof Handle) {
handleId = ((Handle) declaringExtension).getId();
}
// see platform:/plugin/org.eclipse.egf.common/schema/logger.exsd
String clazz = element.getAttribute(EGFLoggerRegistry.INVOKER_ATT_CLASS);
// 'class' attribute is mandatory
if (clazz == null || clazz.trim().length() == 0) {
return null;
}
return new EGFLoggerProxy(element, clazz, uniqueIdentifier, handleId);
}
public EGFLoggerProxy(IConfigurationElement element, String clazz, String uniqueIdentifier, int handleId) {
_element = element;
_class = clazz.trim();
if (uniqueIdentifier != null && uniqueIdentifier.trim().length() != 0) {
_uniqueIdentifier = uniqueIdentifier.trim();
}
_handleId = handleId;
}
public boolean originatesFrom(IExtension extension) {
String id = extension.getUniqueIdentifier();
if (id != null) {
return id.equals(_uniqueIdentifier);
}
if (extension instanceof Handle == false) {
return false;
}
return (_handleId == ((Handle) extension).getId());
}
}