Pergunta

Eu tenho ant script em execução normal, dentro do Eclipse Aqui é um pedaço dele :

<p2.composite.repository failOnExists="true">
            <repository location="file:/${basedir}/compRepo" name="Repository description goes here" />
            <add>
                <repository location="http://url/Eclipse/repo/Galileo-3.5.1/" />
                <repository location="http://another-url/Java/repo/4.0/" />
                <repository location="${diag.location}" />
            </add>
        </p2.composite.repository>

Mas eu gostaria de Hudson CI servidor para ser capaz de executá-lo, mas, independentemente de todas as jarras que eu coloquei na ANT_HOME/lib eu não posso chegar a essa tarefa para ser executado em uma linha de comando simples formiga...Eu fiquei preso com este erro :

C:\workspaces\workspace\project\junit.script\createCompRepo.xml:10: Problem: failed to create task or type p2.composite.repository
Cause: The name is undefined.
Action: Check the spelling.
Action: Check that any custom tasks/types have been declared.
Action: Check that any <presetdef>/<macrodef> declarations have taken place.

Onde são definidas as p2 formiga tarefas ?Existe uma maneira de executá-los fora do Eclipse ?Obrigado muito muito para te ajudar !Anthony

Foi útil?

Solução

Pela leitura este tópico e a Documentação do editor P2, deveria estar em org.eclipse.equinox.launcher_*.jar

Exemplo de uma tarefa P2 (não uma tarefa de formiga aqui) apenas para o -jar argumento:

java -jar <targetProductFolder>/plugins/org.eclipse.equinox.launcher_*.jar
 -application org.eclipse.equinox.p2.publisher.UpdateSitePublisher
 -metadataRepository file:/<some location>/repository
 -artifactRepository file:/<some location>/repository
 -source /<location with a site.xml>
 -configs gtk.linux.x86
 -compress 
 -publishArtifacts

o As tarefas de formiga P2 são descritas aqui, E no Ajuda eclipse.


O op Anthony43 Adiciona nos comentários:

Eu só quero executar um alvo de formigas com P2 TaskDefs, fora do Eclipse.
Eu descobri que deveria usar antRunner, usando essa linha de comando:

./eclipse -vm /opt/sun-java2-6.0/bin/java -nosplash \
-data ${java.io.tmpdir}/workspace -consolelog       \
-application org.eclipse.ant.core.antRunner         \
-f /path/to/scripts/partialMirrorFromRepo.xml 

Mas Andrew Niefer (ECLIPSE COMPTTER ON PDE/BUILD, P2 e Equinox Framework) Adiciona:

o As tarefas P2 precisam ser executadas dentro de um ambiente OSGI e não funcionam em uma corrida de formiga normal.
É por isso que você precisa usar o org.eclipse.ant.core.antRunner inscrição.
Começando com "java -jar lançador.jar" é apenas um método alternativo para invocar o executável do Eclipse.


Martin Jakubik menciona:

Eu gostaria de ver um comando que eu poderia cortar e colar e que junte tudo.
O que eu usei foi:

java -jar <eclipse-install-directory>\eclipse\plugins\org.eclipse.equinox.launcher_*.jar -application org.eclipse.ant.core.antRunner. 

Observe que eu não conseguia descobrir o que <targetProductFolder> Era, então eu usei <eclipse-install...> em vez de.

Outras dicas

Eu criei uma pequena macro de formiga para esse propósito exato

<path id="equinox.launcher.path">
    <fileset dir="${eclipse.home}/plugins">
        <include name="org.eclipse.equinox.launcher_*.jar" />
    </fileset>
</path>

<macrodef name="antRunner">
    <!-- Ant script location -->
    <attribute name="antFile" />
    <!-- the arguments for the script that is executed -->
    <attribute name="args" default=""/>
    <sequential>
        <java 
            classname="org.eclipse.equinox.launcher.Main" 
            fork="true" 
            failonerror="true">

            <arg line="-application org.eclipse.ant.core.antRunner" />
            <arg line="-f @{antFile}" />
            <arg line="@{args}"/>
            <classpath refid="equinox.launcher.path" />
        </java> 
    </sequential>
