Package org.eclipse.osgi.container
Class ModuleContainerAdaptor
java.lang.Object
org.eclipse.osgi.container.ModuleContainerAdaptor
Adapts the behavior of a container.
- Since:
- 3.10
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumEvent types that may bepublishedfor a container.static enum
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionadaptModuleRevisionBuilder(ModuleContainerAdaptor.ModuleEvent operation, Module origin, ModuleRevisionBuilder builder, Object revisionInfo) Allows a builder to be modified before it is used by the container.voidassociateRevision(ModuleRevision revision, Object revisionInfo) After a revision is created this method is called with the specified revision info.abstract ModulecreateModule(String location, long id, EnumSet<Module.Settings> settings, int startlevel) Creates a new module.createModuleLoader(ModuleWiring wiring) Creates a newModuleLoaderfor the specified wiring.abstract SystemModuleCreates the system module.Returns the debug options for the module container.abstract ModuleCollisionHookReturns the collision hook the container will use.getProperty(String key) Returns the specified configuration property valueReturns the executor used to perform resolve operationsabstract ResolverHookFactoryReturns the resolver hook factory the container will use.getRevisionInfo(String location, long id) Returns the current revision info for a module with the specified location and idReturns the scheduled executor that may be used by the container to schedule background tasks.Returns the executor used to by theFrameworkStartLevelimplementation to start bundles that have the same start level.voidThis is called when theSystemModule.init()is running.voidinitEnd()This is called just before theSystemModule.init()returns.voidinvalidateWiring(ModuleWiring moduleWiring, ModuleLoader current) This is called when a wiring is made invalid and allows the adaptor to react to this.abstract voidpublishContainerEvent(ModuleContainerAdaptor.ContainerEvent type, Module module, Throwable error, FrameworkListener... listeners) Publishes the specified container event.abstract voidpublishModuleEvent(ModuleContainerAdaptor.ModuleEvent type, Module module, Module origin) Publishes the specified module event type for the specified module.voidThis is called if a request to refresh modules causes the system module to be refreshed.voidLog a trace message.voidtraceThrowable(String topic, Throwable t) Log a trace exceptionvoidThis is called whenever the module database has been updated.
- 
Constructor Details- 
ModuleContainerAdaptorpublic ModuleContainerAdaptor()
 
- 
- 
Method Details- 
getModuleCollisionHookReturns the collision hook the container will use.- Returns:
- the collision hook the container will use.
 
- 
getResolverHookFactoryReturns the resolver hook factory the container will use.- Returns:
- the resolver hook factory the container will use.
 
- 
publishContainerEventpublic abstract void publishContainerEvent(ModuleContainerAdaptor.ContainerEvent type, Module module, Throwable error, FrameworkListener... listeners) Publishes the specified container event. No locks are held by the container when this method is called- Parameters:
- type- the type of event
- module- the module associated with the event
- error- the error associated with the event, may be- null
- listeners- additional listeners to publish the event to synchronously
 
- 
publishModuleEventpublic abstract void publishModuleEvent(ModuleContainerAdaptor.ModuleEvent type, Module module, Module origin) Publishes the specified module event type for the specified module. No locks are held by the container when this method is called- Parameters:
- type- the event type to publish
- module- the module the event is associated with
- origin- the module which is the origin of the event. For the event type- ModuleContainerAdaptor.ModuleEvent.INSTALLED, this is the module whose context was used to install the module. Otherwise it is the module itself. May be null only when the event is not of type- ModuleContainerAdaptor.ModuleEvent.INSTALLED.
 
- 
getPropertyReturns the specified configuration property value- Parameters:
- key- the key of the configuration property
- Returns:
- the configuration property value
 
- 
createModuleLoaderCreates a newModuleLoaderfor the specified wiring.- Parameters:
- wiring- the module wiring to create a module loader for
- Returns:
- a new ModuleLoaderfor the specified wiring.
 
- 
createModulepublic abstract Module createModule(String location, long id, EnumSet<Module.Settings> settings, int startlevel) Creates a new module. This gets called when a new module is installed or whenloadingpersistent data into this database.- Parameters:
- location- the location for the module
- id- the id for the module
- settings- the settings for the module. May be- nullif there are no settings.
- startlevel- the start level for the module
- Returns:
- the Module
 
- 
createSystemModuleCreates the system module. This gets called when the system module is installed or whenloadingpersistent data into this database.The returned system module must have an idof zero and a location ofSystem Bundle.- Returns:
- the system module
 
- 
getRevisionInfoReturns the current revision info for a module with the specified location and id- Parameters:
- location- the location of the module
- id- the id of the module
- Returns:
- the revision info, may be null
 
- 
associateRevisionAfter a revision is created this method is called with the specified revision info.- Parameters:
- revision- the newly created revision
- revisionInfo- the revision info that got associated with the revision
 
- 
invalidateWiringThis is called when a wiring is made invalid and allows the adaptor to react to this. This method is called while holding state change lock for the module as well as for the module database. Care must be taken not to introduce deadlock.- Parameters:
- moduleWiring- the module wiring being invalidated
- current- the current module loader associated with the wiring, may be- null.
 
- 
refreshedSystemModulepublic void refreshedSystemModule()This is called if a request to refresh modules causes the system module to be refreshed. This causes the system module to be stopped in a back ground thread. This method is called before the background thread is started to stop the system module.
- 
updatedDatabasepublic void updatedDatabase()This is called whenever the module database has been updated.
- 
initBeginpublic void initBegin()This is called when theSystemModule.init()is running.
- 
initEndpublic void initEnd()This is called just before theSystemModule.init()returns.
- 
getDebugOptionsReturns the debug options for the module container.- Returns:
- the debug options for the module container, or null if there are no debug options.
 
- 
traceLog a trace message.- Parameters:
- topic- the topic of the trace message
- message- the trace message
- Since:
- 3.23
 
- 
traceThrowableLog a trace exception- Parameters:
- topic- the topic of the trace exception
- t- the exception to trace
- Since:
- 3.23
 
- 
getResolverExecutorReturns the executor used to perform resolve operations- Returns:
- the executor used to perform resolve operations
- Since:
- 3.11
 
- 
getStartLevelExecutorReturns the executor used to by theFrameworkStartLevelimplementation to start bundles that have the same start level. This allows bundles to be started in parallel.- Returns:
- the executor used by the FrameworkStartLevelimplementation.
- Since:
- 3.14
 
- 
adaptModuleRevisionBuilderpublic ModuleRevisionBuilder adaptModuleRevisionBuilder(ModuleContainerAdaptor.ModuleEvent operation, Module origin, ModuleRevisionBuilder builder, Object revisionInfo) Allows a builder to be modified before it is used by the container. This gets call when a new module isinstalledinto the container or when an existing module isupdatedwith a new revision. The container does not call any methods on the builder before calling this method.- Parameters:
- operation- The lifecycle operation event that is in progress using the supplied builder. This will be either- installedor- updated.
- origin- The module which originated the lifecycle operation. The origin may be- nullfor- installedoperations. This is the module passed to the- installor- updatemethod.
- builder- the builder that will be used to create a new- ModuleRevision.
- revisionInfo- the revision info that will be used for the new revision, may be- null.
- Returns:
- The modified builder or a completely new builder to be used by the
         bundle. A nullvalue indicates the original builder should be used, which may have been modified by adding requirements or capabilities.
- Since:
- 3.12
 
- 
getScheduledExecutorReturns the scheduled executor that may be used by the container to schedule background tasks.- Returns:
- the scheduled executor, or null if background tasks are not supported
- Since:
- 3.13
 
 
-