You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@felix.apache.org by "Gavin Lei (JIRA)" <ji...@apache.org> on 2011/03/31 05:06:06 UTC

[jira] [Updated] (FELIX-2898) test

     [ https://issues.apache.org/jira/browse/FELIX-2898?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Gavin Lei updated FELIX-2898:
-----------------------------

           Description: test  (was: Recently, i am working on split my huge project in to many small sub-projects on OSGi way. Obviously, i want to use Felix as my OSGi framework, but as you know, this splitting job is a long and boring process. So, i am thinking that why can we build some tools for us to do this job ?

We want to build a bnd(tools) based OSGi bunlles maker project, it will help us analyse java application and split the whole project into several OSGi bundles.

The trick is to find strongly coupled packages. These are packages that are in a cycle. A -> B -> C -> A. Normally I find that these packages should be in the same bundle. In bnd (the current next branch) I already can calculate those strongly connected packages. In general, I find that many, especially larger, bundles consist of a number of subsystems.

These subsystems have dependencies on each other, however, by definition there is no cycle between these subsystem dependencies (otherwise they would be strongly connected and be part of the same subsystem).

There should be the following types of subsystems:

API - Self contained, no internal dependencies. All exported/imported. Very few dependencies. The OSGi specification packages are prime examples. Having imports in these packages is always suspect. In my experience, API must be maintained independently but carried in the bundle that implements the API.
Library - Exported code == implementation. Few imports, everything is exported and in general packages are not substitutable.
Implementation - Private code. No exports, many imports, If it provides an API it should carry the API packages.
Bridge - Connects an external subsystem to an internal subsystem. Imports impl. code, no exports. This case is special because they tend to drag in a lot dependencies that are only required when the dependency is already there. For example, a subsystem can provide packages that make it useful in Spring. I.e. it does not require Spring but when other people use spring the package can be used in that connected world. Another example is bnd. It is an ant task but it should only require ant when it runs inside ant.)
           Environment: test  (was: Eclipse platform, this project add a new tool for Felix users to improve OSGi bundles development process in Eclipse environment)
    Remaining Estimate: 1m  (was: 1680h)
     Original Estimate: 1m  (was: 1680h)
               Summary: test  (was: [GSoc 2011]Bndtools based OSGi bundles maker project)

> test
> ----
>
>                 Key: FELIX-2898
>                 URL: https://issues.apache.org/jira/browse/FELIX-2898
>             Project: Felix
>          Issue Type: Task
>         Environment: test
>            Reporter: Gavin Lei
>   Original Estimate: 1m
>  Remaining Estimate: 1m
>
> test

--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira