Не удалось загрузить свойства файла Ant (ошибка bcel?) - PullRequest
6 голосов
/ 18 мая 2009

Я работаю над простым сценарием сборки, который должен получить некоторые константы из файла классов java и использовать их в качестве номеров версий в именах моих файлов. Я использую Eclipse и его собственный Ant, но помещаю bcel-5.2.jar в папку libs и в classpath для вызова Ant.

<target name="generate_version" depends="compile">
    <loadproperties srcfile="${dir.dest}/MyVersion.class">
        <classpath>
            <fileset dir="${dir.libs}">
                <include name="**/bcel*.jar"/>
            </fileset>
        </classpath>

        <filterchain>
            <classconstants/>
        </filterchain>
    </loadproperties>
</target>

Но, к сожалению, задача муравья loadproperties терпит неудачу:

build.xml:46: expected a java resource as source

После этого я попытался запустить Ant из-за пределов Eclipse, используя эту командную строку:

set ANT_HOME=C:\Program Files\Java\ant\apache-ant-1.7.1
"%ANT_HOME%\bin\ant.bat"

Результат

Buildfile: build.xml

init:
     [echo] Building project.
     [echo] ant.home:          C:\Program Files\Java\ant\apache-ant-1.7.1
     [echo] ant.java.version:  1.6
     [echo] ant.version:       Apache Ant version 1.7.1 compiled on June 27 2008

compile:
    [javac] Compiling 262 source files to **********\build
    [javac] Note: Some input files use or override a deprecated API.
    [javac] Note: Recompile with -Xlint:deprecation for details.
    [javac] Note: Some input files use unchecked or unsafe operations.
    [javac] Note: Recompile with -Xlint:unchecked for details.

generate_version:

BUILD FAILED
********************\ant\build.xml:46: expected a java resource as source

Я действительно потерян сейчас. Это ошибка bcel? Это несовместимость муравья с моим собственным bcel?

Последний совет: удаление записи пути к классу bcel из целевого объекта Ant приводит к следующему:

Buildfile: build.xml

init:
     [echo] Building project.
     [echo] ant.home:          C:\Program Files\Java\ant\apache-ant-1.7.1
     [echo] ant.java.version:  1.6
     [echo] ant.version:       Apache Ant version 1.7.1 compiled on June 27 2008

compile:
    [javac] Compiling 262 source files to ********************\build
    [javac] Note: Some input files use or override a deprecated API.
    [javac] Note: Recompile with -Xlint:deprecation for details.
    [javac] Note: Some input files use unchecked or unsafe operations.
    [javac] Note: Recompile with -Xlint:unchecked for details.

generate_version:

BUILD FAILED
java.lang.NoClassDefFoundError: org/apache/bcel/classfile/ClassParser
        at org.apache.tools.ant.filters.util.JavaClassHelper.getConstants(JavaClassHelper.java:47)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)

ОБНОВЛЕНИЕ После установки настроек Ant в Eclipse сообщение об ошибке изменилось:

BUILD FAILED
*********************\build.xml:46: org.apache.bcel.classfile.ClassFormatException:  is not a Java .class file
    at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:115)
    at org.apache.tools.ant.Task.perform(Task.java:348)
    at org.apache.tools.ant.Target.execute(Target.java:357)
    at org.apache.tools.ant.Target.performTasks(Target.java:385)
    at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329)
    at org.apache.tools.ant.Project.executeTarget(Project.java:1298)
    at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
    at org.eclipse.ant.internal.ui.antsupport.EclipseDefaultExecutor.executeTargets(EclipseDefaultExecutor.java:32)
    at org.apache.tools.ant.Project.executeTargets(Project.java:1181)
    at org.eclipse.ant.internal.ui.antsupport.InternalAntRunner.run(InternalAntRunner.java:423)
    at org.eclipse.ant.internal.ui.antsupport.InternalAntRunner.main(InternalAntRunner.java:137)

Теперь я думаю, что это может быть конфликт версий между Ant и BCEL. Или BCEL и JDK1.6. Или Затмение, и BCEL, и Муравей, или JDK ... Я потерян.


ОТВЕТ:

Это комментарий найден ниже

Я должен был упомянуть об этом - вам не нужно ничего конвертировать. Док: "так как муравей 1.7, кодировка символов ISO-8859-1 используется для преобразования символов обратно в байт, так что ОДИН ДОЛЖЕН ИСПОЛЬЗОВАТЬ ЭТО КОДИРОВАНИЕ для чтения файла классов Java. "Это просто соглашение обойти тот факт, что символьный фильтр используется на сырых байтах. ant.apache.org/manual/CoreTypes/… Использование UTF-8 было бы плохо! - Макдауэлл

Ответы [ 3 ]

1 голос
/ 18 мая 2009

В документации для loadproperties говорится, что вложенный элемент classpath предназначен для использования с атрибутом resource - альтернатива использованию srcfile .

Добавьте банку BCEL в глобальный путь к классам. В Eclipse добавьте его как глобальную запись в ваш путь к классам в предпочтениях времени выполнения . В командной строке используйте ключ -lib .

alt text
(источник: eclipse.org )

1 голос
/ 18 мая 2009

Дерьмо, я это знал! Все сводится к проблемам кодировки файлов. Файлы все еще находятся в ISO-8819-1, но я использую UTF-8. Проект довольно старый и был создан с неправильной кодировкой. Установка параметра кодировка в javac и loadproperties Задача исправляет его.

<target name="generate_version" depends="compile">
    <loadproperties encoding="iso-8859-1" srcfile="${dir.dest}/MyVersion.class">
        <filterchain>
            <classconstants/>
        </filterchain>
    </loadproperties>
</target>

Я думал, что это изменилось нашим сервером Subversion, но я думаю, что теперь мне нужно конвертировать каждый отдельный файл в UTF-8 ... думаю, это другой вопрос для SO.

0 голосов
/ 18 мая 2009

Похоже, ошибка пути к классу. Запустите "ant -v", чтобы получить более подробную информацию об ошибках.

...