Вопрос

У меня есть ant-скрипт, который отлично работает внутри Eclipse Вот его фрагмент :

<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>

Но я бы хотел, чтобы сервер Hudson CI мог его запускать, но, независимо от того, сколько банок я поместил в ANT_HOME / lib, я не могу запустить эту задачу в простой командной строке ant...Я застрял с этой ошибкой :

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.

Где определены муравьиные задачи p2 ?Есть ли способ запустить их вне Eclipse?Большое вам спасибо за вашу помощь!Энтони

Это было полезно?

Решение

Читая этот поток и тот Документация издателя P2, это должно быть в org.eclipse.equinox.launcher_*.jar

Пример задачи P2 (здесь не ant-задача) только для -jar аргумент:

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

Тот самый Задачи Ant P2 описаны здесь, и в Справка Eclipse.


Операция Антони43 добавляет в комментариях:

Я просто хочу запустить цель ant с помощью p2 taskdefs, за пределами eclipse.
Я узнал, что мне следует использовать antRunner, используя такую командную строку :

./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 

Но Эндрю Нифер (Коммиттер Eclipse в PDE / Build, p2 и Equinox Framework) добавляет:

Тот самый задачи p2 должны выполняться в среде osgi и не будут работать при обычном запуске ant.
Вот почему вам нужно использовать org.eclipse.ant.core.antRunner применение.
Запуск с "java -jar launcher.jar" - это просто альтернативный метод для вызова исполняемого файла eclipse.


мартин якубик упоминания:

Мне бы хотелось увидеть команду, которую я мог бы вырезать и вставить и которая собрала бы все воедино.
То, что я использовал, было:

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

Обратите внимание, что я не смог понять, что <targetProductFolder> был, поэтому я использовал <eclipse-install...> вместо этого.

Другие советы

Я создал небольшой макрос Ant именно для этой цели

<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>

Для всех задач p2 ТРЕБУЕТСЯ среда выполнения eclipse (как явно указано в справке eclipse, упомянутой выше), поэтому вам определенно нужно использовать eclipse.

Единственный способ обойти это - проанализировать код eclipse, извлечь то, что необходимо, и создать на его основе свою собственную систему сборки.

Просто для завершения примера Jarek Przygódzki вот мое решение, использующее его ant-файл.Я не очень хорошо разбираюсь в использовании ant, так что, возможно, есть потенциал для оптимизации.Этот подход используется без головы на сервере без графического интерфейса, тем не менее мне пришлось установить eclipse.Установка с помощью apt-get не сработала, поэтому лучше установить вручную (загрузить и распаковать).

  1. Первый antfile собирает имена, версии и т.д...
  2. Второй antfile вызывается из первого antfile и создает составные репозитории.

Первый файл antfile:

<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>   

Второй Antfile с именем addCompositeInternal.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>
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top