The problem with using executions is that it forces you to add the obr plugin 
to all bundle projects and that could be a lot.

For me it's all the same, build bundle, deploy bundle and since there's no 
point of deploying a bundle to an OBR without being a bundle to start with I 
think these two plugins would benefit greatly if they were combined. 

In fact the bundle plugin already has it's own config by using <instructions> 
so maybe add a <obr> section?

Patrick


-----Original Message-----
From: Stuart McCulloch <[EMAIL PROTECTED]>
Sent: Tuesday, January 29, 2008 4:42pm
To: [EMAIL PROTECTED], [EMAIL PROTECTED], [email protected]
Subject: Re: Bundle and OBR plugins

On 30/01/2008, Patrick Shea <[EMAIL PROTECTED]> wrote:
>
> I've been trying to use these two plugins together but I got the
> impression that maven would not let two plugins take over the lifecycle
> during the same build.


the maven OBR plugin does not specify a lifecycle - you should use
executions:


http://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html#Plugins

Since these two are really close maybe it would be a good idea to merge
> them.


they are already partially merged - the "bundle" packaging lifecycle will
invoke
code from the OBR plugin to update the local OBR repository.xml file on
install

the reason they're not fully merged is because the OBR plugin also provides
additional goals that are outside of the scope of the bundleplugin - if you
want
to use these goals from your pom.xml then you only need to add an execution
section, as shown later on...

(this is how maven works - otherwise you'd end up merging all sorts of
plugins
 into one uber-plugin that would then be much harder to maintain and debug)

So the goals would be to
>
> 1. Add osgi info to manifest (bundle plugin)
> 2. Update local obr repository (obr plugin)
> 3. Update remote obr repository (obr plugin)


1 + 2 are already there: if you use the 1.2.0 bundleplugin or later you will
see it
update the local repository.xml file on the install phase. However, 3 is not
done
because the remote deploy goal from the OBR plugin is not used as much and
it can always be enabled on a per-project basis using the following
fragment:

      <plugin>
        <groupId>org.apache.felix</groupId>
        <artifactId>maven-obr-plugin</artifactId>
        <version>1.0.0</version>
        <executions>
          <execution>
            <id>obr:deploy</id>
            <goals>
              <goal>deployment</goal>
            </goals>
          </execution>
        </executions>
      </plugin>

you then have to enable this goal with an extra flag:

   mvn deploy -Dmaven.obr.installToRemoteOBR

in the next release, I'm updating the OBR plugin to use standard goal names
and removing the installToRemoteOBR flag as it's not really needed now (you
can achieve the same with profiles in the pom) which means you only need
to use the following to enable remote OBR deployment:

      <plugin>
        <groupId>org.apache.felix</groupId>
        <artifactId>maven-obr-plugin</artifactId>
        <version>1.2.0-SNAPSHOT</version>
        <executions>
          <execution>
            <id>obr:deploy</id>
            <goals>
              <goal>deploy</goal>
            </goals>
          </execution>
        </executions>
      </plugin>

and it will update the remote OBR on every "mvn deploy"

We could add a switch (obr local/remote/off) to turn on/off obr processing.
>
> This plugin would be tied to the "bundle" project type like the current
> bundle plugin.


-- 
Cheers, Stuart



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

Reply via email to