How do I build an Eclipse RCP app so that its features can be updated automatically?

前端 未结 3 906
傲寒
傲寒 2021-02-04 18:45

I am building an RCP application that will be made up of several Features.

My RCP application is configured to check for updates each time it starts. My current probl

相关标签:
3条回答
  • 2021-02-04 19:16

    Before I found the answer that is documented here and accepted, I tried and failed to solve this problem in the following ways:

    I tried putting the Feature in the product definition. This get's the feature installed successfully, but it takes away my ability to have it update independently from other features in the RCP application.

    I have a p2 touchpoint command that is currently working. It adds a repository to the available update sites in the RCP application using a p2.inf file. It looks like this...

    instructions.configure=\
     org.eclipse.equinox.p2.touchpoint.eclipse.addRepository(location:http${#58}//myUpdateSsite/myFeature,type:0,name:My Feature Name,enabled:true);\
     org.eclipse.equinox.p2.touchpoint.eclipse.addRepository(location:http${#58}//myUpdateSsite/myFeature,type:1,name:My Feature Name,enabled:true);\\
    

    I've tried to add a line like this to get that feature installed, but my tycho build fails when I run mvn clean install

    instructions.configure=\
     org.eclipse.equinox.p2.touchpoint.eclipse.installFeature(feature:My Feature Name,featureId:com.my.domain.my.feature.id,version:1.0.0);
    

    Here's some of the error message from maven / tycho

    An error occurred while configuring the installed items session context was:
    (profile=DefaultProfile, phase=org.eclipse.equinox.internal.p2.engine.phases.Configure, operand=null --> 
    [R]{my.domain.my.rcp.product.plugin 1.1.6.20120427-1346}, 
    action=org.eclipse.equinox.internal.p2.touchpoint.eclipse.actions.InstallFeatureAction).
    Installable unit contains no artifacts: [R]my.domain.my.rcp.product.plugin 1.1.6.20120427-1346.
    

    My intuition tells me that this error message is saying that my RCP application plugin is missing something that will tell p2 where to find the feature that I want to install at build time. I think???

    0 讨论(0)
  • 2021-02-04 19:19

    In the meanwhile, Tycho has explicit support for this use case. Starting with Tycho 0.20.0, you can make Tycho install features of an RCP separately from the product. In this way, these features can be updated (or even be uninstalled) independently of the product.

    To install features independently, just add an attribute installMode="root" to the respective feature tags in the product file. Example:

    <features>
       <feature id="org.eclipse.platform"/>
       <feature id="updatable.feature" installMode="root"/>
    </features>
    

    For more information, see this documentation page.

    0 讨论(0)
  • 2021-02-04 19:36

    After a long search, I have found the answer. It's kind of a kludge, but I'm willing to do anything at this point. My solution is dependent upon the fact that my built RCP application includes p2 application org.eclipse.equinox.p2.director. I guess if your RCP app doesn't contain this application, you can refer to another Eclipse install in order to launch the Director. I just did it this way to avoid having an instance of Eclipse sitting on my build machine.

    I used the p2-dev mailing list, and Paul Webster answered my question. (Thanks Paul)

    He suggested using ant to launch the p2 director application to install the IU into my built RCP application.

    Here's his answer on the p2-dev mailing list http://dev.eclipse.org/mhonarc/lists/p2-dev/msg04735.html

    Here's the ant target I came up with.

    <target name="install_IU">
      <path id="launcher.paths">
        <fileset
           dir="${app.dir}"
           includes="plugins/org.eclipse.equinox.launcher_*" />
      </path>
      <property
          name="launcherPath"
          refid="launcher.paths" />
      <echo>-installIU ${iu.id} </echo>
      <java 
          jar="${launcherPath}"
          failonerror="false"
          dir="${app.dir}"
          timeout="900000"
          fork="true"
          output="${basedir}/director.log"
          resultproperty="directorcode">
          <arg line="-application org.eclipse.equinox.p2.director" />
          <arg line="-noSplash" />
          <arg line="-installIUs ${iu.id}" />
          <arg line="-repository ${iu.repo}" />
          <arg line="-destination ${app.dir}" />
          <arg line="-bundlepool ${app.dir}" />
      </java>
    
      <zip destfile="${app.zip}"
        basedir="${app.dir}"/>
    </target>
    

    I put this in an ant file in the same project that produces my Eclipse RCP application via Tycho. Tycho produces my build artifacts in a directory called "target" so my parameters to the ant target above look like this...

    <target name="modify_x86">
      <antcall target="install_IU">
        <param name="iu.id" value="com.mydomain.the.feature.i.want.to.install.feature.feature.group"/>
        <param name="iu.repo" value="http://mydomain.com/thep2repository/where/i/deploy/the/feature/to/install"/>
        <param name="app.dir" value="${basedir}/target/products/com.mydomain.myRCPapplication/win32/win32/x86"/>
        <param name="app.zip" value="${basedir}/target/products/com.mydomain.myRCPapplication-win32.win32.x86.zip"/>
      </antcall>
    </target>
    

    I have a few more of these targets for each platform that my RCP application is built for.

    Hope this helps.

    UPDATE: May 8th, 2014. Tobias has brought it to my attention that I should change the accepted answer from this one to the one that has the new feature that was added to Tycho 0.20.0 that enables this behavior in a much more simple fashion. So, the new accepted answer is the proper solution for this question now.

    0 讨论(0)
提交回复
热议问题