</macrodef>

Todos os p2 tarefas PRECISAM do eclipse de tempo de execução (como declarado explicitamente no eclipse ajudar mencionado acima), então você definitivamente precisa usar o eclipse.

A única maneira de dar a volta dele seria a de analisar o eclipse código, extrair o que é necessário e criar o seu próprio sistema de compilação com ele.

Apenas para completar o exemplo de Jarek Przygódzki Aqui está minha solução, usando o arquivo de formiga dele. Não sou bem versado em usar a ANT, portanto, pode haver potencial para otimização. Essa abordagem é usada sem cabeça em um servidor sem GUI, no entanto, eu tive que instalar o Eclipse. A instalação com o APT-GET não estava funcionando, por isso é melhor instalar o manual (download e unt).

  1. O primeiro arquivo de anti -arquivo reúne nomes, versões, etc ...
  2. O segundo arquivo é chamado do First Filfile e cria repositórios compostos.

Primeiro anti -arquivo:

<project name="project">

<!-- ....do some other stuff...-->

<target name="p2.composite.add">

<!--Call macro for child repo-->
 <antRunner
    name="${site.composite.name}"
    location="${composite.repository.directory}"
    child="${child.repository}"
/>  

<!--Call macro for main repo-->
<antRunner
    name="${main.site.composite.name}"
    location="${main.composite.repository.directory}"
    child="${majorMinorVersion}"
/> 

</target>

<!--Eclipse installation path-->
<path id="equinox.launcher.path">
    <fileset dir="/usr/share/eclipse/plugins">
        <include name="org.eclipse.equinox.launcher_1.3.201.v20161025-1711.jar" />
    </fileset>
</path>

<macrodef name="antRunner">

    <attribute name="name"/>    
    <attribute name="location"/>
    <attribute name="child"/>

    <sequential>

        <java 
            classname="org.eclipse.equinox.launcher.Main" 
            fork="true" 
            failonerror="true">

            <arg line="-application org.eclipse.ant.core.antRunner" />
            <arg line="-f addCompositeInternal.ant run" />
            <arg line="-Dcomposite.name=@{name}"/>
            <arg line="-Dcomposite.location=@{location}"/>
            <arg line="-Dcomposite.child=@{child}"/>
            <classpath refid="equinox.launcher.path" />
        </java> 
    </sequential>
</macrodef>

</project>   

Segundo arquivo de formal, nomeado addComposeinternal.ant

<project name="composite">
<target name="run">
            <add.composite.repository.internal
                composite.repository.location="${composite.location}"
                composite.repository.name="${composite.name}"
                composite.repository.child="${composite.child}"
            />
</target>      

<!-- = = = = = = = = = = = = = = = = =
      macrodef: add.composite.repository.internal          
     = = = = = = = = = = = = = = = = = -->
<macrodef name="add.composite.repository.internal">
    <attribute name="composite.repository.location" />
    <attribute name="composite.repository.name" />
    <attribute name="composite.repository.child" />
    <sequential>

        <echo message=" " />
        <echo message="Composite repository       : @{composite.repository.location}" />
        <echo message="Composite name             : @{composite.repository.name}" />
        <echo message="Adding child repository    : @{composite.repository.child}" />

        <p2.composite.repository>
            <repository compressed="false" location="@{composite.repository.location}" name="@{composite.repository.name}" />
            <add>
                <repository location="@{composite.repository.child}" />
            </add>
        </p2.composite.repository>

        <echo file="@{composite.repository.location}/p2.index">version=1
   metadata.repository.factory.order=compositeContent.xml,\!
   artifact.repository.factory.order=compositeArtifacts.xml,\!
   </echo>

    </sequential>
</macrodef>

</project>
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top