Gentoo style pom dependencies
-----------------------------

         Key: MNG-935
         URL: http://jira.codehaus.org/browse/MNG-935
     Project: Maven 2
        Type: Wish
 Environment: None appropriate
 Reporter: Brian C. Dilley


I'm a long time Gentoo Linux (http://www.gentoo.org/) user, and i think that 
Maven could adpot some idea's from gentoo's portage 
(http://www.gentoo.org/doc/en/handbook/handbook-x86.xml?part=2&chap=1).

Gentoo has a concept of "ebuilds" (which can be compared to poms).  An ebuild 
is an install script of sorts for installing a particular piece of software.  
An ebuild defines, among other things, what it's dependencies (other ebuilds) 
are.  There are two types of dependencies: optional and required.  A required 
depency is something that the software needs to be built or run, while an 
optional depency is the exact opposite... it is optional at compile and run 
time.  Basically an optional depency is a feature that the piece of sotware 
supports that isn't necessary for it to function.

There is also something in gentoo called "USE flags".  Use flags are a system 
scope set of parameters that determine how ebuilds are built... and which 
features are included or excluded.  For instance, "alsa" is a USE flag.  If 
your use flags have "alsa" in them then any application that supports Alsa 
(Advanced Linux Sound Architecture) as an optional dependency will be compiled 
with support for alsa.  Likewise, if your USE flags contain "-alsa" then 
anything that has optional support for alsa will not be compiled with support 
for alsa.  I should also mention that if a particular ebuild requires alsa... 
alsa will be built as well as it (because it requires alsa at compile/run 
time)... but it and anything else that requires it will be the only piece of 
software on the machine that has alsa support.  I should also note that Gentoo 
has what is called "profiles".  Profiles contain (among other things) a default 
set of USE flags for the general user, so in theory a Gentoo user doesn't have 
to modify their USE flags whatsoever.

My thinking is that Maven could adopt this.   Poms could specify required and 
optional dependencies,  and at a project level USE flags could be defined to 
filter what gets included in a project. For instance someone using the Spring 
Framework may not be using Hibernate... in their use flags "-hibernate" could 
be defined so that maven knows not to grab hibernate (and all of it's 
dependencies) just because they want to use the spring MVC framework.



-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
   http://jira.codehaus.org/secure/Administrators.jspa
-
For more information on JIRA, see:
   http://www.atlassian.com/software/jira


---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to