ModuleDefinition construction WAS Re: Goals was: Re: Supporting OSGi Bundles in the Java Module System

Stanley M. Ho Stanley.Ho at sun.com
Fri Jun 13 17:12:36 PDT 2008


Adrian Brock wrote:
> I see a number of possible use cases here 
> (I'll continue with appserver example):
> 
> 1) Fully JSR 277
> 
> The appserver and JavaEE specs are updated to fully understand
> JSR277/294. In this case, the JavaEE deployment process would 
> probably make use of a JSR 277 repository.
> 
> 2) Partial JSR 277
> 
> The appserver knows about JSR277/294 but the JavaEE specs
> haven't been updated (or they are legacy deployments).
> 
> In this case the appserver could try to adapt the deployments
> to conform to the ModuleDefinition/Content.
> 
> In this case, there probably wouldn't be a real repository
> implementation, instead the "repository" would be dummy.
> It would just be serving as an adapter from the old deployment packaging
> and metadata to the new one at runtime.
> 
> 3) Mixed
> 
> Similar to 2, but the opposite. 
> The appserver knows about JSR277/294 and wants to support
> .jam files as well as .jar files in JavaEE deployments.
> i.e. .jam files would be unpacked from a .jar EAR deployment
> and then added to the module system runtime.
> 
> Conclusion:
> 
> I expect there are other possible uses.
> 
> The question is whether Repository is the best api
> for cases (2) and (3). i.e. we implement a dummy
> repository with a dummy "URL" for the source
> or whether there should be a more abstract parent
> class (I called it ModuleSource) that doesn't
> assume a physical repository behind the scenes.
> 
> At least for cases (2) and (3) all we really want
> to do is to PUSH a ModuleDefinition/Content to the
> jsr 277 module system such that we can get back
> a Module/Classloader with the imports resolved.

In your example, if you want to create ModuleDefinitions from the .jar 
files, there are two ways to achieve it:

1. a. Create a ModuleContent based on the content of the .jar file.
    b. Generate the JAM's metadata based on information in the .jar file.
    c. Construct a JAM's ModuleDefinition with the ModuleContent using
       Modules.newJamModuleDefinition(). The ModuleDefinition would be
       associated with the JAM module system.

2. a. Create a ModuleContent based on the content of the .jar file.
    b. Create your own ModuleDefinition with the ModuleContent and use
       the JAM module system as the associated module system. As long as
       your ModuleDefinition exposes the appropriate metadata information
       reflectively, the JAM module system would treat it like other
       JAM's ModuleDefinitions.

In either case, the JAM module system could be used to instantiate and 
initialize Module/ClassLoader from the ModuleDefinition.


Creating a repository implementation is a different story. In the 
current draft API, you do need to override a number of methods in 
Repository in order to have a functional repository implementation. I 
still think Repository is the api for module systems to find 
ModuleDefinitions. The question is how we could change the API to make 
it much easier for developers to create custom repository implementation.

Perhaps we should provide more useful default implementation in the 
Repository's methods so developers only need to override very small 
number of methods. Or perhaps what we really need is a repository 
builder which allows developers to provide a set of ModuleDefinitions 
and get back a basic repository implementation to use.

I'll look into the draft API to see if further simplifications can be made.

- Stanley



More information about the jsr277-eg-observer mailing list