0

TFS プロジェクト フォルダーに ant ターゲットの xml ファイルがあります。プロジェクト フォルダは TFS(Team Foundation Server) にバインドされています。私の問題は、その TFS バインドされた場所で ant ターゲットを実行してプロジェクトをビルドしようとすると失敗することです。次の失敗が発生します。

> ria_ant_build.xml:435: Error running C:\Program Files\Java\jdk1.6.0_20\bin\javac.exe  compiler
        at org.apache.tools.ant.taskdefs.compilers.DefaultCompilerAdapter.executeExternalCompile(DefaultCompilerAdapter.
java:508)
        at org.apache.tools.ant.taskdefs.compilers.JavacExternal.execute(JavacExternal.java:61)
        at org.apache.tools.ant.taskdefs.Javac.compile(Javac.java:1153)
        at org.apache.tools.ant.taskdefs.Javac.execute(Javac.java:930)
        at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
        at sun.reflect.GeneratedMethodAccessor7.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
        at org.apache.tools.ant.Task.perform(Task.java:348)
        at org.apache.tools.ant.Target.execute(Target.java:392)
        at org.apache.tools.ant.Target.performTasks(Target.java:413)
        at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
        at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
        at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
        at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
        at org.apache.tools.ant.Main.runBuild(Main.java:811)
        at org.apache.tools.ant.Main.startAnt(Main.java:217)
        at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
        at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
Caused by: java.io.IOException: Cannot run program "C:\Program Files\Java\jdk1.6.0_20\bin\javac.exe": CreateProcess erro
r=87, The parameter is incorrect
        at java.lang.ProcessBuilder.start(ProcessBuilder.java:460)
        at java.lang.Runtime.exec(Runtime.java:593)
        at org.apache.tools.ant.taskdefs.Execute$Java13CommandLauncher.exec(Execute.java:862)
        at org.apache.tools.ant.taskdefs.Execute.launch(Execute.java:481)
        at org.apache.tools.ant.taskdefs.Execute.execute(Execute.java:495)
        at org.apache.tools.ant.taskdefs.compilers.DefaultCompilerAdapter.executeExternalCompile(DefaultCompilerAdapter.
java:505)
        ... 19 more
Caused by: java.io.IOException: CreateProcess error=87, The parameter is incorrect
        at java.lang.ProcessImpl.create(Native Method)
        at java.lang.ProcessImpl.<init>(ProcessImpl.java:81)
        at java.lang.ProcessImpl.start(ProcessImpl.java:30)
        at java.lang.ProcessBuilder.start(ProcessBuilder.java:453)
        ... 24 more

しかし、プロジェクトを別の場所にコピーし、フォルダーから読み取り専用属性を削除すると、ant ターゲットはエラーなしで実行され、デプロイ可能なアーティファクトが得られます。しかし、TFS フォルダーから読み取り専用属性を削除しても、Ant ターゲットをビルドできませんでした。TFS の場所自体に問題があるようです。:(

この問題を解決する方法を教えてください。私はTFSの場所にとどまらなければなりません。あなたたちは私が推測する理由を知っています:)

-- ありがとうございます、ランガナ

4

1 に答える 1

1

あなたの質問から、あなたの問題の本当の原因を突き止めるのは難しいです。

おそらく、ant 呼び出しの長さが長すぎて、最大コマンド プロンプト ライン (最新バージョンの Windows では 8191 文字) よりもさらに長くなっています。質問Fail to launch application (CreateProcess error=87), can't use short classpath workaroundは、「フォルダー名を短くする、フォルダー ツリーの深さを減らす、パラメーター ファイルを使用するなど」を検討できると述べています。

-debugオプションを指定してantを実行して、TFS ワークスペース内のビルド呼び出しの特定のコマンド ライン パラメーターを確認してください。このようにして、通話の合計時間を見積もることができます。

于 2012-09-24T18:19:18.030 に答える