Dear all,
here are the paragraphs I want to add to the "Contributing to
Infinispan" page in relation to the API, Commons, Core split. Comment
please on clarity, grammar, spelling, etc
API, Commons, Core
In order to provide proper separation between public APIs, common
utilities and the actual implementation of Infinispan, these are split
into 3 modules: infinispan-api, infinispan-commons and infinispan-core.
This separation also makes sure that modules, such as the remote
clients, don't have to depend on infinispan-core and its transitive
dependencies. The following paragraphs describe the role of each of
these modules and give indication as to what goes where.
API
The infinispan-api module should only contain the public interfaces
which can be used in any context (local, remote, etc). Ideally it should
not contain any concrete classes, however this rule can be relaxed for
small, self-contained classes which need to be referenced from the API
interfaces. When promoting interfaces from infinispan-core to
infinispan-api, please bear in mind the type of functionality that is
being exposed: if something only makes sense for local mode and not for
remote mode (e.g. eviction), then it should remain in infinispan-core.
Commons
The infinispan-commons module contains utility classes which can be
reused across other modules. Classes in infinispan-commons should be
self-contained and not pull in unnecessary dependencies. They should
also make no reference to configuration aspects specific to a particular
environment.
Core
The infinispan-core module contains the actual implementation used for
local/embedded mode. When adding new functionality to the APIs, it is
generally safe to start by putting them in infinispan-core and promoting
them to infinispan-api only when it is deemed to do so and it makes
sense across the various use-cases.