blob: c70b52d006933a5b362264a0b2127717a8a65f4c [file] [log] [blame]
/*
* Copyright (c) 2007-2009, 2011, 2012, 2015 Eike Stepper (Berlin, Germany) 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:
* Eike Stepper - initial API and implementation
*/
package org.eclipse.net4j.internal.db.bundle;
import org.eclipse.net4j.db.IDBAdapter;
import org.eclipse.net4j.internal.db.DBAdapterDescriptor;
import org.eclipse.net4j.internal.db.DBAdapterRegistry;
import org.eclipse.net4j.util.om.OMBundle;
import org.eclipse.net4j.util.om.OMPlatform;
import org.eclipse.net4j.util.om.OSGiActivator;
import org.eclipse.net4j.util.om.log.OMLogger;
import org.eclipse.net4j.util.om.trace.OMTracer;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IConfigurationElement;
import org.eclipse.core.runtime.IExtensionRegistry;
import org.eclipse.core.runtime.Platform;
/**
* The <em>Operations & Maintenance</em> class of this bundle.
*
* @author Eike Stepper
*/
public abstract class OM
{
public static final String BUNDLE_ID = "org.eclipse.net4j.db"; //$NON-NLS-1$
public static final OMBundle BUNDLE = OMPlatform.INSTANCE.bundle(BUNDLE_ID, OM.class);
public static final OMTracer DEBUG = BUNDLE.tracer("debug"); //$NON-NLS-1$
public static final OMTracer DEBUG_SQL = DEBUG.tracer("sql"); //$NON-NLS-1$
public static final OMLogger LOG = BUNDLE.logger();
public static final String EXT_POINT = "dbAdapters"; //$NON-NLS-1$
/**
* @author Eike Stepper
*/
public static final class Activator extends OSGiActivator
{
public Activator()
{
super(BUNDLE);
}
@Override
protected void doStart() throws Exception
{
initDBAdapterRegistry();
}
private void initDBAdapterRegistry()
{
IExtensionRegistry registry = Platform.getExtensionRegistry();
IConfigurationElement[] elements = registry.getConfigurationElementsFor(BUNDLE_ID, EXT_POINT);
for (final IConfigurationElement element : elements)
{
if ("dbAdapter".equals(element.getName())) //$NON-NLS-1$
{
DBAdapterDescriptor descriptor = new DBAdapterDescriptor(element.getAttribute("name")) //$NON-NLS-1$
{
@Override
public IDBAdapter createDBAdapter()
{
try
{
return (IDBAdapter)element.createExecutableExtension("class"); //$NON-NLS-1$
}
catch (CoreException ex)
{
OM.LOG.error(ex);
return null;
}
}
};
DBAdapterRegistry.INSTANCE.addDescriptor(descriptor);
}
}
}
}
}