Eclipse Equinox DS(Declarative Service)
- Equinox DS's METE-INF/MANIFEST.MF
Manifest-Version: 1.0
Lazy-ManifestFilter: (Service-Component=*)
Bundle-Localization: plugin
Bundle-RequiredExecutionEnvironment: OSGi/Minimum-1.2,CDC-1.1/Foundation-1.1,J2SE-1.4
Bundle-SymbolicName: org.eclipse.equinox.ds;singleton:=true
Eclipse-SourceReferences: scm:git:git://git.eclipse.org/gitroot/equino
x/rt.equinox.bundles.git;path="bundles/org.eclipse.equinox.ds";tag=v2
-
Bundle-Activator: org.eclipse.equinox.internal.ds.Activator
Export-Package: org.eclipse.equinox.internal.ds;x-internal:=true,org.e
clipse.equinox.internal.ds.impl;x-internal:=true,org.eclipse.equinox.
internal.ds.model;x-internal:=true,org.eclipse.equinox.internal.ds.st
orage.file;x-internal:=true,org.eclipse.equinox.internal.util.io;x-in
ternal:=true,org.eclipse.equinox.internal.util.xml;x-internal:=true,o
rg.eclipse.equinox.internal.util.xml.impl;x-internal:=true,org.eclips
e.equinox.internal.util.string;x-internal:=true,org.apache.felix.scr;
version="1.6"
Bundle-Version: 1.4..v20120522-
Bundle-Description: This bundle provides support for OSGi Declarative Services
Bundle-Vendor: %bundleVendor
Bundle-Name: %bundleName
Import-Package: org.eclipse.equinox.internal.util.event;version="1.0",
org.eclipse.equinox.internal.util.hash;version="1.0",org.eclipse.equi
nox.internal.util.pool;version="1.0",org.eclipse.equinox.internal.uti
l.ref;version="1.0",org.eclipse.equinox.internal.util.threadpool;vers
ion="1.0",org.eclipse.equinox.internal.util.timer;version="1.0",org.e
clipse.osgi.framework.console;version="1.0.0";resolution:=optional,or
g.eclipse.osgi.framework.log;version="1.0.0",org.eclipse.osgi.service
.debug;version="1.0",org.eclipse.osgi.service.environment;version="1.
2.0",org.eclipse.osgi.util,org.osgi.framework;version="1.3",org.osgi.
service.cm;version="1.2",org.osgi.service.component;version="[1.1,1.3
)",org.osgi.service.log;version="1.3.",org.osgi.util.tracker;version
="1.3",org.apache.felix.scr; version="[1.6,1.7)"
Bundle-ManifestVersion:org.eclipse.equinox.internal.ds.Activator
/*******************************************************************************
* Copyright (c) 1997, 2010 by ProSyst Software GmbH
* http://www.prosyst.com
* 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:
* ProSyst Software GmbH - initial API and implementation
*******************************************************************************/
package org.eclipse.equinox.internal.ds; import java.io.IOException;
import java.util.Dictionary;
import java.util.Hashtable;
import org.apache.felix.scr.ScrService;
import org.eclipse.equinox.internal.util.ref.Log;
import org.eclipse.osgi.framework.log.FrameworkLog;
import org.eclipse.osgi.framework.log.FrameworkLogEntry;
import org.eclipse.osgi.service.debug.DebugOptions;
import org.eclipse.osgi.service.environment.EnvironmentInfo;
import org.osgi.framework.*;
import org.osgi.service.cm.*;
import org.osgi.service.component.ComponentConstants;
import org.osgi.service.log.LogService;
import org.osgi.util.tracker.ServiceTracker; /**
* This is the main starting class for the Service Component Runtime.
* The SCR is not fully initialized until it detects at least one bundle providing DS components.
* Thus it has considerably small startup time and does improve a little the runtime performance
* since it does not listen for service events.
*
* @author Valentin Valchev
* @author Stoyan Boshev
* @author Pavlin Dobrev
*/ public class Activator implements BundleActivator, SynchronousBundleListener, ServiceListener { public static BundleContext bc = null;
public static ConfigurationAdmin configAdmin = null;
public static boolean security = false; private ServiceRegistration configListenerReg;
private SCRManager scrManager = null;
public ScrServiceImpl scrService = null;
private ServiceRegistration scrServiceReg;
private ServiceRegistration scrCommandProviderReg;
private static FrameworkLog fwLog;
private boolean inited = false; public static Log log;
public static boolean DEBUG;
public static boolean PERF;
public static boolean DBSTORE;
public static boolean INSTANTIATE_ALL;
public static boolean startup; static long time[] = null; public static void timeLog(String message) {
time[1] = time[0];
log.debug(message + String.valueOf((time[0] = System.currentTimeMillis()) - time[1]), null);
} private void initSCR() {
synchronized (this) {
if (inited)
return;
inited = true;
} boolean lazyIniting = false;
if (startup && time == null) {
long tmp = System.currentTimeMillis();
time = new long[] {tmp, 0, tmp};
lazyIniting = true;
if (startup)
timeLog("[BEGIN - lazy SCR init]"); //$NON-NLS-1$
} WorkThread.IDLE_TIMEOUT = getInteger("equinox.ds.idle_timeout", 1000); //$NON-NLS-1$
WorkThread.BLOCK_TIMEOUT = getInteger("equinox.ds.block_timeout", 30000); //$NON-NLS-1$ try {
bc.addServiceListener(this, "(objectClass=" + ConfigurationAdmin.class.getName() + ')'); //$NON-NLS-1$
} catch (InvalidSyntaxException e) {
//should never happen
}
//get config admin service if available
ServiceReference caRef = bc.getServiceReference(ConfigurationAdmin.class.getName());
if (caRef != null) {
configAdmin = (ConfigurationAdmin) bc.getService(caRef);
}
if (startup)
timeLog("ConfigurationAdmin service getting took "); //$NON-NLS-1$ scrManager = new SCRManager();
if (startup)
timeLog("SCRManager instantiation took "); //$NON-NLS-1$ // add the configuration listener - we to receive CM events to restart
// components
configListenerReg = bc.registerService(ConfigurationListener.class.getName(), scrManager, null);
if (startup)
timeLog("ConfigurationListener service registered for "); //$NON-NLS-1$
bc.addServiceListener(scrManager); scrManager.startIt();
if (Activator.startup)
Activator.timeLog("startIt() method took "); //$NON-NLS-1$ installCommandProvider(); if (startup && lazyIniting) {
log.debug("[END - lazy SCR init] Activator.initSCR() method executed for " + String.valueOf(time[0] - time[2]), null); //$NON-NLS-1$
time = null;
}
} /*
* (non-Javadoc)
*
* @see org.osgi.framework.BundleActivator#start(org.osgi.framework.BundleContext)
*/
public void start(BundleContext bundleContext) throws Exception {
Activator.bc = bundleContext;
startup = getBoolean("equinox.measurements.bundles", false); //$NON-NLS-1$
if (startup) {
long tmp = System.currentTimeMillis();
time = new long[] {tmp, 0, tmp};
}
// initialize the logging routines
log = new Log(bundleContext, false);
ServiceTracker debugTracker = new ServiceTracker(bundleContext, DebugOptions.class.getName(), null);
debugTracker.open();
DebugOptions debugOptions = (DebugOptions) debugTracker.getService();
DEBUG = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/debug", false) || getBoolean("equinox.ds.debug", false); //$NON-NLS-1$ //$NON-NLS-2$
PERF = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/performance", false) || getBoolean("equinox.ds.perf", false); //$NON-NLS-1$ //$NON-NLS-2$
INSTANTIATE_ALL = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/instantiate_all", false) || getBoolean("equinox.ds.instantiate_all", false); //$NON-NLS-1$ //$NON-NLS-2$ DBSTORE = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/cache_descriptions", true) || getBoolean("equinox.ds.dbstore", true); //$NON-NLS-1$ //$NON-NLS-2$
boolean print = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/print_on_console", false) || getBoolean("equinox.ds.print", false); //$NON-NLS-1$ //$NON-NLS-2$
log.setDebug(DEBUG);
log.setPrintOnConsole(print);
//DebugOptions no longer needed
debugTracker.close();
ServiceReference fwRef = bc.getServiceReference(FrameworkLog.class.getName());
if (fwRef != null) {
fwLog = (FrameworkLog) bc.getService(fwRef);
} if (startup)
timeLog("[BEGIN - start method] Creating Log instance and initializing log system took "); //$NON-NLS-1$ security = Log.security();
boolean hasHeaders = false;
Bundle[] allBundles = bundleContext.getBundles();
for (int i = 0; i < allBundles.length; i++) {
Dictionary allHeaders = allBundles[i].getHeaders(""); //$NON-NLS-1$
if (allHeaders.get(ComponentConstants.SERVICE_COMPONENT) != null) {
hasHeaders = true;
break;
}
} if (hasHeaders) {
initSCR();
} else {
// there are no bundles holding components - SCR will not be
// initialized yet
bundleContext.addBundleListener(this);
}
ServiceReference envInfoRef = bc.getServiceReference(EnvironmentInfo.class.getName());
EnvironmentInfo envInfo = null;
if (envInfoRef != null) {
envInfo = (EnvironmentInfo) bc.getService(envInfoRef);
}
if (envInfo != null) {
envInfo.setProperty("equinox.use.ds", "true"); //$NON-NLS-1$//$NON-NLS-2$
bc.ungetService(envInfoRef);
} else {
System.setProperty("equinox.use.ds", "true"); //$NON-NLS-1$ //$NON-NLS-2$
} scrService = new ScrServiceImpl();
scrServiceReg = bc.registerService(ScrService.class.getName(), scrService, null); if (startup) {
log.debug("[END - start method] Activator.start() method executed for " + String.valueOf(time[0] - time[2]), null); //$NON-NLS-1$
time = null;
}
} /*
* (non-Javadoc)
*
* @see org.osgi.framework.BundleActivator#stop(org.osgi.framework.BundleContext)
*/
public void stop(BundleContext bundleContext) throws Exception {
if (scrManager != null) {
scrManager.stopIt();
bundleContext.removeServiceListener(scrManager);
}
// dispose the CM Listener
if (configListenerReg != null) {
configListenerReg.unregister();
}
if (scrService != null) {
scrService.dispose();
scrServiceReg.unregister();
} if (scrCommandProviderReg != null)
scrCommandProviderReg.unregister(); if (scrManager != null) {
bundleContext.removeBundleListener(scrManager);
} else {
bundleContext.removeBundleListener(this);
}
ServiceReference envInfoRef = bc.getServiceReference(EnvironmentInfo.class.getName());
EnvironmentInfo envInfo = null;
if (envInfoRef != null) {
envInfo = (EnvironmentInfo) bc.getService(envInfoRef);
}
if (envInfo != null) {
envInfo.setProperty("equinox.use.ds", "false"); //$NON-NLS-1$//$NON-NLS-2$
bc.ungetService(envInfoRef);
} else {
System.setProperty("equinox.use.ds", "false"); //$NON-NLS-1$ //$NON-NLS-2$
} log.close();
log = null;
} public static Filter createFilter(String filter) throws InvalidSyntaxException {
return bc.createFilter(filter);
} public void bundleChanged(BundleEvent event) {
if (event.getType() == BundleEvent.STARTED || event.getType() == BundleEvent.LAZY_ACTIVATION) {
Dictionary allHeaders = event.getBundle().getHeaders(""); //$NON-NLS-1$
if ((allHeaders.get(ComponentConstants.SERVICE_COMPONENT)) != null) {
// The bundle is holding components - activate scr
bc.removeBundleListener(this);
initSCR();
}
}
} public static Configuration getConfiguration(String pid) throws IOException {
if (configAdmin != null) {
return configAdmin.getConfiguration(pid);
}
return null;
} public static Configuration[] listConfigurations(String filter) throws IOException, InvalidSyntaxException {
if (configAdmin != null) {
return configAdmin.listConfigurations(filter);
}
return null;
} public static boolean getBoolean(String property, boolean defaultValue) {
String prop = (bc != null) ? bc.getProperty(property) : System.getProperty(property);
if (prop != null) {
return prop.equalsIgnoreCase("true"); //$NON-NLS-1$
}
return defaultValue;
} public static boolean getBoolean(String property) {
return getBoolean(property, false);
} public static int getInteger(String property, int defaultValue) {
String prop = (bc != null) ? bc.getProperty(property) : System.getProperty(property);
if (prop != null) {
try {
return Integer.decode(prop).intValue();
} catch (NumberFormatException e) {
//do nothing
}
}
return defaultValue;
} public boolean getBooleanDebugOption(DebugOptions optionsService, String option, boolean defaultValue) {
if (optionsService != null) {
String value = optionsService.getOption(option);
if (value != null)
return value.equalsIgnoreCase("true"); //$NON-NLS-1$
}
return defaultValue;
} private void installCommandProvider() {
try {
SCRCommandProvider scrCommandProvider = new SCRCommandProvider(scrManager);
Hashtable reg_props = new Hashtable(1, 1);
reg_props.put(org.osgi.framework.Constants.SERVICE_RANKING, new Integer(Integer.MAX_VALUE));
scrCommandProviderReg = bc.registerService(org.eclipse.osgi.framework.console.CommandProvider.class.getName(), scrCommandProvider, reg_props);
} catch (NoClassDefFoundError e) {
//the org.eclipse.osgi.framework.console package is optional
if (Activator.DEBUG) {
log.debug("Cannot register SCR CommandProvider!", e); //$NON-NLS-1$
}
}
} public static void log(BundleContext bundleContext, int level, String message, Throwable t) {
LogService logService = null;
ServiceReference logRef = null;
if (bundleContext != null) {
try {
logRef = bundleContext.getServiceReference(LogService.class.getName());
if (logRef != null) {
logService = (LogService) bundleContext.getService(logRef);
}
} catch (Exception e) {
if (Activator.DEBUG) {
log.debug("Cannot get LogService for bundle " + bundleContext.getBundle().getSymbolicName(), e); //$NON-NLS-1$
}
}
}
if (logService != null) {
logService.log(level, message, t);
bundleContext.ungetService(logRef);
if (log.getPrintOnConsole()) {
String prefix = ""; //$NON-NLS-1$
switch (level) {
case LogService.LOG_ERROR :
prefix = "ERROR "; //$NON-NLS-1$
break;
case LogService.LOG_WARNING :
prefix = "WARNING "; //$NON-NLS-1$
break;
case LogService.LOG_INFO :
prefix = "INFO "; //$NON-NLS-1$
break;
}
dumpOnConsole(prefix, bundleContext, message, t, level == LogService.LOG_ERROR);
}
} else {
logRef = bc.getServiceReference(LogService.class.getName());
if (logRef == null) {
//log service is not available
if (!log.getPrintOnConsole() && !log.autoPrintOnConsole && fwLog == null) {
//The log will not print the message on the console and the FrameworkLog service is not available
//Will print errors on the console as last resort
if (level == LogService.LOG_ERROR) {
dumpOnConsole("ERROR ", bundleContext, message, t, true); //$NON-NLS-1$
}
}
} //using the SCR log
switch (level) {
case LogService.LOG_ERROR :
log.error(message, t);
break;
case LogService.LOG_WARNING :
log.warning(message, t);
break;
case LogService.LOG_INFO :
log.info(message);
break;
default :
log.debug(message, t);
break;
}
}
if (fwLog != null) {
logToFWLog(bundleContext != null ? bundleContext.getBundle().getSymbolicName() : bc.getBundle().getSymbolicName(), level, message, t);
}
} private static void dumpOnConsole(String prefix, BundleContext bundleContext, String msg, Throwable t, boolean printInErr) {
String message = prefix + bundleContext.getBundle().getBundleId() + " " + msg; //$NON-NLS-1$
if (printInErr) {
System.err.println(message);
} else {
System.out.println(message);
}
if (t != null) {
t.printStackTrace();
}
} private static void logToFWLog(String bsn, int level, String message, Throwable t) {
int severity = FrameworkLogEntry.INFO;
switch (level) {
case LogService.LOG_ERROR :
severity = FrameworkLogEntry.ERROR;
break;
case LogService.LOG_WARNING :
severity = FrameworkLogEntry.WARNING;
break;
case LogService.LOG_INFO :
severity = FrameworkLogEntry.INFO;
break;
case LogService.LOG_DEBUG :
severity = FrameworkLogEntry.INFO;
break;
}
fwLog.log(new FrameworkLogEntry(bsn, severity, 0, message, 0, t, null));
} public void serviceChanged(ServiceEvent event) {
switch (event.getType()) {
case ServiceEvent.REGISTERED :
Object caService = bc.getService(event.getServiceReference());
configAdmin = (ConfigurationAdmin) caService;
if (caService != null) {
// Config Admin registered
if (scrManager != null) {
scrManager.configAdminRegistered((ConfigurationAdmin) caService, event.getServiceReference());
}
}
break;
case ServiceEvent.UNREGISTERING :
//get replacement config admin service if available
ServiceReference caRef = bc.getServiceReference(ConfigurationAdmin.class.getName());
if (caRef != null) {
configAdmin = (ConfigurationAdmin) bc.getService(caRef);
} else {
configAdmin = null;
}
break;
}
}
}Activator
- One example of Service-Component
- MAINFEST.INF
Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: Toast Back End Emergency
Bundle-SymbolicName: org.eclipse.examples.toast.backend.emergency
Bundle-Version: 1.0.0
Bundle-RequiredExecutionEnvironment: J2SE-1.4
Service-Component: OSGI-INF/component.xml,OSGI-INF/emergencyCenter.xml
Import-Package: javax.servlet;version="2.4.0",
javax.servlet.http;version="2.4.0",
org.eclipse.examples.toast.backend.controlcenter,
org.eclipse.examples.toast.backend.data,
org.eclipse.examples.toast.backend.data.internal,
org.eclipse.examples.toast.core;version="[1.0.0,2.0.0)",
org.eclipse.examples.toast.core.emergency;version="[1.0.0,2.0.0)",
org.osgi.service.http;version="[1.2.0,2.0.0)"
Export-Package: org.eclipse.examples.toast.internal.backend.emergency;version="1.0.0";x-internal:=true,- Service-Component: OSGI-INF/component.xml,OSGI-INF/emergencyCenter.xml
<?xml version="1.0" encoding="UTF-8"?>
<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" activate="startup" deactivate="shutdown" name="org.eclipse.examples.toast.backend.emergency">
<implementation class="org.eclipse.examples.toast.internal.backend.emergency.bundle.Component"/>
<reference bind="setHttp" interface="org.osgi.service.http.HttpService" name="http"/>
<reference bind="setEmergencyCenter" interface="org.eclipse.examples.toast.core.emergency.IEmergencyCenter" name="emergencyCenter"/>
</scr:component> <?xml version="1.0" encoding="UTF-8"?>
<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.1.0" activate="startup" deactivate="shutdown" name="org.eclipse.examples.toast.backend.emergency.center">
<implementation class="org.eclipse.examples.toast.internal.backend.emergency.EmergencyCenter"/>
<service>
<provide interface="org.eclipse.examples.toast.core.emergency.IEmergencyCenter"/>
</service>
<reference bind="setData" cardinality="1..1" interface="org.eclipse.examples.toast.backend.controlcenter.IData" name="IData" policy="static"/>
</scr:component>
- start method implemented by Activator
public void start(BundleContext bundleContext) throws Exception {
Activator.bc = bundleContext;
startup = getBoolean("equinox.measurements.bundles", false); //$NON-NLS-1$
if (startup) {
long tmp = System.currentTimeMillis();
time = new long[] {tmp, 0, tmp};
}
// initialize the logging routines
log = new Log(bundleContext, false);
ServiceTracker debugTracker = new ServiceTracker(bundleContext, DebugOptions.class.getName(), null);
debugTracker.open();
DebugOptions debugOptions = (DebugOptions) debugTracker.getService();
DEBUG = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/debug", false) || getBoolean("equinox.ds.debug", false); //$NON-NLS-1$ //$NON-NLS-2$
PERF = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/performance", false) || getBoolean("equinox.ds.perf", false); //$NON-NLS-1$ //$NON-NLS-2$
INSTANTIATE_ALL = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/instantiate_all", false) || getBoolean("equinox.ds.instantiate_all", false); //$NON-NLS-1$ //$NON-NLS-2$ DBSTORE = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/cache_descriptions", true) || getBoolean("equinox.ds.dbstore", true); //$NON-NLS-1$ //$NON-NLS-2$
boolean print = getBooleanDebugOption(debugOptions, "org.eclipse.equinox.ds/print_on_console", false) || getBoolean("equinox.ds.print", false); //$NON-NLS-1$ //$NON-NLS-2$
log.setDebug(DEBUG);
log.setPrintOnConsole(print);
//DebugOptions no longer needed
debugTracker.close();
ServiceReference fwRef = bc.getServiceReference(FrameworkLog.class.getName());
if (fwRef != null) {
fwLog = (FrameworkLog) bc.getService(fwRef);
} if (startup)
timeLog("[BEGIN - start method] Creating Log instance and initializing log system took "); //$NON-NLS-1$ security = Log.security();
boolean hasHeaders = false;
Bundle[] allBundles = bundleContext.getBundles();
for (int i = 0; i < allBundles.length; i++) {
Dictionary allHeaders = allBundles[i].getHeaders(""); //$NON-NLS-1$
if (allHeaders.get(ComponentConstants.SERVICE_COMPONENT) != null) {
hasHeaders = true;
break;
}
} if (hasHeaders) {
initSCR();
} else {
// there are no bundles holding components - SCR will not be
// initialized yet
bundleContext.addBundleListener(this);
}
ServiceReference envInfoRef = bc.getServiceReference(EnvironmentInfo.class.getName());
EnvironmentInfo envInfo = null;
if (envInfoRef != null) {
envInfo = (EnvironmentInfo) bc.getService(envInfoRef);
}
if (envInfo != null) {
envInfo.setProperty("equinox.use.ds", "true"); //$NON-NLS-1$//$NON-NLS-2$
bc.ungetService(envInfoRef);
} else {
System.setProperty("equinox.use.ds", "true"); //$NON-NLS-1$ //$NON-NLS-2$
} scrService = new ScrServiceImpl();
scrServiceReg = bc.registerService(ScrService.class.getName(), scrService, null); if (startup) {
log.debug("[END - start method] Activator.start() method executed for " + String.valueOf(time[0] - time[2]), null); //$NON-NLS-1$
time = null;
}
}- initSCR() in Activator
private void initSCR() {
synchronized (this) {
if (inited)
return;
inited = true;
} boolean lazyIniting = false;
if (startup && time == null) {
long tmp = System.currentTimeMillis();
time = new long[] {tmp, 0, tmp};
lazyIniting = true;
if (startup)
timeLog("[BEGIN - lazy SCR init]"); //$NON-NLS-1$
} WorkThread.IDLE_TIMEOUT = getInteger("equinox.ds.idle_timeout", 1000); //$NON-NLS-1$
WorkThread.BLOCK_TIMEOUT = getInteger("equinox.ds.block_timeout", 30000); //$NON-NLS-1$ try {
bc.addServiceListener(this, "(objectClass=" + ConfigurationAdmin.class.getName() + ')'); //$NON-NLS-1$
} catch (InvalidSyntaxException e) {
//should never happen
}
//get config admin service if available
ServiceReference caRef = bc.getServiceReference(ConfigurationAdmin.class.getName());
if (caRef != null) {
configAdmin = (ConfigurationAdmin) bc.getService(caRef);
}
if (startup)
timeLog("ConfigurationAdmin service getting took "); //$NON-NLS-1$ scrManager = new SCRManager();
if (startup)
timeLog("SCRManager instantiation took "); //$NON-NLS-1$ // add the configuration listener - we to receive CM events to restart
// components
configListenerReg = bc.registerService(ConfigurationListener.class.getName(), scrManager, null);
if (startup)
timeLog("ConfigurationListener service registered for "); //$NON-NLS-1$
bc.addServiceListener(scrManager); scrManager.startIt();
if (Activator.startup)
Activator.timeLog("startIt() method took "); //$NON-NLS-1$ installCommandProvider(); if (startup && lazyIniting) {
log.debug("[END - lazy SCR init] Activator.initSCR() method executed for " + String.valueOf(time[0] - time[2]), null); //$NON-NLS-1$
time = null;
}
}public void startIt() {
// loop through the currently installed bundles
Bundle[] bundles = Activator.bc.getBundles();
if (bundles != null) {
for (int i = 0; i < bundles.length; i++) {
Bundle current = bundles[i];
// try to process the active ones.
if (current.getState() == Bundle.ACTIVE) {
startedBundle(current);
} else if (current.getState() == Bundle.STARTING) {
String lazy = (String) current.getHeaders("").get(Constants.BUNDLE_ACTIVATIONPOLICY); //$NON-NLS-1$
if (lazy != null && lazy.indexOf(Constants.ACTIVATION_LAZY) >= 0) {
startedBundle(current);
}
}
}
}
}void startedBundle(Bundle bundle) {
synchronized (processingBundles) {
if (processingBundles.get(bundle) != null) {
//the bundle is already being processed
return;
}
processingBundles.put(bundle, ""); //$NON-NLS-1$
}
try {
startedBundle2(bundle);
} finally {
processingBundles.remove(bundle);
}
}void startedBundle2(Bundle bundle) {
long start = 0l;
if (Activator.PERF) {
start = System.currentTimeMillis();
}
if (bundleToServiceComponents != null && bundleToServiceComponents.get(bundle) != null) {
// the bundle is already processed - skipping it
return;
} String dsHeader = null;
Dictionary allHeaders = bundle.getHeaders(""); //$NON-NLS-1$ if (!((dsHeader = (String) allHeaders.get(ComponentConstants.SERVICE_COMPONENT)) != null)) {
// no component descriptions in this bundle
return;
} Vector components = storage.loadComponentDefinitions(bundle, dsHeader);
if (components != null && !components.isEmpty()) {
if (!hasRegisteredServiceListener) {
hasRegisteredServiceListener = true;
Activator.bc.addServiceListener(this);
resolver.synchronizeServiceReferences();
}
if (Activator.PERF) {
start = System.currentTimeMillis() - start;
Activator.log.info("[DS perf] The components of bundle " + bundle + " are parsed for " + start + "ms"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$
}
if (bundleToServiceComponents == null) {
synchronized (this) {
if (bundleToServiceComponents == null) {
bundleToServiceComponents = new Hashtable(11);
}
}
} //check whether component's names are unique
ServiceComponent comp;
ServiceComponent comp2;
L1: for (int i = 0; i < components.size(); i++) {
comp = (ServiceComponent) components.elementAt(i);
//check if unique in its bundle
for (int j = i + 1; j < components.size(); j++) {
comp2 = (ServiceComponent) components.elementAt(j);
if (comp.name.equals(comp2.name)) {
Activator.log(comp.bc, LogService.LOG_ERROR, NLS.bind(Messages.FOUND_COMPONENTS_WITH_DUPLICATED_NAMES, comp), null);
//removing one of the components
components.remove(i);
i--;
continue L1;
}
}
//check if the component is globally unique
Enumeration keys = bundleToServiceComponents.keys();
while (keys.hasMoreElements()) {
Vector components2 = (Vector) bundleToServiceComponents.get(keys.nextElement());
for (int j = 0; j < components2.size(); j++) {
comp2 = (ServiceComponent) components2.elementAt(j);
if (comp.name.equals(comp2.name)) {
Activator.log(comp.bc, LogService.LOG_WARNING, NLS.bind(Messages.FOUND_COMPONENTS_WITH_DUPLICATED_NAMES2, comp, comp2), null);
}
}
} if (comp.autoenable) {
comp.enabled = true;
}
}
// store the components in the cache
bundleToServiceComponents.put(bundle, components.clone());
if (workThread != null && workThread.processingThread == Thread.currentThread()) {
//we are in the queue thread already. Processing synchronously the job
resolver.enableComponents(components);
} else {
// this will also resolve the component dependencies!
enqueueWork(this, ENABLE_COMPONENTS, components, false);
synchronized (components) {
long startTime = System.currentTimeMillis();
try {
while (!components.isEmpty() && (System.currentTimeMillis() - startTime < WorkThread.BLOCK_TIMEOUT)) {
components.wait(1000);
}
if (System.currentTimeMillis() - startTime >= WorkThread.BLOCK_TIMEOUT) {
Activator.log(null, LogService.LOG_WARNING, NLS.bind(Messages.TIMEOUT_REACHED_ENABLING_COMPONENTS, getBundleName(bundle), Integer.toString(WorkThread.BLOCK_TIMEOUT)), null);
}
} catch (InterruptedException e) {
//do nothing
}
}
}
}
}- ad
Eclipse Equinox DS(Declarative Service)的更多相关文章
- OSGiBundle出现 Could not find bundle: org.eclipse.equinox.console的解决方案
按照网上教程创建OSGI HelloWorld实例配置run configuration时出现Could not find bundle: org.eclipse.equinox.console 和C ...
- Eclipse equinox implementation of OSGi
Bundle package org.osgi.framework; public interface Bundle extends Comparable<Bundle> { int UN ...
- 【Tomcat】解决Eclipse无法添加Tomcat Service问题
直接上图:今天因为弄Maven的时候,不小心把Tomcat7 Service 给弄没了,没法直接添加. 可以参照上图的结构进行 Download and Install...点击之后等待一会儿. 其实 ...
- 使用Eclipse自带Web Service插件(Axis1.4)生成Web Service服务端/客户端
创建一个名字为math的Java web工程,并将WSDL文件拷入该工程中 将Axis所需的jar包拷贝至WebRoot\WEB-INF\lib目录下,这些jar包会自动导入math工程中 一,生成W ...
- Eclipse Configuration
*** Date: 2013年9月12日星期四中国标准时间上午8时41分50秒 *** Platform Details: *** System properties:applicationXMI=o ...
- Equinox P2的学习
product.configuration 点击“Add按钮”并添加以下插件: org.eclipse.equinox.p2.ui org.eclipse.equinox.p2.ui.sdk org. ...
- Equinox P2 介绍(一)Getting Start
一直觉得 Equinox 的 P2 是个神秘的东西,常常使得 Eclipse 或 Equinox 表现出一些奇怪的行为,于是找来官方文档读一读,试图更好地理解与应用 Equinox . 官方文档很多, ...
- eclipse启动报错:An error has occurred.See the log file D:\eclipse\configuration\1552616709202.log
如题,Eclipse崩了,只能按它留下的线索去看了1552616709202.log: !SESSION -- ::08.739 ----------------------------------- ...
- OSGi简介
OSGi简介 OSGi是什么 下面来看看“维基百科”给出的解释: OSGi(Open Service Gateway Initiative)有双重含义.一方面它指OSGi Alliance组织:另一方 ...
随机推荐
- kotlin spring @value 注解
spring boot和kotlin里静态类使用@Value注解配置解决方案前言spring boot里默认是不能给静态属性使用@Value赋值的.所以这里使用中间变量过渡绑定. 方案//applic ...
- quill 设置 初始值...
1down voteaccepted For your first issue change this: text.value = JSON.stringify(quill.root.innerHTM ...
- 关于zipfile解压出现的字符编码问题
使用zipfile解压文件时,出现了中文乱码问题,具体解决方法有两个,直接上代码吧. def deco_zip(path, file_path): os.mkdir(file_path) # 方式一 ...
- git 项目常用命令
git remote -v 查看对应的远程仓库 git fetch origin master 将某个远程主机的更新,全部取回本地 git merge origin master 合并分支 git a ...
- switch case 注意事项
switch case常见的注意事项: 1.case后面常量值的顺序可以任意,一般按顺序编写 2.default顺序也可以编写在switch中的任意位置 当所有case都不满足时则执行default ...
- lnmp 一键搭建脚本
转载注明出处!!!!!!!!! 不足之处望多多指教. 不明之处站内私. #!/bin/bash #################################################### ...
- 移动端刷新组件XtnScroll--Angular4实现
刷新组件 - 主要是学习一下Angular4所有花了我一天时间,写了这个刷新组件. 以项目开发当中,特别是手机移动端开发的时候,经常要用到就是上拉加载下一面,下拉刷新获取最新数据的功能. 在网也有很多 ...
- pycharm + git实现两台电脑代码同步
说明:此篇文章是作者方便日后查阅所有,请不要按本文的方法搭建 1.下载msysygit,https://git-for-windows.github.io/ 点击download获取下载链接,可能由于 ...
- Steamworks and Unity – P2P多人游戏
之前我们讨论过“如何把Steamworks.Net和Unity整合起来”,这是一个很好的开始,现在我们研究深一点,谈一谈Steam中的多人游戏.这不是教程,但是可以指导你在你的游戏中如何使用Steam ...
- 1分钟搭建极简mock server
1.无聊的背景.起源: 如今的业务系统越来越复杂庞大,各个功能直接的调用也是多如牛毛,但如果在联调的时候,恰好被调的接口正在开发,怎么办?傻傻的等么,不存在的!这时会搭建一些server来进行mock ...