flexClient_<число>.cache (такого файла или каталога нет)
У нас есть машина Linux (Red Hat) для компиляции нашего приложения flex (3.0). Это задача муравья (которая вызывается maven-antrun-plugin).
Мы решили изменить нашу сборочную машину (та же Red Hat).
Поэтому я копирую / вставляю реперторий FLEX_HOME на новую машину (со старой), устанавливаю ant и проверяю проект на новой машине.
Вот журнал, когда я звоню: ant -buildfile build-flex.xml
Buildfile: build-flex.xml
версия:
[echo] Версия $ {maven.pom.version}
[копия] Копирование 1 файла в / home / ad59aphr / build / pharerh-ihm / flex_resourcescompile.release:
[mxmlc] Загрузка файла конфигурации /exec/products/flex_sdk/frameworks/flex-config.xml
[mxmlc] /home/ad59aphr/build/pharerh-ihm/flex_src/flexClient_381495.cache (нет такого> файла или каталога)
Большую часть времени он зависает здесь с Java, используя 100% процессора. Иногда он показывает несколько предупреждений из компиляции, но не идет дальше.
Когда я использую ant -debug -buildfile build-flex.xml, он показывает выполненную команду:
[mxmlc] FlexTask.execute: -compiler.keep-generate-actionscript=true -compiler.incremental=true +flexlib=/exec/products/flex_sdk/frameworks -compiler.services=/home/ad59aphr/build/pharerh-ihm/WebContent/WEB-INF/flex/services-config.xml -metadata.description=PhareRH -metadata.title=PhareRH -compiler.accessible=true -compiler.optimize=true -compiler.strict=true -compiler.headless-server=true -load-config=/exec/products/flex_sdk/frameworks/flex-config.xml -compiler.source-path=/exec/products/flex_sdk/frameworks -compiler.source-path=/home/ad59aphr/build/pharerh-ihm/flex_resources -compiler.source-path=/home/ad59aphr/build/pharerh-ihm/flex_src -compiler.source-path=/home/ad59aphr/build/pharerh-ihm/flex_src_gen -compiler.context-root=/ -compiler.debug=false -compiler.include-library +=/home/ad59aphr/build/pharerh-ihm/flex_libs/Cairngorm.swc -compiler.include-library +=/home/ad59aphr/build/pharerh-ihm/flex_libs/Collator.swc -compiler.include-library +=/home/ad59aphr/build/pharerh-ihm/flex_libs/automatic.swc -compiler.include-library + = / home / ad59aphr / build / pharerh-ihm / flex_libs / Automation_agent.swc -compiler.include-library + = / home / ad59aphr / build / pharerh-ihm / flex_libs / Automation_dmv.swc -compiler.include-library +=/home/ad59aphr/build/pharerh-ihm/flex_libs/qtp.swc - /home/ad59aphr/build/pharerh-ihm/flex_src/flexClient.mxml
Я не вижу никакой разницы между рабочей машиной (старой) и этой новой машиной в отношении результатов отладки.
Я попытался скопировать старый файл.cache на новый компьютер (+ изменив номер), он дает мне:
compile.release:
[mxmlc] Загрузка файла конфигурации /exec/products/flex_sdk/frameworks/flex-config.xml
[mxmlc] Не удалось сопоставить цель компиляции с /home/ad59aphr/build/pharerh-ihm/flex_src/flexClient_381495.cache. Файл кэша не будет использоваться повторно.
Я попытался изменить -incremental на false в build-flex.xml, но результат тот же: застрял.
Я попытался скомпилировать в root, чтобы избежать проблем с правами, тот же результат.
Мой build-flex.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!-- $HeadURL: http://svnserver.mdp/pharerh/branches/G1R3/developpement/pharerh-ihm/build-flex.xml $ -->
<!-- WARNING: Eclipse auto-generated file.
Any modifications will be overwritten.
To include a user specific buildfile here, simply create one in the same
directory with the processing instruction <?eclipse.ant.import?>
as the first entry and export the buildfile again. -->
<project basedir="." default="release" name="iah-admin-ui">
<property environment="env" />
<property name="WebApp.location" value="${env.TOMCAT_HOME}/webapps/pharerh-ihm" />
<property name="flexClient.location" value="${basedir}" />
<property name="FLEX_HOME" value="${env.FLEX_HOME}" />
<property name="FDS_CONFIG_FILE" value="${env.FLEX_HOME}/frameworks/flex-config.xml" />
<property name="webcontent_location" value="${flexClient.location}/WebContent" />
<property name="FDS_SERVICES_CONFIG_FILE" value="${flexClient.location}/WebContent/WEB-INF/flex/services-config.xml" />
<taskdef resource="flexTasks.tasks" classpath="${env.FLEX_HOME}/ant/lib/flexTasks.jar" />
<target name="version">
<echo message="Version ${maven.pom.version}" />
<copy file="${flexClient.location}/flex_templates/version.properties" toDir="${flexClient.location}/flex_resources/" overwrite="true">
<filterset>
<filter token="generated" value="# ATTENTION : Ce fichier est le resultat d'une generation automatique. Ne pas editer." />
<filter token="version" value="${maven.pom.version}" />
</filterset>
</copy>
</target>
<target name="compile.release" depends="version">
<mxmlc file="${flexClient.location}/flex_src/flexClient.mxml" keep-generated-actionscript="true" incremental="true" services="${FDS_SERVICES_CONFIG_FILE}" >
<accessible>true</accessible>
<optimize>true</optimize>
<strict>true</strict>
<headless-server>true</headless-server>
<load-config filename="${FDS_CONFIG_FILE}" />
<source-path path-element="${env.FLEX_HOME}/frameworks" />
<source-path path-element="${flexClient.location}/flex_resources" />
<source-path path-element="${flexClient.location}/flex_src" />
<source-path path-element="${flexClient.location}/flex_src_gen" />
<compiler.include-libraries dir="${flexClient.location}/flex_libs" append="true" >
<include name="*.swc" />
</compiler.include-libraries>
<compiler.context-root>/</compiler.context-root>
<debug>false</debug>
<metadata description="PhareRH" title="PhareRH" />
</mxmlc>
</target>
<target name="flex.wrapper">
<html-wrapper
title="Bienvenue sur l'application Phare-rh"
height="100%"
width="100%"
bgcolor="#869ca7"
output="${webcontent_location}"
swf="flexClient"
template="express-installation"
history="false"
application="flexClient"
file="flexClient.html"
/>
<!-- Ajout des balises pour la gestion du cache dans le fichier html. -->
<replace file="${webcontent_location}/flexClient.html">
<replacetoken><![CDATA[<head>]]></replacetoken>
<replacevalue><![CDATA[<head>
<!-- Gestion du cache -->
<meta http-equiv="expires" content="0" />
<meta http-equiv="pragma" content="no-cache" />
<meta http-equiv="cache-control" content="no-cache, must-revalidate, max-age=0" />
<meta http-equiv="Cache" Content="no store" />
<meta http-equiv="last-modified" content="" />
]]></replacevalue>
</replace>
</target>
<target name="compile.debug" depends="version">
<mxmlc file="flex_src/flexClient.mxml" keep-generated-actionscript="false" services="${FDS_SERVICES_CONFIG_FILE}">
<accessible>false</accessible>
<optimize>false</optimize>
<strict>true</strict>
<load-config filename="${FDS_CONFIG_FILE}" />
<source-path path-element="${env.FLEX_HOME}/frameworks" />
<compiler.include-libraries dir="flex_libs" append="true">
<include name="*.swc" />
</compiler.include-libraries>
<debug>true</debug>
<metadata description="PhareRH" title="PhareRH">
</metadata>
</mxmlc>
</target>
<target name="release" depends="compile.release">
<move file="flex_src/flexClient.swf" todir="${webcontent_location}" overwrite="true" />
</target>
<target name="packaging" depends="compile.release, flex.wrapper">
<move file="flex_src/flexClient.swf" todir="${webcontent_location}" overwrite="true" />
</target>
<target name="release-debug" depends="compile.debug">
<move file="${APP_ROOT}/flex_src/flexClient.swf" todir="release" overwrite="true" />
</target>
<target name="release-no-compile">
<echo message="WebAppLocation : ${WebApp.location}"/>
<copy file="bin-debug/flexClient.swf" todir="${WebApp.location}" overwrite="true" />
</target>
<target name="properties-encoding">
<exec command="native2ascii -encoding ISO8859_1 flex_resources/election.properties election.properties.ISO8859_1">
</exec>
<move file="election.properties.ISO8859_1" tofile="flex_resources/election.properties" overwrite="true" />
<exec command="native2ascii -encoding ISO8859_1 flex_resources/phareRH.properties phareRH.properties.ISO8859_1">
</exec>
<move file="phareRH.properties.ISO8859_1" tofile="flex_resources/phareRH.properties" overwrite="true" />
<exec command="native2ascii -encoding ISO8859_1 flex_resources/erreurs.properties erreurs.properties.ISO8859_1">
</exec>
<move file="erreurs.properties.ISO8859_1" tofile="flex_resources/erreurs.properties" overwrite="true" />
<exec command="native2ascii -encoding ISO8859_1 flex_resources/veillesociale.properties veillesociale.properties.ISO8859_1">
</exec>
<move file="veillesociale.properties.ISO8859_1" tofile="flex_resources/veillesociale.properties" overwrite="true" />
<exec command="native2ascii -encoding ISO8859_1 flex_resources/rup.properties rup.properties.ISO8859_1">
</exec>
<move file="rup.properties.ISO8859_1" tofile="flex_resources/rup.properties" overwrite="true" />
<exec command="native2ascii -encoding ISO8859_1 flex_resources/administration.properties administration.properties.ISO8859_1">
</exec>
<move file="administration.properties.ISO8859_1" tofile="flex_resources/administration.properties" overwrite="true" />
</target>
</project>
Мой flex-config.xml
<?xml version="1.0"?>
<!--
ADOBE SYSTEMS INCORPORATED
Copyright 2005-2007 Adobe Systems Incorporated
All Rights Reserved.
NOTICE: Adobe permits you to use, modify, and distribute this file
in accordance with the terms of the license agreement accompanying it.
-->
<flex-config>
<compiler>
<!-- Turn on generation of accessible SWFs. -->
<accessible>false</accessible>
<!-- Specifies the locales for internationalization. -->
<locale>
<locale-element>en_US</locale-element>
</locale>
<!-- List of path elements that form the roots of ActionScript class hierarchies. -->
<!-- not set -->
<!--
<source-path>
<path-element>string</path-element>
</source-path>
-->
<!-- Allow the source-path to have path-elements which contain other path-elements -->
<allow-source-path-overlap>false</allow-source-path-overlap>
<!-- Run the AS3 compiler in a mode that detects legal but potentially incorrect -->
<!-- code. -->
<show-actionscript-warnings>true</show-actionscript-warnings>
<!-- Turn on generation of debuggable SWFs. False by default for mxmlc, -->
<!-- but true by default for compc. -->
<!--
<debug>true</debug>
-->
<!-- List of SWC files or directories to compile against but to omit from -->
<!-- linking. -->
<external-library-path>
<path-element>libs/player/playerglobal.swc</path-element>
</external-library-path>
<!-- Turn on writing of generated/*.as files to disk. These files are generated by -->
<!-- the compiler during mxml translation and are helpful with understanding and -->
<!-- debugging Flex applications. -->
<keep-generated-actionscript>false</keep-generated-actionscript>
<!-- not set -->
<!--
<include-libraries>
<library>string</library>
</include-libraries>
-->
<!-- List of SWC files or directories that contain SWC files. -->
<library-path>
<path-element>libs</path-element>
<path-element>libs/player</path-element>
<path-element>locale/{locale}</path-element>
</library-path>
<namespaces>
<!-- Specify a URI to associate with a manifest of components for use as MXML -->
<!-- elements. -->
<namespace>
<uri>http://www.adobe.com/2006/mxml</uri>
<manifest>mxml-manifest.xml</manifest>
</namespace>
</namespaces>
<!-- Enable post-link SWF optimization. -->
<optimize>true</optimize>
<!-- Keep the following AS3 metadata in the bytecodes. -->
<!-- Warning: For the data binding feature in the Flex framework to work properly, -->
<!-- the following metadata must be kept: -->
<!-- 1. Bindable -->
<!-- 2. Managed -->
<!-- 3. ChangeEvent -->
<!-- 4. NonCommittingChangeEvent -->
<!-- 5. Transient -->
<!--
<keep-as3-metadata>
<name>Bindable</name>
<name>Managed</name>
<name>ChangeEvent</name>
<name>NonCommittingChangeEvent</name>
<name>Transient</name>
</keep-as3-metadata>
-->
<!-- Turn on reporting of data binding warnings. For example: Warning: Data binding -->
<!-- will not be able to detect assignments to "foo". -->
<show-binding-warnings>true</show-binding-warnings>
<!-- toggle whether warnings generated from unused type selectors are displayed -->
<show-unused-type-selector-warnings>true</show-unused-type-selector-warnings>
<!-- Run the AS3 compiler in strict error checking mode. -->
<strict>true</strict>
<!-- Use the ActionScript 3 class based object model for greater performance and better error reporting. -->
<!-- In the class based object model most built-in functions are implemented as fixed methods of classes -->
<!-- (-strict is recommended, but not required, for earlier errors) -->
<as3>true</as3>
<!-- Use the ECMAScript edition 3 prototype based object model to allow dynamic overriding of prototype -->
<!-- properties. In the prototype based object model built-in functions are implemented as dynamic -->
<!-- properties of prototype objects (-strict is allowed, but may result in compiler errors for -->
<!-- references to dynamic properties) -->
<es>false</es>
<!-- List of CSS or SWC files to apply as a theme. -->
<!-- not set -->
<!--
<theme>
<filename>string</filename>
<filename>string</filename>
</theme>
-->
<!-- Turns on the display of stack traces for uncaught runtime errors. -->
<verbose-stacktraces>false</verbose-stacktraces>
<!-- Defines the AS3 file encoding. -->
<!-- not set -->
<!--
<actionscript-file-encoding></actionscript-file-encoding>
-->
<fonts>
<!-- Enables advanced anti-aliasing for embedded fonts, which provides greater clarity for small -->
<!-- fonts. This setting can be overriden in CSS for specific fonts. -->
<!-- NOTE: flash-type has been deprecated. Please use advanced-anti-aliasing <flash-type>true</flash-type> -->
<advanced-anti-aliasing>true</advanced-anti-aliasing>
<!-- The number of embedded font faces that are cached. -->
<max-cached-fonts>20</max-cached-fonts>
<!-- The number of character glyph outlines to cache for each font face. -->
<max-glyphs-per-face>1000</max-glyphs-per-face>
<!-- Defines ranges that can be used across multiple font-face declarations. -->
<!-- See flash-unicode-table.xml for more examples. -->
<!-- not set -->
<!--
<languages>
<language-range>
<lang>englishRange</lang>
<range>U+0020-U+007E</range>
</language-range>
</languages>
-->
<!-- Compiler font manager classes, in policy resolution order-->
<managers>
<manager-class>flash.fonts.JREFontManager</manager-class>
<manager-class>flash.fonts.AFEFontManager</manager-class>
<manager-class>flash.fonts.BatikFontManager</manager-class>
</managers>
<!-- File containing cached system font licensing information produced via
java -cp mxmlc.jar flex2.tools.FontSnapshot (fontpath)
Will default to winFonts.ser on Windows XP and
macFonts.ser on Mac OS X, so is commented out by default.
<local-fonts-snapshot>localFonts.ser</local-fonts-snapshot>
-->
</fonts>
<!-- Array.toString() format has changed. -->
<warn-array-tostring-changes>false</warn-array-tostring-changes>
<!-- Assignment within conditional. -->
<warn-assignment-within-conditional>true</warn-assignment-within-conditional>
<!-- Possibly invalid Array cast operation. -->
<warn-bad-array-cast>true</warn-bad-array-cast>
<!-- Non-Boolean value used where a Boolean value was expected. -->
<warn-bad-bool-assignment>true</warn-bad-bool-assignment>
<!-- Invalid Date cast operation. -->
<warn-bad-date-cast>true</warn-bad-date-cast>
<!-- Unknown method. -->
<warn-bad-es3-type-method>true</warn-bad-es3-type-method>
<!-- Unknown property. -->
<warn-bad-es3-type-prop>true</warn-bad-es3-type-prop>
<!-- Illogical comparison with NaN. Any comparison operation involving NaN will evaluate to false because NaN != NaN. -->
<warn-bad-nan-comparison>true</warn-bad-nan-comparison>
<!-- Impossible assignment to null. -->
<warn-bad-null-assignment>true</warn-bad-null-assignment>
<!-- Illogical comparison with null. -->
<warn-bad-null-comparison>true</warn-bad-null-comparison>
<!-- Illogical comparison with undefined. Only untyped variables (or variables of type *) can be undefined. -->
<warn-bad-undefined-comparison>true</warn-bad-undefined-comparison>
<!-- Boolean() with no arguments returns false in ActionScript 3.0. Boolean() returned undefined in ActionScript 2.0. -->
<warn-boolean-constructor-with-no-args>false</warn-boolean-constructor-with-no-args>
<!-- __resolve is no longer supported. -->
<warn-changes-in-resolve>false</warn-changes-in-resolve>
<!-- Class is sealed. It cannot have members added to it dynamically. -->
<warn-class-is-sealed>true</warn-class-is-sealed>
<!-- Constant not initialized. -->
<warn-const-not-initialized>true</warn-const-not-initialized>
<!-- Function used in new expression returns a value. Result will be what the -->
<!-- function returns, rather than a new instance of that function. -->
<warn-constructor-returns-value>false</warn-constructor-returns-value>
<!-- EventHandler was not added as a listener. -->
<warn-deprecated-event-handler-error>false</warn-deprecated-event-handler-error>
<!-- Unsupported ActionScript 2.0 function. -->
<warn-deprecated-function-error>true</warn-deprecated-function-error>
<!-- Unsupported ActionScript 2.0 property. -->
<warn-deprecated-property-error>true</warn-deprecated-property-error>
<!-- More than one argument by the same name. -->
<warn-duplicate-argument-names>true</warn-duplicate-argument-names>
<!-- Duplicate variable definition -->
<warn-duplicate-variable-def>true</warn-duplicate-variable-def>
<!-- ActionScript 3.0 iterates over an object's properties within a "for x in target" statement in random order. -->
<warn-for-var-in-changes>false</warn-for-var-in-changes>
<!-- Importing a package by the same name as the current class will hide that class identifier in this scope. -->
<warn-import-hides-class>true</warn-import-hides-class>
<!-- Use of the instanceof operator. -->
<warn-instance-of-changes>true</warn-instance-of-changes>
<!-- Internal error in compiler. -->
<warn-internal-error>true</warn-internal-error>
<!-- _level is no longer supported. For more information, see the flash.display package. -->
<warn-level-not-supported>true</warn-level-not-supported>
<!-- Missing namespace declaration (e.g. variable is not defined to be public, private, etc.). -->
<warn-missing-namespace-decl>true</warn-missing-namespace-decl>
<!-- Negative value will become a large positive value when assigned to a uint data type. -->
<warn-negative-uint-literal>true</warn-negative-uint-literal>
<!-- Missing constructor. -->
<warn-no-constructor>false</warn-no-constructor>
<!-- The super() statement was not called within the constructor. -->
<warn-no-explicit-super-call-in-constructor>false</warn-no-explicit-super-call-in-constructor>
<!-- Missing type declaration. -->
<warn-no-type-decl>true</warn-no-type-decl>
<!-- In ActionScript 3.0, white space is ignored and '' returns 0. Number() returns -->
<!-- NaN in ActionScript 2.0 when the parameter is '' or contains white space. -->
<warn-number-from-string-changes>false</warn-number-from-string-changes>
<!-- Change in scoping for the this keyword. Class methods extracted from an -->
<!-- instance of a class will always resolve this back to that instance. In -->
<!-- ActionScript 2.0 this is looked up dynamically based on where the method -->
<!-- is invoked from. -->
<warn-scoping-change-in-this>false</warn-scoping-change-in-this>
<!-- Inefficient use of += on a TextField.-->
<warn-slow-text-field-addition>true</warn-slow-text-field-addition>
<!-- Possible missing parentheses. -->
<warn-unlikely-function-value>true</warn-unlikely-function-value>
<!-- Possible usage of the ActionScript 2.0 XML class. -->
<warn-xml-class-has-changed>false</warn-xml-class-has-changed>
</compiler>
<!-- compute-digest: writes a digest to the catalog.xml of a library. Use this when the library will be used as a
cross-domain rsl.-->
<!-- compute-digest usage:
<compute-digest>boolean</compute-digest>
-->
<!-- A list of runtime shared library URLs to be loaded before applications start. -->
<!-- not set -->
<!--
<runtime-shared-libraries>
<url>string</url>
<url>string</url>
</runtime-shared-libraries>
-->
<!-- runtime-shared-library-path: specifies a SWC or directory to link against and an RSL URL to load with optional failover URLs -->
<runtime-shared-library-path>
<path-element>libs/framework.swc</path-element>
<rsl-url>framework_3.0.0.477.swz</rsl-url>
<policy-file-url></policy-file-url>
<rsl-url>framework_3.0.0.477.swf</rsl-url>
<policy-file-url></policy-file-url>
</runtime-shared-library-path>
<!-- static-link-runtime-shared-libraries: statically link the libraries specified by the -runtime-shared-libraries-path option.-->
<static-link-runtime-shared-libraries>true</static-link-runtime-shared-libraries>
<!-- target-player: specifies the version of the player the application is targeting.
Features requiring a later version will not be compiled into the application.
The minimum value supported is "9.0.0".-->
<!-- target-player usage:
<target-player>version</target-player>
-->
<!-- Enables SWFs to access the network. -->
<use-network>true</use-network>
<!-- Metadata added to SWFs via the SWF Metadata tag. -->
<metadata>
<title>Adobe Flex 3 Application</title>
<description>http://www.adobe.com/products/flex</description>
<publisher>unknown</publisher>
<creator>unknown</creator>
<language>EN</language>
</metadata>
<!-- licenses: specifies a list of product and serial number pairs. -->
<!-- not set -->
<licenses>
<license>
<product>flexbuilder3</product>
<serial-number>XXXXXXXXXXXXXXXXX</serial-number>
</license>
</licenses>
</flex-config>
1 ответ
Я думаю, что сообщение "flexClient_381495.cache (Нет такого> файла или каталога)" безобидно. Это просто стандартный вывод от ant или задача ant, верно? Я думаю, что видел подобные сообщения миллион раз, но с тех пор, как я использовал муравья, прошло много времени...
Вы упомянули, что он зависает после печати этого вывода, но иногда вы также видите предупреждения компилятора. Я предполагаю, что это входит в фазу компиляции каждый раз. Иногда вы попадаете достаточно далеко, чтобы увидеть некоторые предупреждающие сообщения.
Похоже, вы можете указать больший размер кучи для JVM. Некоторые подробности о том, как сделать это здесь и здесь.