--- /dev/null
+ GNU GENERAL PUBLIC LICENSE
+ Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc. <http://fsf.org/>
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The GNU General Public License is a free, copyleft license for
+software and other kinds of works.
+
+ The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works. By contrast,
+the GNU General Public License is intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains free
+software for all its users. We, the Free Software Foundation, use the
+GNU General Public License for most of our software; it applies also to
+any other work released this way by its authors. You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+them if you wish), that you receive source code or can get it if you
+want it, that you can change the software or use pieces of it in new
+free programs, and that you know you can do these things.
+
+ To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights. Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received. You must make sure that they, too, receive
+or can get the source code. And you must show them these terms so they
+know their rights.
+
+ Developers that use the GNU GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+ For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this free software. For both users' and
+authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+ Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so. This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software. The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable. Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products. If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+ Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to a free program could
+make it effectively proprietary. To prevent this, the GPL assures that
+patents cannot be used to render the program non-free.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ TERMS AND CONDITIONS
+
+ 0. Definitions.
+
+ "This License" refers to version 3 of the GNU General Public License.
+
+ "Copyright" also means copyright-like laws that apply to other kinds of
+works, such as semiconductor masks.
+
+ "The Program" refers to any copyrightable work licensed under this
+License. Each licensee is addressed as "you". "Licensees" and
+"recipients" may be individuals or organizations.
+
+ To "modify" a work means to copy from or adapt all or part of the work
+in a fashion requiring copyright permission, other than the making of an
+exact copy. The resulting work is called a "modified version" of the
+earlier work or a work "based on" the earlier work.
+
+ A "covered work" means either the unmodified Program or a work based
+on the Program.
+
+ To "propagate" a work means to do anything with it that, without
+permission, would make you directly or secondarily liable for
+infringement under applicable copyright law, except executing it on a
+computer or modifying a private copy. Propagation includes copying,
+distribution (with or without modification), making available to the
+public, and in some countries other activities as well.
+
+ To "convey" a work means any kind of propagation that enables other
+parties to make or receive copies. Mere interaction with a user through
+a computer network, with no transfer of a copy, is not conveying.
+
+ An interactive user interface displays "Appropriate Legal Notices"
+to the extent that it includes a convenient and prominently visible
+feature that (1) displays an appropriate copyright notice, and (2)
+tells the user that there is no warranty for the work (except to the
+extent that warranties are provided), that licensees may convey the
+work under this License, and how to view a copy of this License. If
+the interface presents a list of user commands or options, such as a
+menu, a prominent item in the list meets this criterion.
+
+ 1. Source Code.
+
+ The "source code" for a work means the preferred form of the work
+for making modifications to it. "Object code" means any non-source
+form of a work.
+
+ A "Standard Interface" means an interface that either is an official
+standard defined by a recognized standards body, or, in the case of
+interfaces specified for a particular programming language, one that
+is widely used among developers working in that language.
+
+ The "System Libraries" of an executable work include anything, other
+than the work as a whole, that (a) is included in the normal form of
+packaging a Major Component, but which is not part of that Major
+Component, and (b) serves only to enable use of the work with that
+Major Component, or to implement a Standard Interface for which an
+implementation is available to the public in source code form. A
+"Major Component", in this context, means a major essential component
+(kernel, window system, and so on) of the specific operating system
+(if any) on which the executable work runs, or a compiler used to
+produce the work, or an object code interpreter used to run it.
+
+ The "Corresponding Source" for a work in object code form means all
+the source code needed to generate, install, and (for an executable
+work) run the object code and to modify the work, including scripts to
+control those activities. However, it does not include the work's
+System Libraries, or general-purpose tools or generally available free
+programs which are used unmodified in performing those activities but
+which are not part of the work. For example, Corresponding Source
+includes interface definition files associated with source files for
+the work, and the source code for shared libraries and dynamically
+linked subprograms that the work is specifically designed to require,
+such as by intimate data communication or control flow between those
+subprograms and other parts of the work.
+
+ The Corresponding Source need not include anything that users
+can regenerate automatically from other parts of the Corresponding
+Source.
+
+ The Corresponding Source for a work in source code form is that
+same work.
+
+ 2. Basic Permissions.
+
+ All rights granted under this License are granted for the term of
+copyright on the Program, and are irrevocable provided the stated
+conditions are met. This License explicitly affirms your unlimited
+permission to run the unmodified Program. The output from running a
+covered work is covered by this License only if the output, given its
+content, constitutes a covered work. This License acknowledges your
+rights of fair use or other equivalent, as provided by copyright law.
+
+ You may make, run and propagate covered works that you do not
+convey, without conditions so long as your license otherwise remains
+in force. You may convey covered works to others for the sole purpose
+of having them make modifications exclusively for you, or provide you
+with facilities for running those works, provided that you comply with
+the terms of this License in conveying all material for which you do
+not control copyright. Those thus making or running the covered works
+for you must do so exclusively on your behalf, under your direction
+and control, on terms that prohibit them from making any copies of
+your copyrighted material outside their relationship with you.
+
+ Conveying under any other circumstances is permitted solely under
+the conditions stated below. Sublicensing is not allowed; section 10
+makes it unnecessary.
+
+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
+
+ No covered work shall be deemed part of an effective technological
+measure under any applicable law fulfilling obligations under article
+11 of the WIPO copyright treaty adopted on 20 December 1996, or
+similar laws prohibiting or restricting circumvention of such
+measures.
+
+ When you convey a covered work, you waive any legal power to forbid
+circumvention of technological measures to the extent such circumvention
+is effected by exercising rights under this License with respect to
+the covered work, and you disclaim any intention to limit operation or
+modification of the work as a means of enforcing, against the work's
+users, your or third parties' legal rights to forbid circumvention of
+technological measures.
+
+ 4. Conveying Verbatim Copies.
+
+ You may convey verbatim copies of the Program's source code as you
+receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice;
+keep intact all notices stating that this License and any
+non-permissive terms added in accord with section 7 apply to the code;
+keep intact all notices of the absence of any warranty; and give all
+recipients a copy of this License along with the Program.
+
+ You may charge any price or no price for each copy that you convey,
+and you may offer support or warranty protection for a fee.
+
+ 5. Conveying Modified Source Versions.
+
+ You may convey a work based on the Program, or the modifications to
+produce it from the Program, in the form of source code under the
+terms of section 4, provided that you also meet all of these conditions:
+
+ a) The work must carry prominent notices stating that you modified
+ it, and giving a relevant date.
+
+ b) The work must carry prominent notices stating that it is
+ released under this License and any conditions added under section
+ 7. This requirement modifies the requirement in section 4 to
+ "keep intact all notices".
+
+ c) You must license the entire work, as a whole, under this
+ License to anyone who comes into possession of a copy. This
+ License will therefore apply, along with any applicable section 7
+ additional terms, to the whole of the work, and all its parts,
+ regardless of how they are packaged. This License gives no
+ permission to license the work in any other way, but it does not
+ invalidate such permission if you have separately received it.
+
+ d) If the work has interactive user interfaces, each must display
+ Appropriate Legal Notices; however, if the Program has interactive
+ interfaces that do not display Appropriate Legal Notices, your
+ work need not make them do so.
+
+ A compilation of a covered work with other separate and independent
+works, which are not by their nature extensions of the covered work,
+and which are not combined with it such as to form a larger program,
+in or on a volume of a storage or distribution medium, is called an
+"aggregate" if the compilation and its resulting copyright are not
+used to limit the access or legal rights of the compilation's users
+beyond what the individual works permit. Inclusion of a covered work
+in an aggregate does not cause this License to apply to the other
+parts of the aggregate.
+
+ 6. Conveying Non-Source Forms.
+
+ You may convey a covered work in object code form under the terms
+of sections 4 and 5, provided that you also convey the
+machine-readable Corresponding Source under the terms of this License,
+in one of these ways:
+
+ a) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by the
+ Corresponding Source fixed on a durable physical medium
+ customarily used for software interchange.
+
+ b) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by a
+ written offer, valid for at least three years and valid for as
+ long as you offer spare parts or customer support for that product
+ model, to give anyone who possesses the object code either (1) a
+ copy of the Corresponding Source for all the software in the
+ product that is covered by this License, on a durable physical
+ medium customarily used for software interchange, for a price no
+ more than your reasonable cost of physically performing this
+ conveying of source, or (2) access to copy the
+ Corresponding Source from a network server at no charge.
+
+ c) Convey individual copies of the object code with a copy of the
+ written offer to provide the Corresponding Source. This
+ alternative is allowed only occasionally and noncommercially, and
+ only if you received the object code with such an offer, in accord
+ with subsection 6b.
+
+ d) Convey the object code by offering access from a designated
+ place (gratis or for a charge), and offer equivalent access to the
+ Corresponding Source in the same way through the same place at no
+ further charge. You need not require recipients to copy the
+ Corresponding Source along with the object code. If the place to
+ copy the object code is a network server, the Corresponding Source
+ may be on a different server (operated by you or a third party)
+ that supports equivalent copying facilities, provided you maintain
+ clear directions next to the object code saying where to find the
+ Corresponding Source. Regardless of what server hosts the
+ Corresponding Source, you remain obligated to ensure that it is
+ available for as long as needed to satisfy these requirements.
+
+ e) Convey the object code using peer-to-peer transmission, provided
+ you inform other peers where the object code and Corresponding
+ Source of the work are being offered to the general public at no
+ charge under subsection 6d.
+
+ A separable portion of the object code, whose source code is excluded
+from the Corresponding Source as a System Library, need not be
+included in conveying the object code work.
+
+ A "User Product" is either (1) a "consumer product", which means any
+tangible personal property which is normally used for personal, family,
+or household purposes, or (2) anything designed or sold for incorporation
+into a dwelling. In determining whether a product is a consumer product,
+doubtful cases shall be resolved in favor of coverage. For a particular
+product received by a particular user, "normally used" refers to a
+typical or common use of that class of product, regardless of the status
+of the particular user or of the way in which the particular user
+actually uses, or expects or is expected to use, the product. A product
+is a consumer product regardless of whether the product has substantial
+commercial, industrial or non-consumer uses, unless such uses represent
+the only significant mode of use of the product.
+
+ "Installation Information" for a User Product means any methods,
+procedures, authorization keys, or other information required to install
+and execute modified versions of a covered work in that User Product from
+a modified version of its Corresponding Source. The information must
+suffice to ensure that the continued functioning of the modified object
+code is in no case prevented or interfered with solely because
+modification has been made.
+
+ If you convey an object code work under this section in, or with, or
+specifically for use in, a User Product, and the conveying occurs as
+part of a transaction in which the right of possession and use of the
+User Product is transferred to the recipient in perpetuity or for a
+fixed term (regardless of how the transaction is characterized), the
+Corresponding Source conveyed under this section must be accompanied
+by the Installation Information. But this requirement does not apply
+if neither you nor any third party retains the ability to install
+modified object code on the User Product (for example, the work has
+been installed in ROM).
+
+ The requirement to provide Installation Information does not include a
+requirement to continue to provide support service, warranty, or updates
+for a work that has been modified or installed by the recipient, or for
+the User Product in which it has been modified or installed. Access to a
+network may be denied when the modification itself materially and
+adversely affects the operation of the network or violates the rules and
+protocols for communication across the network.
+
+ Corresponding Source conveyed, and Installation Information provided,
+in accord with this section must be in a format that is publicly
+documented (and with an implementation available to the public in
+source code form), and must require no special password or key for
+unpacking, reading or copying.
+
+ 7. Additional Terms.
+
+ "Additional permissions" are terms that supplement the terms of this
+License by making exceptions from one or more of its conditions.
+Additional permissions that are applicable to the entire Program shall
+be treated as though they were included in this License, to the extent
+that they are valid under applicable law. If additional permissions
+apply only to part of the Program, that part may be used separately
+under those permissions, but the entire Program remains governed by
+this License without regard to the additional permissions.
+
+ When you convey a copy of a covered work, you may at your option
+remove any additional permissions from that copy, or from any part of
+it. (Additional permissions may be written to require their own
+removal in certain cases when you modify the work.) You may place
+additional permissions on material, added by you to a covered work,
+for which you have or can give appropriate copyright permission.
+
+ Notwithstanding any other provision of this License, for material you
+add to a covered work, you may (if authorized by the copyright holders of
+that material) supplement the terms of this License with terms:
+
+ a) Disclaiming warranty or limiting liability differently from the
+ terms of sections 15 and 16 of this License; or
+
+ b) Requiring preservation of specified reasonable legal notices or
+ author attributions in that material or in the Appropriate Legal
+ Notices displayed by works containing it; or
+
+ c) Prohibiting misrepresentation of the origin of that material, or
+ requiring that modified versions of such material be marked in
+ reasonable ways as different from the original version; or
+
+ d) Limiting the use for publicity purposes of names of licensors or
+ authors of the material; or
+
+ e) Declining to grant rights under trademark law for use of some
+ trade names, trademarks, or service marks; or
+
+ f) Requiring indemnification of licensors and authors of that
+ material by anyone who conveys the material (or modified versions of
+ it) with contractual assumptions of liability to the recipient, for
+ any liability that these contractual assumptions directly impose on
+ those licensors and authors.
+
+ All other non-permissive additional terms are considered "further
+restrictions" within the meaning of section 10. If the Program as you
+received it, or any part of it, contains a notice stating that it is
+governed by this License along with a term that is a further
+restriction, you may remove that term. If a license document contains
+a further restriction but permits relicensing or conveying under this
+License, you may add to a covered work material governed by the terms
+of that license document, provided that the further restriction does
+not survive such relicensing or conveying.
+
+ If you add terms to a covered work in accord with this section, you
+must place, in the relevant source files, a statement of the
+additional terms that apply to those files, or a notice indicating
+where to find the applicable terms.
+
+ Additional terms, permissive or non-permissive, may be stated in the
+form of a separately written license, or stated as exceptions;
+the above requirements apply either way.
+
+ 8. Termination.
+
+ You may not propagate or modify a covered work except as expressly
+provided under this License. Any attempt otherwise to propagate or
+modify it is void, and will automatically terminate your rights under
+this License (including any patent licenses granted under the third
+paragraph of section 11).
+
+ However, if you cease all violation of this License, then your
+license from a particular copyright holder is reinstated (a)
+provisionally, unless and until the copyright holder explicitly and
+finally terminates your license, and (b) permanently, if the copyright
+holder fails to notify you of the violation by some reasonable means
+prior to 60 days after the cessation.
+
+ Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+
+ Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License. If your rights have been terminated and not permanently
+reinstated, you do not qualify to receive new licenses for the same
+material under section 10.
+
+ 9. Acceptance Not Required for Having Copies.
+
+ You are not required to accept this License in order to receive or
+run a copy of the Program. Ancillary propagation of a covered work
+occurring solely as a consequence of using peer-to-peer transmission
+to receive a copy likewise does not require acceptance. However,
+nothing other than this License grants you permission to propagate or
+modify any covered work. These actions infringe copyright if you do
+not accept this License. Therefore, by modifying or propagating a
+covered work, you indicate your acceptance of this License to do so.
+
+ 10. Automatic Licensing of Downstream Recipients.
+
+ Each time you convey a covered work, the recipient automatically
+receives a license from the original licensors, to run, modify and
+propagate that work, subject to this License. You are not responsible
+for enforcing compliance by third parties with this License.
+
+ An "entity transaction" is a transaction transferring control of an
+organization, or substantially all assets of one, or subdividing an
+organization, or merging organizations. If propagation of a covered
+work results from an entity transaction, each party to that
+transaction who receives a copy of the work also receives whatever
+licenses to the work the party's predecessor in interest had or could
+give under the previous paragraph, plus a right to possession of the
+Corresponding Source of the work from the predecessor in interest, if
+the predecessor has it or can get it with reasonable efforts.
+
+ You may not impose any further restrictions on the exercise of the
+rights granted or affirmed under this License. For example, you may
+not impose a license fee, royalty, or other charge for exercise of
+rights granted under this License, and you may not initiate litigation
+(including a cross-claim or counterclaim in a lawsuit) alleging that
+any patent claim is infringed by making, using, selling, offering for
+sale, or importing the Program or any portion of it.
+
+ 11. Patents.
+
+ A "contributor" is a copyright holder who authorizes use under this
+License of the Program or a work on which the Program is based. The
+work thus licensed is called the contributor's "contributor version".
+
+ A contributor's "essential patent claims" are all patent claims
+owned or controlled by the contributor, whether already acquired or
+hereafter acquired, that would be infringed by some manner, permitted
+by this License, of making, using, or selling its contributor version,
+but do not include claims that would be infringed only as a
+consequence of further modification of the contributor version. For
+purposes of this definition, "control" includes the right to grant
+patent sublicenses in a manner consistent with the requirements of
+this License.
+
+ Each contributor grants you a non-exclusive, worldwide, royalty-free
+patent license under the contributor's essential patent claims, to
+make, use, sell, offer for sale, import and otherwise run, modify and
+propagate the contents of its contributor version.
+
+ In the following three paragraphs, a "patent license" is any express
+agreement or commitment, however denominated, not to enforce a patent
+(such as an express permission to practice a patent or covenant not to
+sue for patent infringement). To "grant" such a patent license to a
+party means to make such an agreement or commitment not to enforce a
+patent against the party.
+
+ If you convey a covered work, knowingly relying on a patent license,
+and the Corresponding Source of the work is not available for anyone
+to copy, free of charge and under the terms of this License, through a
+publicly available network server or other readily accessible means,
+then you must either (1) cause the Corresponding Source to be so
+available, or (2) arrange to deprive yourself of the benefit of the
+patent license for this particular work, or (3) arrange, in a manner
+consistent with the requirements of this License, to extend the patent
+license to downstream recipients. "Knowingly relying" means you have
+actual knowledge that, but for the patent license, your conveying the
+covered work in a country, or your recipient's use of the covered work
+in a country, would infringe one or more identifiable patents in that
+country that you have reason to believe are valid.
+
+ If, pursuant to or in connection with a single transaction or
+arrangement, you convey, or propagate by procuring conveyance of, a
+covered work, and grant a patent license to some of the parties
+receiving the covered work authorizing them to use, propagate, modify
+or convey a specific copy of the covered work, then the patent license
+you grant is automatically extended to all recipients of the covered
+work and works based on it.
+
+ A patent license is "discriminatory" if it does not include within
+the scope of its coverage, prohibits the exercise of, or is
+conditioned on the non-exercise of one or more of the rights that are
+specifically granted under this License. You may not convey a covered
+work if you are a party to an arrangement with a third party that is
+in the business of distributing software, under which you make payment
+to the third party based on the extent of your activity of conveying
+the work, and under which the third party grants, to any of the
+parties who would receive the covered work from you, a discriminatory
+patent license (a) in connection with copies of the covered work
+conveyed by you (or copies made from those copies), or (b) primarily
+for and in connection with specific products or compilations that
+contain the covered work, unless you entered into that arrangement,
+or that patent license was granted, prior to 28 March 2007.
+
+ Nothing in this License shall be construed as excluding or limiting
+any implied license or other defenses to infringement that may
+otherwise be available to you under applicable patent law.
+
+ 12. No Surrender of Others' Freedom.
+
+ If conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot convey a
+covered work so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you may
+not convey it at all. For example, if you agree to terms that obligate you
+to collect a royalty for further conveying from those to whom you convey
+the Program, the only way you could satisfy both those terms and this
+License would be to refrain entirely from conveying the Program.
+
+ 13. Use with the GNU Affero General Public License.
+
+ Notwithstanding any other provision of this License, you have
+permission to link or combine any covered work with a work licensed
+under version 3 of the GNU Affero General Public License into a single
+combined work, and to convey the resulting work. The terms of this
+License will continue to apply to the part which is the covered work,
+but the special requirements of the GNU Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+ 14. Revised Versions of this License.
+
+ The Free Software Foundation may publish revised and/or new versions of
+the GNU General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+ Each version is given a distinguishing version number. If the
+Program specifies that a certain numbered version of the GNU General
+Public License "or any later version" applies to it, you have the
+option of following the terms and conditions either of that numbered
+version or of any later version published by the Free Software
+Foundation. If the Program does not specify a version number of the
+GNU General Public License, you may choose any version ever published
+by the Free Software Foundation.
+
+ If the Program specifies that a proxy can decide which future
+versions of the GNU General Public License can be used, that proxy's
+public statement of acceptance of a version permanently authorizes you
+to choose that version for the Program.
+
+ Later license versions may give you additional or different
+permissions. However, no additional obligations are imposed on any
+author or copyright holder as a result of your choosing to follow a
+later version.
+
+ 15. Disclaimer of Warranty.
+
+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. Limitation of Liability.
+
+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGES.
+
+ 17. Interpretation of Sections 15 and 16.
+
+ If the disclaimer of warranty and limitation of liability provided
+above cannot be given local legal effect according to their terms,
+reviewing courts shall apply local law that most closely approximates
+an absolute waiver of all civil liability in connection with the
+Program, unless a warranty or assumption of liability accompanies a
+copy of the Program in return for a fee.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+state the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+Also add information on how to contact you by electronic and paper mail.
+
+ If the program does terminal interaction, make it output a short
+notice like this when it starts in an interactive mode:
+
+ <program> Copyright (C) <year> <name of author>
+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, your program's commands
+might be different; for a GUI interface, you would use an "about box".
+
+ You should also get your employer (if you work as a programmer) or school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.
+For more information on this, and how to apply and follow the GNU GPL, see
+<http://www.gnu.org/licenses/>.
+
+ The GNU General Public License does not permit incorporating your program
+into proprietary programs. If your program is a subroutine library, you
+may consider it more useful to permit linking proprietary applications with
+the library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License. But first, please read
+<http://www.gnu.org/philosophy/why-not-lgpl.html>.
--- /dev/null
+
+README
+------
+
+This is pre-alpha work-in-progress map editor for DuskZ using JavaFX.
+
+In it's present state it allows for loading of a Tiled map and cross
+referencing the content of an 'old' Dusk game with a 'new' DuskZ game
+(i.e. scripts so on).
+
+At the moment it is hardcoded to data I only have locally so isn't
+much use to anyone else.
+
+I can't even remember if i had intented to keep working on or or just
+use it as a transition tool. There is very little code here at any
+rate and most of it was a JavaFX learning exercise.
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?><!-- You may freely edit this file. See commented blocks below for --><!-- some examples of how to customize the build. --><!-- (If you delete it and reopen the project it will be recreated.) --><!-- By default, only the Clean and Build commands use this build script. --><project name="TileZ" default="default" basedir="." xmlns:fx="javafx:com.sun.javafx.tools.ant">
+ <description>Builds, tests, and runs the project TileZ.</description>
+ <import file="nbproject/build-impl.xml"/>
+ <!--
+
+ There exist several targets which are by default empty and which can be
+ used for execution of your tasks. These targets are usually executed
+ before and after some main targets. Those of them relevant for JavaFX project are:
+
+ -pre-init: called before initialization of project properties
+ -post-init: called after initialization of project properties
+ -pre-compile: called before javac compilation
+ -post-compile: called after javac compilation
+ -pre-compile-test: called before javac compilation of JUnit tests
+ -post-compile-test: called after javac compilation of JUnit tests
+ -pre-jfx-jar: called before FX SDK specific <fx:jar> task
+ -post-jfx-jar: called after FX SDK specific <fx:jar> task
+ -pre-jfx-deploy: called before FX SDK specific <fx:deploy> task
+ -post-jfx-deploy: called after FX SDK specific <fx:deploy> task
+ -pre-jfx-native: called just after -pre-jfx-deploy if <fx:deploy> runs in native packaging mode
+ -post-jfx-native: called just after -post-jfx-deploy if <fx:deploy> runs in native packaging mode
+ -post-clean: called after cleaning build products
+
+ (Targets beginning with '-' are not intended to be called on their own.)
+
+ Example of inserting a HTML postprocessor after javaFX SDK deployment:
+
+ <target name="-post-jfx-deploy">
+ <basename property="jfx.deployment.base" file="${jfx.deployment.jar}" suffix=".jar"/>
+ <property name="jfx.deployment.html" location="${jfx.deployment.dir}${file.separator}${jfx.deployment.base}.html"/>
+ <custompostprocess>
+ <fileset dir="${jfx.deployment.html}"/>
+ </custompostprocess>
+ </target>
+
+ Example of calling an Ant task from JavaFX SDK. Note that access to JavaFX SDK Ant tasks must be
+ initialized; to ensure this is done add the dependence on -check-jfx-sdk-version target:
+
+ <target name="-post-jfx-jar" depends="-check-jfx-sdk-version">
+ <echo message="Calling jar task from JavaFX SDK"/>
+ <fx:jar ...>
+ ...
+ </fx:jar>
+ </target>
+
+ For more details about JavaFX SDK Ant tasks go to
+ http://docs.oracle.com/javafx/2/deployment/jfxpub-deployment.htm
+
+ For list of available properties check the files
+ nbproject/build-impl.xml and nbproject/jfx-impl.xml.
+
+ -->
+</project>
--- /dev/null
+Manifest-Version: 1.0
+X-COMMENT: Main-Class will be added automatically by build
+
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+*** GENERATED FROM project.xml - DO NOT EDIT ***
+*** EDIT ../build.xml INSTEAD ***
+
+For the purpose of easier reading the script
+is divided into following sections:
+
+ - initialization
+ - compilation
+ - jar
+ - execution
+ - debugging
+ - javadoc
+ - test compilation
+ - test execution
+ - test debugging
+ - applet
+ - cleanup
+
+ -->
+<project xmlns:j2seproject1="http://www.netbeans.org/ns/j2se-project/1" xmlns:j2seproject3="http://www.netbeans.org/ns/j2se-project/3" xmlns:jaxrpc="http://www.netbeans.org/ns/j2se-project/jax-rpc" basedir=".." default="default" name="TileZ-impl">
+ <import file="jfx-impl.xml"/>
+ <fail message="Please build using Ant 1.8.0 or higher.">
+ <condition>
+ <not>
+ <antversion atleast="1.8.0"/>
+ </not>
+ </condition>
+ </fail>
+ <target depends="test,jar,javadoc" description="Build and test whole project." name="default"/>
+ <!--
+ ======================
+ INITIALIZATION SECTION
+ ======================
+ -->
+ <target name="-pre-init">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="-pre-init" name="-init-private">
+ <property file="nbproject/private/config.properties"/>
+ <property file="nbproject/private/configs/${config}.properties"/>
+ <property file="nbproject/private/private.properties"/>
+ </target>
+ <target depends="-pre-init,-init-private" name="-init-user">
+ <property file="${user.properties.file}"/>
+ <!-- The two properties below are usually overridden -->
+ <!-- by the active platform. Just a fallback. -->
+ <property name="default.javac.source" value="1.4"/>
+ <property name="default.javac.target" value="1.4"/>
+ </target>
+ <target depends="-pre-init,-init-private,-init-user" name="-init-project">
+ <property file="nbproject/configs/${config}.properties"/>
+ <property file="nbproject/project.properties"/>
+ </target>
+ <target depends="-pre-init,-init-private,-init-user,-init-project,-init-macrodef-property" name="-do-init">
+ <j2seproject1:property name="platform.home" value="platforms.${platform.active}.home"/>
+ <j2seproject1:property name="platform.bootcp" value="platforms.${platform.active}.bootclasspath"/>
+ <j2seproject1:property name="platform.compiler" value="platforms.${platform.active}.compile"/>
+ <j2seproject1:property name="platform.javac.tmp" value="platforms.${platform.active}.javac"/>
+ <condition property="platform.javac" value="${platform.home}/bin/javac">
+ <equals arg1="${platform.javac.tmp}" arg2="$${platforms.${platform.active}.javac}"/>
+ </condition>
+ <property name="platform.javac" value="${platform.javac.tmp}"/>
+ <j2seproject1:property name="platform.java.tmp" value="platforms.${platform.active}.java"/>
+ <condition property="platform.java" value="${platform.home}/bin/java">
+ <equals arg1="${platform.java.tmp}" arg2="$${platforms.${platform.active}.java}"/>
+ </condition>
+ <property name="platform.java" value="${platform.java.tmp}"/>
+ <j2seproject1:property name="platform.javadoc.tmp" value="platforms.${platform.active}.javadoc"/>
+ <condition property="platform.javadoc" value="${platform.home}/bin/javadoc">
+ <equals arg1="${platform.javadoc.tmp}" arg2="$${platforms.${platform.active}.javadoc}"/>
+ </condition>
+ <property name="platform.javadoc" value="${platform.javadoc.tmp}"/>
+ <condition property="platform.invalid" value="true">
+ <or>
+ <contains string="${platform.javac}" substring="$${platforms."/>
+ <contains string="${platform.java}" substring="$${platforms."/>
+ <contains string="${platform.javadoc}" substring="$${platforms."/>
+ </or>
+ </condition>
+ <fail unless="platform.home">Must set platform.home</fail>
+ <fail unless="platform.bootcp">Must set platform.bootcp</fail>
+ <fail unless="platform.java">Must set platform.java</fail>
+ <fail unless="platform.javac">Must set platform.javac</fail>
+ <fail if="platform.invalid">
+ The J2SE Platform is not correctly set up.
+ Your active platform is: ${platform.active}, but the corresponding property "platforms.${platform.active}.home" is not found in the project's properties files.
+ Either open the project in the IDE and setup the Platform with the same name or add it manually.
+ For example like this:
+ ant -Duser.properties.file=<path_to_property_file> jar (where you put the property "platforms.${platform.active}.home" in a .properties file)
+ or ant -Dplatforms.${platform.active}.home=<path_to_JDK_home> jar (where no properties file is used)
+ </fail>
+ <available file="${manifest.file}" property="manifest.available"/>
+ <condition property="splashscreen.available">
+ <and>
+ <not>
+ <equals arg1="${application.splash}" arg2="" trim="true"/>
+ </not>
+ <available file="${application.splash}"/>
+ </and>
+ </condition>
+ <condition property="main.class.available">
+ <and>
+ <isset property="main.class"/>
+ <not>
+ <equals arg1="${main.class}" arg2="" trim="true"/>
+ </not>
+ </and>
+ </condition>
+ <condition property="manifest.available+main.class">
+ <and>
+ <isset property="manifest.available"/>
+ <isset property="main.class.available"/>
+ </and>
+ </condition>
+ <condition property="do.archive">
+ <not>
+ <istrue value="${jar.archive.disabled}"/>
+ </not>
+ </condition>
+ <condition property="do.mkdist">
+ <and>
+ <isset property="do.archive"/>
+ <isset property="libs.CopyLibs.classpath"/>
+ <not>
+ <istrue value="${mkdist.disabled}"/>
+ </not>
+ </and>
+ </condition>
+ <condition property="manifest.available+main.class+mkdist.available">
+ <and>
+ <istrue value="${manifest.available+main.class}"/>
+ <isset property="do.mkdist"/>
+ </and>
+ </condition>
+ <condition property="do.archive+manifest.available">
+ <and>
+ <isset property="manifest.available"/>
+ <istrue value="${do.archive}"/>
+ </and>
+ </condition>
+ <condition property="do.archive+main.class.available">
+ <and>
+ <isset property="main.class.available"/>
+ <istrue value="${do.archive}"/>
+ </and>
+ </condition>
+ <condition property="do.archive+splashscreen.available">
+ <and>
+ <isset property="splashscreen.available"/>
+ <istrue value="${do.archive}"/>
+ </and>
+ </condition>
+ <condition property="do.archive+manifest.available+main.class">
+ <and>
+ <istrue value="${manifest.available+main.class}"/>
+ <istrue value="${do.archive}"/>
+ </and>
+ </condition>
+ <condition property="manifest.available-mkdist.available">
+ <or>
+ <istrue value="${manifest.available}"/>
+ <isset property="do.mkdist"/>
+ </or>
+ </condition>
+ <condition property="manifest.available+main.class-mkdist.available">
+ <or>
+ <istrue value="${manifest.available+main.class}"/>
+ <isset property="do.mkdist"/>
+ </or>
+ </condition>
+ <condition property="have.tests">
+ <or>
+ <available file="${test.src.dir}"/>
+ </or>
+ </condition>
+ <condition property="have.sources">
+ <or>
+ <available file="${src.dir}"/>
+ </or>
+ </condition>
+ <condition property="netbeans.home+have.tests">
+ <and>
+ <isset property="netbeans.home"/>
+ <isset property="have.tests"/>
+ </and>
+ </condition>
+ <condition property="no.javadoc.preview">
+ <and>
+ <isset property="javadoc.preview"/>
+ <isfalse value="${javadoc.preview}"/>
+ </and>
+ </condition>
+ <property name="run.jvmargs" value=""/>
+ <property name="run.jvmargs.ide" value=""/>
+ <property name="javac.compilerargs" value=""/>
+ <property name="work.dir" value="${basedir}"/>
+ <condition property="no.deps">
+ <and>
+ <istrue value="${no.dependencies}"/>
+ </and>
+ </condition>
+ <property name="javac.debug" value="true"/>
+ <property name="javadoc.preview" value="true"/>
+ <property name="application.args" value=""/>
+ <property name="source.encoding" value="${file.encoding}"/>
+ <property name="runtime.encoding" value="${source.encoding}"/>
+ <condition property="javadoc.encoding.used" value="${javadoc.encoding}">
+ <and>
+ <isset property="javadoc.encoding"/>
+ <not>
+ <equals arg1="${javadoc.encoding}" arg2=""/>
+ </not>
+ </and>
+ </condition>
+ <property name="javadoc.encoding.used" value="${source.encoding}"/>
+ <property name="includes" value="**"/>
+ <property name="excludes" value=""/>
+ <property name="do.depend" value="false"/>
+ <condition property="do.depend.true">
+ <istrue value="${do.depend}"/>
+ </condition>
+ <path id="endorsed.classpath.path" path="${endorsed.classpath}"/>
+ <condition else="" property="endorsed.classpath.cmd.line.arg" value="-Xbootclasspath/p:'${toString:endorsed.classpath.path}'">
+ <length length="0" string="${endorsed.classpath}" when="greater"/>
+ </condition>
+ <property name="jar.index" value="false"/>
+ <property name="jar.index.metainf" value="${jar.index}"/>
+ <property name="copylibs.rebase" value="true"/>
+ <available file="${meta.inf.dir}/persistence.xml" property="has.persistence.xml"/>
+ <condition property="junit.available">
+ <or>
+ <available classname="org.junit.Test" classpath="${run.test.classpath}"/>
+ <available classname="junit.framework.Test" classpath="${run.test.classpath}"/>
+ </or>
+ </condition>
+ <condition property="testng.available">
+ <available classname="org.testng.annotations.Test" classpath="${run.test.classpath}"/>
+ </condition>
+ <condition property="junit+testng.available">
+ <and>
+ <istrue value="${junit.available}"/>
+ <istrue value="${testng.available}"/>
+ </and>
+ </condition>
+ <condition else="testng" property="testng.mode" value="mixed">
+ <istrue value="${junit+testng.available}"/>
+ </condition>
+ <condition else="" property="testng.debug.mode" value="-mixed">
+ <istrue value="${junit+testng.available}"/>
+ </condition>
+ </target>
+ <target name="-post-init">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="-pre-init,-init-private,-init-user,-init-project,-do-init,-check-javafx" name="-init-check">
+ <fail unless="src.dir">Must set src.dir</fail>
+ <fail unless="test.src.dir">Must set test.src.dir</fail>
+ <fail unless="build.dir">Must set build.dir</fail>
+ <fail unless="dist.dir">Must set dist.dir</fail>
+ <fail unless="build.classes.dir">Must set build.classes.dir</fail>
+ <fail unless="dist.javadoc.dir">Must set dist.javadoc.dir</fail>
+ <fail unless="build.test.classes.dir">Must set build.test.classes.dir</fail>
+ <fail unless="build.test.results.dir">Must set build.test.results.dir</fail>
+ <fail unless="build.classes.excludes">Must set build.classes.excludes</fail>
+ <fail unless="dist.jar">Must set dist.jar</fail>
+ </target>
+ <target name="-init-macrodef-property">
+ <macrodef name="property" uri="http://www.netbeans.org/ns/j2se-project/1">
+ <attribute name="name"/>
+ <attribute name="value"/>
+ <sequential>
+ <property name="@{name}" value="${@{value}}"/>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-ap-cmdline-properties" if="ap.supported.internal" name="-init-macrodef-javac-with-processors">
+ <macrodef name="javac" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${src.dir}" name="srcdir"/>
+ <attribute default="${build.classes.dir}" name="destdir"/>
+ <attribute default="${javac.classpath}" name="classpath"/>
+ <attribute default="${javac.processorpath}" name="processorpath"/>
+ <attribute default="${build.generated.sources.dir}/ap-source-output" name="apgeneratedsrcdir"/>
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="${javac.debug}" name="debug"/>
+ <attribute default="${empty.dir}" name="sourcepath"/>
+ <attribute default="${empty.dir}" name="gensrcdir"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property location="${build.dir}/empty" name="empty.dir"/>
+ <mkdir dir="${empty.dir}"/>
+ <mkdir dir="@{apgeneratedsrcdir}"/>
+ <javac debug="@{debug}" deprecation="${javac.deprecation}" destdir="@{destdir}" encoding="${source.encoding}" excludes="@{excludes}" executable="${platform.javac}" fork="yes" includeantruntime="false" includes="@{includes}" source="${javac.source}" sourcepath="@{sourcepath}" srcdir="@{srcdir}" target="${javac.target}" tempdir="${java.io.tmpdir}">
+ <src>
+ <dirset dir="@{gensrcdir}" erroronmissingdir="false">
+ <include name="*"/>
+ </dirset>
+ </src>
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <compilerarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <compilerarg line="${javac.compilerargs}"/>
+ <compilerarg value="-processorpath"/>
+ <compilerarg path="@{processorpath}:${empty.dir}"/>
+ <compilerarg line="${ap.processors.internal}"/>
+ <compilerarg line="${annotation.processing.processor.options}"/>
+ <compilerarg value="-s"/>
+ <compilerarg path="@{apgeneratedsrcdir}"/>
+ <compilerarg line="${ap.proc.none.internal}"/>
+ <customize/>
+ </javac>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-ap-cmdline-properties" name="-init-macrodef-javac-without-processors" unless="ap.supported.internal">
+ <macrodef name="javac" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${src.dir}" name="srcdir"/>
+ <attribute default="${build.classes.dir}" name="destdir"/>
+ <attribute default="${javac.classpath}" name="classpath"/>
+ <attribute default="${javac.processorpath}" name="processorpath"/>
+ <attribute default="${build.generated.sources.dir}/ap-source-output" name="apgeneratedsrcdir"/>
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="${javac.debug}" name="debug"/>
+ <attribute default="${empty.dir}" name="sourcepath"/>
+ <attribute default="${empty.dir}" name="gensrcdir"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property location="${build.dir}/empty" name="empty.dir"/>
+ <mkdir dir="${empty.dir}"/>
+ <javac debug="@{debug}" deprecation="${javac.deprecation}" destdir="@{destdir}" encoding="${source.encoding}" excludes="@{excludes}" executable="${platform.javac}" fork="yes" includeantruntime="false" includes="@{includes}" source="${javac.source}" sourcepath="@{sourcepath}" srcdir="@{srcdir}" target="${javac.target}" tempdir="${java.io.tmpdir}">
+ <src>
+ <dirset dir="@{gensrcdir}" erroronmissingdir="false">
+ <include name="*"/>
+ </dirset>
+ </src>
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <compilerarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <compilerarg line="${javac.compilerargs}"/>
+ <customize/>
+ </javac>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-javac-with-processors,-init-macrodef-javac-without-processors" name="-init-macrodef-javac">
+ <macrodef name="depend" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${src.dir}" name="srcdir"/>
+ <attribute default="${build.classes.dir}" name="destdir"/>
+ <attribute default="${javac.classpath}" name="classpath"/>
+ <sequential>
+ <depend cache="${build.dir}/depcache" destdir="@{destdir}" excludes="${excludes}" includes="${includes}" srcdir="@{srcdir}">
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ </depend>
+ </sequential>
+ </macrodef>
+ <macrodef name="force-recompile" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${build.classes.dir}" name="destdir"/>
+ <sequential>
+ <fail unless="javac.includes">Must set javac.includes</fail>
+ <pathconvert pathsep="${line.separator}" property="javac.includes.binary">
+ <path>
+ <filelist dir="@{destdir}" files="${javac.includes}"/>
+ </path>
+ <globmapper from="*.java" to="*.class"/>
+ </pathconvert>
+ <tempfile deleteonexit="true" property="javac.includesfile.binary"/>
+ <echo file="${javac.includesfile.binary}" message="${javac.includes.binary}"/>
+ <delete>
+ <files includesfile="${javac.includesfile.binary}"/>
+ </delete>
+ <delete>
+ <fileset file="${javac.includesfile.binary}"/>
+ </delete>
+ </sequential>
+ </macrodef>
+ </target>
+ <target if="${junit.available}" name="-init-macrodef-junit-init">
+ <condition else="false" property="nb.junit.batch" value="true">
+ <and>
+ <istrue value="${junit.available}"/>
+ <not>
+ <isset property="test.method"/>
+ </not>
+ </and>
+ </condition>
+ <condition else="false" property="nb.junit.single" value="true">
+ <and>
+ <istrue value="${junit.available}"/>
+ <isset property="test.method"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-init-test-properties">
+ <property name="test.binaryincludes" value="<nothing>"/>
+ <property name="test.binarytestincludes" value=""/>
+ <property name="test.binaryexcludes" value=""/>
+ </target>
+ <target if="${nb.junit.single}" name="-init-macrodef-junit-single" unless="${nb.junit.batch}">
+ <macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property name="junit.forkmode" value="perTest"/>
+ <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" jvm="${platform.java}" showoutput="true" tempdir="${build.dir}">
+ <test methods="@{testmethods}" name="@{testincludes}" todir="${build.test.results.dir}"/>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <formatter type="brief" usefile="false"/>
+ <formatter type="xml"/>
+ <jvmarg value="-ea"/>
+ <customize/>
+ </junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-test-properties" if="${nb.junit.batch}" name="-init-macrodef-junit-batch" unless="${nb.junit.single}">
+ <macrodef name="junit" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property name="junit.forkmode" value="perTest"/>
+ <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" jvm="${platform.java}" showoutput="true" tempdir="${build.dir}">
+ <batchtest todir="${build.test.results.dir}">
+ <fileset dir="${test.src.dir}" excludes="@{excludes},${excludes}" includes="@{includes}">
+ <filename name="@{testincludes}"/>
+ </fileset>
+ <fileset dir="${build.test.classes.dir}" excludes="@{excludes},${excludes},${test.binaryexcludes}" includes="${test.binaryincludes}">
+ <filename name="${test.binarytestincludes}"/>
+ </fileset>
+ </batchtest>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <formatter type="brief" usefile="false"/>
+ <formatter type="xml"/>
+ <jvmarg value="-ea"/>
+ <customize/>
+ </junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-junit-init,-init-macrodef-junit-single, -init-macrodef-junit-batch" if="${junit.available}" name="-init-macrodef-junit"/>
+ <target if="${testng.available}" name="-init-macrodef-testng">
+ <macrodef name="testng" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <condition else="" property="testng.methods.arg" value="@{testincludes}.@{testmethods}">
+ <isset property="test.method"/>
+ </condition>
+ <union id="test.set">
+ <fileset dir="${test.src.dir}" excludes="@{excludes},**/*.xml,${excludes}" includes="@{includes}">
+ <filename name="@{testincludes}"/>
+ </fileset>
+ </union>
+ <taskdef classname="org.testng.TestNGAntTask" classpath="${run.test.classpath}" name="testng"/>
+ <testng classfilesetref="test.set" failureProperty="tests.failed" jvm="${platform.java}" methods="${testng.methods.arg}" mode="${testng.mode}" outputdir="${build.test.results.dir}" suitename="TileZ" testname="TestNG tests" workingDir="${work.dir}">
+ <xmlfileset dir="${build.test.classes.dir}" includes="@{testincludes}"/>
+ <propertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </propertyset>
+ <customize/>
+ </testng>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-macrodef-test-impl">
+ <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element implicit="true" name="customize" optional="true"/>
+ <sequential>
+ <echo>No tests executed.</echo>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-junit" if="${junit.available}" name="-init-macrodef-junit-impl">
+ <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element implicit="true" name="customize" optional="true"/>
+ <sequential>
+ <j2seproject3:junit excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize/>
+ </j2seproject3:junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-testng" if="${testng.available}" name="-init-macrodef-testng-impl">
+ <macrodef name="test-impl" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element implicit="true" name="customize" optional="true"/>
+ <sequential>
+ <j2seproject3:testng excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize/>
+ </j2seproject3:testng>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-test-impl,-init-macrodef-junit-impl,-init-macrodef-testng-impl" name="-init-macrodef-test">
+ <macrodef name="test" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <sequential>
+ <j2seproject3:test-impl excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ </customize>
+ </j2seproject3:test-impl>
+ </sequential>
+ </macrodef>
+ </target>
+ <target if="${junit.available}" name="-init-macrodef-junit-debug" unless="${nb.junit.batch}">
+ <macrodef name="junit-debug" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property name="junit.forkmode" value="perTest"/>
+ <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" jvm="${platform.java}" showoutput="true" tempdir="${build.dir}">
+ <test methods="@{testmethods}" name="@{testincludes}" todir="${build.test.results.dir}"/>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <formatter type="brief" usefile="false"/>
+ <formatter type="xml"/>
+ <jvmarg value="-ea"/>
+ <jvmarg line="${debug-args-line}"/>
+ <jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/>
+ <customize/>
+ </junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-test-properties" if="${nb.junit.batch}" name="-init-macrodef-junit-debug-batch">
+ <macrodef name="junit-debug" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property name="junit.forkmode" value="perTest"/>
+ <junit dir="${work.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" forkmode="${junit.forkmode}" jvm="${platform.java}" showoutput="true" tempdir="${build.dir}">
+ <batchtest todir="${build.test.results.dir}">
+ <fileset dir="${test.src.dir}" excludes="@{excludes},${excludes}" includes="@{includes}">
+ <filename name="@{testincludes}"/>
+ </fileset>
+ <fileset dir="${build.test.classes.dir}" excludes="@{excludes},${excludes},${test.binaryexcludes}" includes="${test.binaryincludes}">
+ <filename name="${test.binarytestincludes}"/>
+ </fileset>
+ </batchtest>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <formatter type="brief" usefile="false"/>
+ <formatter type="xml"/>
+ <jvmarg value="-ea"/>
+ <jvmarg line="${debug-args-line}"/>
+ <jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/>
+ <customize/>
+ </junit>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-junit-debug,-init-macrodef-junit-debug-batch" if="${junit.available}" name="-init-macrodef-junit-debug-impl">
+ <macrodef name="test-debug-impl" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <element implicit="true" name="customize" optional="true"/>
+ <sequential>
+ <j2seproject3:junit-debug excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize/>
+ </j2seproject3:junit-debug>
+ </sequential>
+ </macrodef>
+ </target>
+ <target if="${testng.available}" name="-init-macrodef-testng-debug">
+ <macrodef name="testng-debug" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${main.class}" name="testClass"/>
+ <attribute default="" name="testMethod"/>
+ <element name="customize2" optional="true"/>
+ <sequential>
+ <condition else="-testclass @{testClass}" property="test.class.or.method" value="-methods @{testClass}.@{testMethod}">
+ <isset property="test.method"/>
+ </condition>
+ <condition else="-suitename TileZ -testname @{testClass} ${test.class.or.method}" property="testng.cmd.args" value="@{testClass}">
+ <matches pattern=".*\.xml" string="@{testClass}"/>
+ </condition>
+ <delete dir="${build.test.results.dir}" quiet="true"/>
+ <mkdir dir="${build.test.results.dir}"/>
+ <j2seproject3:debug classname="org.testng.TestNG" classpath="${debug.test.classpath}">
+ <customize>
+ <customize2/>
+ <jvmarg value="-ea"/>
+ <arg line="${testng.debug.mode}"/>
+ <arg line="-d ${build.test.results.dir}"/>
+ <arg line="-listener org.testng.reporters.VerboseReporter"/>
+ <arg line="${testng.cmd.args}"/>
+ </customize>
+ </j2seproject3:debug>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-testng-debug" if="${testng.available}" name="-init-macrodef-testng-debug-impl">
+ <macrodef name="testng-debug-impl" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${main.class}" name="testClass"/>
+ <attribute default="" name="testMethod"/>
+ <element implicit="true" name="customize2" optional="true"/>
+ <sequential>
+ <j2seproject3:testng-debug testClass="@{testClass}" testMethod="@{testMethod}">
+ <customize2/>
+ </j2seproject3:testng-debug>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-junit-debug-impl" if="${junit.available}" name="-init-macrodef-test-debug-junit">
+ <macrodef name="test-debug" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <attribute default="${main.class}" name="testClass"/>
+ <attribute default="" name="testMethod"/>
+ <sequential>
+ <j2seproject3:test-debug-impl excludes="@{excludes}" includes="@{includes}" testincludes="@{testincludes}" testmethods="@{testmethods}">
+ <customize>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ </customize>
+ </j2seproject3:test-debug-impl>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-testng-debug-impl" if="${testng.available}" name="-init-macrodef-test-debug-testng">
+ <macrodef name="test-debug" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${includes}" name="includes"/>
+ <attribute default="${excludes}" name="excludes"/>
+ <attribute default="**" name="testincludes"/>
+ <attribute default="" name="testmethods"/>
+ <attribute default="${main.class}" name="testClass"/>
+ <attribute default="" name="testMethod"/>
+ <sequential>
+ <j2seproject3:testng-debug-impl testClass="@{testClass}" testMethod="@{testMethod}">
+ <customize2>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ </customize2>
+ </j2seproject3:testng-debug-impl>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-init-macrodef-test-debug-junit,-init-macrodef-test-debug-testng" name="-init-macrodef-test-debug"/>
+ <!--
+ pre NB7.2 profiling section; consider it deprecated
+ -->
+ <target depends="-profile-pre-init, init, -profile-post-init, -profile-init-macrodef-profile, -profile-init-check" if="profiler.info.jvmargs.agent" name="profile-init"/>
+ <target if="profiler.info.jvmargs.agent" name="-profile-pre-init">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target if="profiler.info.jvmargs.agent" name="-profile-post-init">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target if="profiler.info.jvmargs.agent" name="-profile-init-macrodef-profile">
+ <macrodef name="resolve">
+ <attribute name="name"/>
+ <attribute name="value"/>
+ <sequential>
+ <property name="@{name}" value="${env.@{value}}"/>
+ </sequential>
+ </macrodef>
+ <macrodef name="profile">
+ <attribute default="${main.class}" name="classname"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property environment="env"/>
+ <resolve name="profiler.current.path" value="${profiler.info.pathvar}"/>
+ <java classname="@{classname}" dir="${profiler.info.dir}" fork="true" jvm="${profiler.info.jvm}">
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg value="${profiler.info.jvmargs.agent}"/>
+ <jvmarg line="${profiler.info.jvmargs}"/>
+ <env key="${profiler.info.pathvar}" path="${profiler.info.agentpath}:${profiler.current.path}"/>
+ <arg line="${application.args}"/>
+ <classpath>
+ <path path="${run.classpath}"/>
+ </classpath>
+ <syspropertyset>
+ <propertyref prefix="run-sys-prop."/>
+ <mapper from="run-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <customize/>
+ </java>
+ </sequential>
+ </macrodef>
+ </target>
+ <target depends="-profile-pre-init, init, -profile-post-init, -profile-init-macrodef-profile" if="profiler.info.jvmargs.agent" name="-profile-init-check">
+ <fail unless="profiler.info.jvm">Must set JVM to use for profiling in profiler.info.jvm</fail>
+ <fail unless="profiler.info.jvmargs.agent">Must set profiler agent JVM arguments in profiler.info.jvmargs.agent</fail>
+ </target>
+ <!--
+ end of pre NB7.2 profiling section
+ -->
+ <target depends="-init-debug-args" name="-init-macrodef-nbjpda">
+ <macrodef name="nbjpdastart" uri="http://www.netbeans.org/ns/j2se-project/1">
+ <attribute default="${main.class}" name="name"/>
+ <attribute default="${debug.classpath}" name="classpath"/>
+ <attribute default="" name="stopclassname"/>
+ <sequential>
+ <nbjpdastart addressproperty="jpda.address" name="@{name}" stopclassname="@{stopclassname}" transport="${debug-transport}">
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <bootclasspath>
+ <path path="${platform.bootcp}"/>
+ </bootclasspath>
+ </nbjpdastart>
+ </sequential>
+ </macrodef>
+ <macrodef name="nbjpdareload" uri="http://www.netbeans.org/ns/j2se-project/1">
+ <attribute default="${build.classes.dir}" name="dir"/>
+ <sequential>
+ <nbjpdareload>
+ <fileset dir="@{dir}" includes="${fix.classes}">
+ <include name="${fix.includes}*.class"/>
+ </fileset>
+ </nbjpdareload>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-debug-args">
+ <exec executable="${platform.java}" outputproperty="version-output">
+ <arg value="-version"/>
+ </exec>
+ <condition property="have-jdk-older-than-1.4">
+ <or>
+ <contains string="${version-output}" substring="java version "1.0"/>
+ <contains string="${version-output}" substring="java version "1.1"/>
+ <contains string="${version-output}" substring="java version "1.2"/>
+ <contains string="${version-output}" substring="java version "1.3"/>
+ </or>
+ </condition>
+ <condition else="-Xdebug" property="debug-args-line" value="-Xdebug -Xnoagent -Djava.compiler=none">
+ <istrue value="${have-jdk-older-than-1.4}"/>
+ </condition>
+ <condition else="dt_socket" property="debug-transport-by-os" value="dt_shmem">
+ <os family="windows"/>
+ </condition>
+ <condition else="${debug-transport-by-os}" property="debug-transport" value="${debug.transport}">
+ <isset property="debug.transport"/>
+ </condition>
+ </target>
+ <target depends="-init-debug-args" name="-init-macrodef-debug">
+ <macrodef name="debug" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${main.class}" name="classname"/>
+ <attribute default="${debug.classpath}" name="classpath"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <java classname="@{classname}" dir="${work.dir}" fork="true" jvm="${platform.java}">
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg line="${debug-args-line}"/>
+ <jvmarg value="-Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/>
+ <jvmarg value="-Dfile.encoding=${runtime.encoding}"/>
+ <redirector errorencoding="${runtime.encoding}" inputencoding="${runtime.encoding}" outputencoding="${runtime.encoding}"/>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <syspropertyset>
+ <propertyref prefix="run-sys-prop."/>
+ <mapper from="run-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <customize/>
+ </java>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-macrodef-java">
+ <macrodef name="java" uri="http://www.netbeans.org/ns/j2se-project/1">
+ <attribute default="${main.class}" name="classname"/>
+ <attribute default="${run.classpath}" name="classpath"/>
+ <attribute default="jvm" name="jvm"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <java classname="@{classname}" dir="${work.dir}" fork="true" jvm="${platform.java}">
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg value="-Dfile.encoding=${runtime.encoding}"/>
+ <redirector errorencoding="${runtime.encoding}" inputencoding="${runtime.encoding}" outputencoding="${runtime.encoding}"/>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ <classpath>
+ <path path="@{classpath}"/>
+ </classpath>
+ <syspropertyset>
+ <propertyref prefix="run-sys-prop."/>
+ <mapper from="run-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <customize/>
+ </java>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-macrodef-copylibs">
+ <macrodef name="copylibs" uri="http://www.netbeans.org/ns/j2se-project/3">
+ <attribute default="${manifest.file}" name="manifest"/>
+ <element name="customize" optional="true"/>
+ <sequential>
+ <property location="${build.classes.dir}" name="build.classes.dir.resolved"/>
+ <pathconvert property="run.classpath.without.build.classes.dir">
+ <path path="${run.classpath}"/>
+ <map from="${build.classes.dir.resolved}" to=""/>
+ </pathconvert>
+ <pathconvert pathsep=" " property="jar.classpath">
+ <path path="${run.classpath.without.build.classes.dir}"/>
+ <chainedmapper>
+ <flattenmapper/>
+ <filtermapper>
+ <replacestring from=" " to="%20"/>
+ </filtermapper>
+ <globmapper from="*" to="lib/*"/>
+ </chainedmapper>
+ </pathconvert>
+ <taskdef classname="org.netbeans.modules.java.j2seproject.copylibstask.CopyLibs" classpath="${libs.CopyLibs.classpath}" name="copylibs"/>
+ <copylibs compress="${jar.compress}" index="${jar.index}" indexMetaInf="${jar.index.metainf}" jarfile="${dist.jar}" manifest="@{manifest}" rebase="${copylibs.rebase}" runtimeclasspath="${run.classpath.without.build.classes.dir}">
+ <fileset dir="${build.classes.dir}"/>
+ <manifest>
+ <attribute name="Class-Path" value="${jar.classpath}"/>
+ <customize/>
+ </manifest>
+ </copylibs>
+ </sequential>
+ </macrodef>
+ </target>
+ <target name="-init-presetdef-jar">
+ <presetdef name="jar" uri="http://www.netbeans.org/ns/j2se-project/1">
+ <jar compress="${jar.compress}" index="${jar.index}" jarfile="${dist.jar}">
+ <j2seproject1:fileset dir="${build.classes.dir}"/>
+ </jar>
+ </presetdef>
+ </target>
+ <target name="-init-ap-cmdline-properties">
+ <property name="annotation.processing.enabled" value="true"/>
+ <property name="annotation.processing.processors.list" value=""/>
+ <property name="annotation.processing.processor.options" value=""/>
+ <property name="annotation.processing.run.all.processors" value="true"/>
+ <property name="javac.processorpath" value="${javac.classpath}"/>
+ <property name="javac.test.processorpath" value="${javac.test.classpath}"/>
+ <condition property="ap.supported.internal" value="true">
+ <not>
+ <matches pattern="1\.[0-5](\..*)?" string="${javac.source}"/>
+ </not>
+ </condition>
+ </target>
+ <target depends="-init-ap-cmdline-properties" if="ap.supported.internal" name="-init-ap-cmdline-supported">
+ <condition else="" property="ap.processors.internal" value="-processor ${annotation.processing.processors.list}">
+ <isfalse value="${annotation.processing.run.all.processors}"/>
+ </condition>
+ <condition else="" property="ap.proc.none.internal" value="-proc:none">
+ <isfalse value="${annotation.processing.enabled}"/>
+ </condition>
+ </target>
+ <target depends="-init-ap-cmdline-properties,-init-ap-cmdline-supported" name="-init-ap-cmdline">
+ <property name="ap.cmd.line.internal" value=""/>
+ </target>
+ <target depends="-pre-init,-init-private,-init-user,-init-project,-do-init,-post-init,-init-check,-init-macrodef-property,-init-macrodef-javac,-init-macrodef-test,-init-macrodef-test-debug,-init-macrodef-nbjpda,-init-macrodef-debug,-init-macrodef-java,-init-presetdef-jar,-init-ap-cmdline" name="init"/>
+ <!--
+ ===================
+ COMPILATION SECTION
+ ===================
+ -->
+ <target name="-deps-jar-init" unless="built-jar.properties">
+ <property location="${build.dir}/built-jar.properties" name="built-jar.properties"/>
+ <delete file="${built-jar.properties}" quiet="true"/>
+ </target>
+ <target if="already.built.jar.${basedir}" name="-warn-already-built-jar">
+ <echo level="warn" message="Cycle detected: TileZ was already built"/>
+ </target>
+ <target depends="init,-deps-jar-init" name="deps-jar" unless="no.deps">
+ <mkdir dir="${build.dir}"/>
+ <touch file="${built-jar.properties}" verbose="false"/>
+ <property file="${built-jar.properties}" prefix="already.built.jar."/>
+ <antcall target="-warn-already-built-jar"/>
+ <propertyfile file="${built-jar.properties}">
+ <entry key="${basedir}" value=""/>
+ </propertyfile>
+ <antcall target="-maybe-call-dep">
+ <param name="call.built.properties" value="${built-jar.properties}"/>
+ <param location="${project.DuskServer}" name="call.subproject"/>
+ <param location="${project.DuskServer}/build.xml" name="call.script"/>
+ <param name="call.target" value="jar"/>
+ <param name="transfer.built-jar.properties" value="${built-jar.properties}"/>
+ </antcall>
+ <antcall target="-maybe-call-dep">
+ <param name="call.built.properties" value="${built-jar.properties}"/>
+ <param location="${project.DuskZ}" name="call.subproject"/>
+ <param location="${project.DuskZ}/build.xml" name="call.script"/>
+ <param name="call.target" value="jar"/>
+ <param name="transfer.built-jar.properties" value="${built-jar.properties}"/>
+ </antcall>
+ </target>
+ <target depends="init,-check-automatic-build,-clean-after-automatic-build" name="-verify-automatic-build"/>
+ <target depends="init" name="-check-automatic-build">
+ <available file="${build.classes.dir}/.netbeans_automatic_build" property="netbeans.automatic.build"/>
+ </target>
+ <target depends="init" if="netbeans.automatic.build" name="-clean-after-automatic-build">
+ <antcall target="clean"/>
+ </target>
+ <target depends="init,deps-jar" name="-pre-pre-compile">
+ <mkdir dir="${build.classes.dir}"/>
+ </target>
+ <target name="-pre-compile">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target if="do.depend.true" name="-compile-depend">
+ <pathconvert property="build.generated.subdirs">
+ <dirset dir="${build.generated.sources.dir}" erroronmissingdir="false">
+ <include name="*"/>
+ </dirset>
+ </pathconvert>
+ <j2seproject3:depend srcdir="${src.dir}:${build.generated.subdirs}"/>
+ </target>
+ <target depends="init,deps-jar,-pre-pre-compile,-pre-compile, -copy-persistence-xml,-compile-depend" if="have.sources" name="-do-compile">
+ <j2seproject3:javac gensrcdir="${build.generated.sources.dir}"/>
+ <copy todir="${build.classes.dir}">
+ <fileset dir="${src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ </copy>
+ </target>
+ <target if="has.persistence.xml" name="-copy-persistence-xml">
+ <mkdir dir="${build.classes.dir}/META-INF"/>
+ <copy todir="${build.classes.dir}/META-INF">
+ <fileset dir="${meta.inf.dir}" includes="persistence.xml orm.xml"/>
+ </copy>
+ </target>
+ <target name="-post-compile">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,deps-jar,-verify-automatic-build,-pre-pre-compile,-pre-compile,-do-compile,-post-compile" description="Compile project." name="compile"/>
+ <target name="-pre-compile-single">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,deps-jar,-pre-pre-compile" name="-do-compile-single">
+ <fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail>
+ <j2seproject3:force-recompile/>
+ <j2seproject3:javac excludes="" gensrcdir="${build.generated.sources.dir}" includes="${javac.includes}" sourcepath="${src.dir}"/>
+ </target>
+ <target name="-post-compile-single">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,deps-jar,-verify-automatic-build,-pre-pre-compile,-pre-compile-single,-do-compile-single,-post-compile-single" name="compile-single"/>
+ <!--
+ ====================
+ JAR BUILDING SECTION
+ ====================
+ -->
+ <target depends="init" name="-pre-pre-jar">
+ <dirname file="${dist.jar}" property="dist.jar.dir"/>
+ <mkdir dir="${dist.jar.dir}"/>
+ </target>
+ <target name="-pre-jar">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,compile,-pre-pre-jar,-pre-jar" if="do.archive" name="-do-jar-without-manifest" unless="manifest.available-mkdist.available">
+ <j2seproject1:jar/>
+ </target>
+ <target depends="init,compile,-pre-pre-jar,-pre-jar" if="do.archive+manifest.available" name="-do-jar-with-manifest" unless="manifest.available+main.class-mkdist.available">
+ <j2seproject1:jar manifest="${manifest.file}"/>
+ </target>
+ <target depends="init,compile,-pre-pre-jar,-pre-jar" if="do.archive+manifest.available+main.class" name="-do-jar-with-mainclass" unless="manifest.available+main.class+mkdist.available">
+ <j2seproject1:jar manifest="${manifest.file}">
+ <j2seproject1:manifest>
+ <j2seproject1:attribute name="Main-Class" value="${main.class}"/>
+ </j2seproject1:manifest>
+ </j2seproject1:jar>
+ <echo level="info">To run this application from the command line without Ant, try:</echo>
+ <property location="${build.classes.dir}" name="build.classes.dir.resolved"/>
+ <property location="${dist.jar}" name="dist.jar.resolved"/>
+ <pathconvert property="run.classpath.with.dist.jar">
+ <path path="${run.classpath}"/>
+ <map from="${build.classes.dir.resolved}" to="${dist.jar.resolved}"/>
+ </pathconvert>
+ <echo level="info">${platform.java} -cp "${run.classpath.with.dist.jar}" ${main.class}</echo>
+ </target>
+ <target depends="init" if="do.archive" name="-do-jar-with-libraries-create-manifest" unless="manifest.available">
+ <tempfile deleteonexit="true" destdir="${build.dir}" property="tmp.manifest.file"/>
+ <touch file="${tmp.manifest.file}" verbose="false"/>
+ </target>
+ <target depends="init" if="do.archive+manifest.available" name="-do-jar-with-libraries-copy-manifest">
+ <tempfile deleteonexit="true" destdir="${build.dir}" property="tmp.manifest.file"/>
+ <copy file="${manifest.file}" tofile="${tmp.manifest.file}"/>
+ </target>
+ <target depends="init,-do-jar-with-libraries-create-manifest,-do-jar-with-libraries-copy-manifest" if="do.archive+main.class.available" name="-do-jar-with-libraries-set-main">
+ <manifest file="${tmp.manifest.file}" mode="update">
+ <attribute name="Main-Class" value="${main.class}"/>
+ </manifest>
+ </target>
+ <target depends="init,-do-jar-with-libraries-create-manifest,-do-jar-with-libraries-copy-manifest" if="do.archive+splashscreen.available" name="-do-jar-with-libraries-set-splashscreen">
+ <basename file="${application.splash}" property="splashscreen.basename"/>
+ <mkdir dir="${build.classes.dir}/META-INF"/>
+ <copy failonerror="false" file="${application.splash}" todir="${build.classes.dir}/META-INF"/>
+ <manifest file="${tmp.manifest.file}" mode="update">
+ <attribute name="SplashScreen-Image" value="META-INF/${splashscreen.basename}"/>
+ </manifest>
+ </target>
+ <target depends="init,-init-macrodef-copylibs,compile,-pre-pre-jar,-pre-jar,-do-jar-with-libraries-create-manifest,-do-jar-with-libraries-copy-manifest,-do-jar-with-libraries-set-main,-do-jar-with-libraries-set-splashscreen" if="do.mkdist" name="-do-jar-with-libraries-pack">
+ <j2seproject3:copylibs manifest="${tmp.manifest.file}"/>
+ <echo level="info">To run this application from the command line without Ant, try:</echo>
+ <property location="${dist.jar}" name="dist.jar.resolved"/>
+ <echo level="info">${platform.java} -jar "${dist.jar.resolved}"</echo>
+ </target>
+ <target depends="-do-jar-with-libraries-pack" if="do.archive" name="-do-jar-with-libraries-delete-manifest">
+ <delete>
+ <fileset file="${tmp.manifest.file}"/>
+ </delete>
+ </target>
+ <target depends="init,compile,-pre-pre-jar,-pre-jar,-do-jar-with-libraries-create-manifest,-do-jar-with-libraries-copy-manifest,-do-jar-with-libraries-set-main,-do-jar-with-libraries-set-splashscreen,-do-jar-with-libraries-pack,-do-jar-with-libraries-delete-manifest" name="-do-jar-with-libraries"/>
+ <target depends="-jfx-copylibs,-rebase-libs,jfx-deployment" name="-post-jar">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,compile,-pre-jar,-do-jar-with-manifest,-do-jar-without-manifest,-do-jar-with-mainclass,-do-jar-with-libraries,-post-jar,-jfx-copylibs,-rebase-libs" description="Build JAR." name="jar"/>
+ <!--
+ =================
+ EXECUTION SECTION
+ =================
+ -->
+ <target depends="init,compile,jar" description="Run a main class." name="run">
+ <j2seproject1:java>
+ <customize>
+ <arg line="${application.args}"/>
+ </customize>
+ </j2seproject1:java>
+ </target>
+ <target name="-do-not-recompile">
+ <property name="javac.includes.binary" value=""/>
+ </target>
+ <target depends="init,compile-single" name="run-single">
+ <fail unless="run.class">Must select one file in the IDE or set run.class</fail>
+ <j2seproject1:java classname="${run.class}"/>
+ </target>
+ <target depends="init,compile-test-single" name="run-test-with-main">
+ <fail unless="run.class">Must select one file in the IDE or set run.class</fail>
+ <j2seproject1:java classname="${run.class}" classpath="${run.test.classpath}"/>
+ </target>
+ <!--
+ =================
+ DEBUGGING SECTION
+ =================
+ -->
+ <target depends="init" if="netbeans.home" name="-debug-start-debugger">
+ <j2seproject1:nbjpdastart name="${debug.class}"/>
+ </target>
+ <target depends="init" if="netbeans.home" name="-debug-start-debugger-main-test">
+ <j2seproject1:nbjpdastart classpath="${debug.test.classpath}" name="${debug.class}"/>
+ </target>
+ <target depends="init,compile" name="-debug-start-debuggee">
+ <j2seproject3:debug>
+ <customize>
+ <arg line="${application.args}"/>
+ </customize>
+ </j2seproject3:debug>
+ </target>
+ <target depends="init,compile,-debug-start-debugger,-debug-start-debuggee,jar" description="Debug project in IDE." if="netbeans.home" name="debug"/>
+ <target depends="init" if="netbeans.home" name="-debug-start-debugger-stepinto">
+ <j2seproject1:nbjpdastart stopclassname="${main.class}"/>
+ </target>
+ <target depends="init,compile,-debug-start-debugger-stepinto,-debug-start-debuggee" if="netbeans.home" name="debug-stepinto"/>
+ <target depends="init,compile-single" if="netbeans.home" name="-debug-start-debuggee-single">
+ <fail unless="debug.class">Must select one file in the IDE or set debug.class</fail>
+ <j2seproject3:debug classname="${debug.class}"/>
+ </target>
+ <target depends="init,compile-single,-debug-start-debugger,-debug-start-debuggee-single" if="netbeans.home" name="debug-single"/>
+ <target depends="init,compile-test-single" if="netbeans.home" name="-debug-start-debuggee-main-test">
+ <fail unless="debug.class">Must select one file in the IDE or set debug.class</fail>
+ <j2seproject3:debug classname="${debug.class}" classpath="${debug.test.classpath}"/>
+ </target>
+ <target depends="init,compile-test-single,-debug-start-debugger-main-test,-debug-start-debuggee-main-test" if="netbeans.home" name="debug-test-with-main"/>
+ <target depends="init" name="-pre-debug-fix">
+ <fail unless="fix.includes">Must set fix.includes</fail>
+ <property name="javac.includes" value="${fix.includes}.java"/>
+ </target>
+ <target depends="init,-pre-debug-fix,compile-single" if="netbeans.home" name="-do-debug-fix">
+ <j2seproject1:nbjpdareload/>
+ </target>
+ <target depends="init,-pre-debug-fix,-do-debug-fix" if="netbeans.home" name="debug-fix"/>
+ <!--
+ =================
+ PROFILING SECTION
+ =================
+ -->
+ <!--
+ pre NB7.2 profiler integration
+ -->
+ <target depends="profile-init,compile" description="Profile a project in the IDE." if="profiler.info.jvmargs.agent" name="-profile-pre72">
+ <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail>
+ <nbprofiledirect>
+ <classpath>
+ <path path="${run.classpath}"/>
+ </classpath>
+ </nbprofiledirect>
+ <profile/>
+ </target>
+ <target depends="profile-init,compile-single" description="Profile a selected class in the IDE." if="profiler.info.jvmargs.agent" name="-profile-single-pre72">
+ <fail unless="profile.class">Must select one file in the IDE or set profile.class</fail>
+ <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail>
+ <nbprofiledirect>
+ <classpath>
+ <path path="${run.classpath}"/>
+ </classpath>
+ </nbprofiledirect>
+ <profile classname="${profile.class}"/>
+ </target>
+ <target depends="profile-init,compile-single" if="profiler.info.jvmargs.agent" name="-profile-applet-pre72">
+ <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail>
+ <nbprofiledirect>
+ <classpath>
+ <path path="${run.classpath}"/>
+ </classpath>
+ </nbprofiledirect>
+ <profile classname="sun.applet.AppletViewer">
+ <customize>
+ <arg value="${applet.url}"/>
+ </customize>
+ </profile>
+ </target>
+ <target depends="profile-init,compile-test-single" if="profiler.info.jvmargs.agent" name="-profile-test-single-pre72">
+ <fail unless="netbeans.home">This target only works when run from inside the NetBeans IDE.</fail>
+ <nbprofiledirect>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ </nbprofiledirect>
+ <junit dir="${profiler.info.dir}" errorproperty="tests.failed" failureproperty="tests.failed" fork="true" jvm="${profiler.info.jvm}" showoutput="true">
+ <env key="${profiler.info.pathvar}" path="${profiler.info.agentpath}:${profiler.current.path}"/>
+ <jvmarg value="${profiler.info.jvmargs.agent}"/>
+ <jvmarg line="${profiler.info.jvmargs}"/>
+ <test name="${profile.class}"/>
+ <classpath>
+ <path path="${run.test.classpath}"/>
+ </classpath>
+ <syspropertyset>
+ <propertyref prefix="test-sys-prop."/>
+ <mapper from="test-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ <formatter type="brief" usefile="false"/>
+ <formatter type="xml"/>
+ </junit>
+ </target>
+ <!--
+ end of pre NB72 profiling section
+ -->
+ <target if="netbeans.home" name="-profile-check">
+ <condition property="profiler.configured">
+ <or>
+ <contains casesensitive="true" string="${run.jvmargs.ide}" substring="-agentpath:"/>
+ <contains casesensitive="true" string="${run.jvmargs.ide}" substring="-javaagent:"/>
+ </or>
+ </condition>
+ </target>
+ <target depends="-profile-check,-profile-pre72,jar" description="Profile a project in the IDE." if="profiler.configured" name="profile" unless="profiler.info.jvmargs.agent">
+ <startprofiler/>
+ <antcall target="run"/>
+ </target>
+ <target depends="-profile-check,-profile-single-pre72" description="Profile a selected class in the IDE." if="profiler.configured" name="profile-single" unless="profiler.info.jvmargs.agent">
+ <fail unless="run.class">Must select one file in the IDE or set run.class</fail>
+ <startprofiler/>
+ <antcall target="run-single"/>
+ </target>
+ <target depends="-profile-test-single-pre72" description="Profile a selected test in the IDE." name="profile-test-single"/>
+ <target depends="-profile-check" description="Profile a selected test in the IDE." if="profiler.configured" name="profile-test" unless="profiler.info.jvmargs">
+ <fail unless="test.includes">Must select some files in the IDE or set test.includes</fail>
+ <startprofiler/>
+ <antcall target="test-single"/>
+ </target>
+ <target depends="-profile-check" description="Profile a selected class in the IDE." if="profiler.configured" name="profile-test-with-main">
+ <fail unless="run.class">Must select one file in the IDE or set run.class</fail>
+ <startprofiler/>
+ <antcal target="run-test-with-main"/>
+ </target>
+ <target depends="-profile-check,-profile-applet-pre72" if="profiler.configured" name="profile-applet" unless="profiler.info.jvmargs.agent">
+ <fail unless="applet.url">Must select one file in the IDE or set applet.url</fail>
+ <startprofiler/>
+ <antcall target="run-applet"/>
+ </target>
+ <!--
+ ===============
+ JAVADOC SECTION
+ ===============
+ -->
+ <target depends="init" if="have.sources" name="-javadoc-build">
+ <mkdir dir="${dist.javadoc.dir}"/>
+ <condition else="" property="javadoc.endorsed.classpath.cmd.line.arg" value="-J${endorsed.classpath.cmd.line.arg}">
+ <and>
+ <isset property="endorsed.classpath.cmd.line.arg"/>
+ <not>
+ <equals arg1="${endorsed.classpath.cmd.line.arg}" arg2=""/>
+ </not>
+ </and>
+ </condition>
+ <javadoc additionalparam="${javadoc.additionalparam}" author="${javadoc.author}" charset="UTF-8" destdir="${dist.javadoc.dir}" docencoding="UTF-8" encoding="${javadoc.encoding.used}" executable="${platform.javadoc}" failonerror="true" noindex="${javadoc.noindex}" nonavbar="${javadoc.nonavbar}" notree="${javadoc.notree}" private="${javadoc.private}" source="${javac.source}" splitindex="${javadoc.splitindex}" use="${javadoc.use}" useexternalfile="true" version="${javadoc.version}" windowtitle="${javadoc.windowtitle}">
+ <classpath>
+ <path path="${javac.classpath}"/>
+ </classpath>
+ <fileset dir="${src.dir}" excludes="*.java,${excludes}" includes="${includes}">
+ <filename name="**/*.java"/>
+ </fileset>
+ <fileset dir="${build.generated.sources.dir}" erroronmissingdir="false">
+ <include name="**/*.java"/>
+ <exclude name="*.java"/>
+ </fileset>
+ <arg line="${javadoc.endorsed.classpath.cmd.line.arg}"/>
+ </javadoc>
+ <copy todir="${dist.javadoc.dir}">
+ <fileset dir="${src.dir}" excludes="${excludes}" includes="${includes}">
+ <filename name="**/doc-files/**"/>
+ </fileset>
+ <fileset dir="${build.generated.sources.dir}" erroronmissingdir="false">
+ <include name="**/doc-files/**"/>
+ </fileset>
+ </copy>
+ </target>
+ <target depends="init,-javadoc-build" if="netbeans.home" name="-javadoc-browse" unless="no.javadoc.preview">
+ <nbbrowse file="${dist.javadoc.dir}/index.html"/>
+ </target>
+ <target depends="init,-javadoc-build,-javadoc-browse" description="Build Javadoc." name="javadoc"/>
+ <!--
+ =========================
+ TEST COMPILATION SECTION
+ =========================
+ -->
+ <target depends="init,compile" if="have.tests" name="-pre-pre-compile-test">
+ <mkdir dir="${build.test.classes.dir}"/>
+ </target>
+ <target name="-pre-compile-test">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target if="do.depend.true" name="-compile-test-depend">
+ <j2seproject3:depend classpath="${javac.test.classpath}" destdir="${build.test.classes.dir}" srcdir="${test.src.dir}"/>
+ </target>
+ <target depends="init,deps-jar,compile,-pre-pre-compile-test,-pre-compile-test,-compile-test-depend" if="have.tests" name="-do-compile-test">
+ <j2seproject3:javac apgeneratedsrcdir="${build.test.classes.dir}" classpath="${javac.test.classpath}" debug="true" destdir="${build.test.classes.dir}" processorpath="${javac.test.processorpath}" srcdir="${test.src.dir}"/>
+ <copy todir="${build.test.classes.dir}">
+ <fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ </copy>
+ </target>
+ <target name="-post-compile-test">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,compile,-pre-pre-compile-test,-pre-compile-test,-do-compile-test,-post-compile-test" name="compile-test"/>
+ <target name="-pre-compile-test-single">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,deps-jar,compile,-pre-pre-compile-test,-pre-compile-test-single" if="have.tests" name="-do-compile-test-single">
+ <fail unless="javac.includes">Must select some files in the IDE or set javac.includes</fail>
+ <j2seproject3:force-recompile destdir="${build.test.classes.dir}"/>
+ <j2seproject3:javac apgeneratedsrcdir="${build.test.classes.dir}" classpath="${javac.test.classpath}" debug="true" destdir="${build.test.classes.dir}" excludes="" includes="${javac.includes}" processorpath="${javac.test.processorpath}" sourcepath="${test.src.dir}" srcdir="${test.src.dir}"/>
+ <copy todir="${build.test.classes.dir}">
+ <fileset dir="${test.src.dir}" excludes="${build.classes.excludes},${excludes}" includes="${includes}"/>
+ </copy>
+ </target>
+ <target name="-post-compile-test-single">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,compile,-pre-pre-compile-test,-pre-compile-test-single,-do-compile-test-single,-post-compile-test-single" name="compile-test-single"/>
+ <!--
+ =======================
+ TEST EXECUTION SECTION
+ =======================
+ -->
+ <target depends="init" if="have.tests" name="-pre-test-run">
+ <mkdir dir="${build.test.results.dir}"/>
+ </target>
+ <target depends="init,compile-test,-pre-test-run" if="have.tests" name="-do-test-run">
+ <j2seproject3:test testincludes="**/*Test.java"/>
+ </target>
+ <target depends="init,compile-test,-pre-test-run,-do-test-run" if="have.tests" name="-post-test-run">
+ <fail if="tests.failed" unless="ignore.failing.tests">Some tests failed; see details above.</fail>
+ </target>
+ <target depends="init" if="have.tests" name="test-report"/>
+ <target depends="init" if="netbeans.home+have.tests" name="-test-browse"/>
+ <target depends="init,compile-test,-pre-test-run,-do-test-run,test-report,-post-test-run,-test-browse" description="Run unit tests." name="test"/>
+ <target depends="init" if="have.tests" name="-pre-test-run-single">
+ <mkdir dir="${build.test.results.dir}"/>
+ </target>
+ <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-do-test-run-single">
+ <fail unless="test.includes">Must select some files in the IDE or set test.includes</fail>
+ <j2seproject3:test excludes="" includes="${test.includes}" testincludes="${test.includes}"/>
+ </target>
+ <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single" if="have.tests" name="-post-test-run-single">
+ <fail if="tests.failed" unless="ignore.failing.tests">Some tests failed; see details above.</fail>
+ </target>
+ <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single,-post-test-run-single" description="Run single unit test." name="test-single"/>
+ <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-do-test-run-single-method">
+ <fail unless="test.class">Must select some files in the IDE or set test.class</fail>
+ <fail unless="test.method">Must select some method in the IDE or set test.method</fail>
+ <j2seproject3:test excludes="" includes="${javac.includes}" testincludes="${test.class}" testmethods="${test.method}"/>
+ </target>
+ <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single-method" if="have.tests" name="-post-test-run-single-method">
+ <fail if="tests.failed" unless="ignore.failing.tests">Some tests failed; see details above.</fail>
+ </target>
+ <target depends="init,compile-test-single,-pre-test-run-single,-do-test-run-single-method,-post-test-run-single-method" description="Run single unit test." name="test-single-method"/>
+ <!--
+ =======================
+ TEST DEBUGGING SECTION
+ =======================
+ -->
+ <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-debug-start-debuggee-test">
+ <fail unless="test.class">Must select one file in the IDE or set test.class</fail>
+ <j2seproject3:test-debug excludes="" includes="${javac.includes}" testClass="${test.class}" testincludes="${javac.includes}"/>
+ </target>
+ <target depends="init,compile-test-single,-pre-test-run-single" if="have.tests" name="-debug-start-debuggee-test-method">
+ <fail unless="test.class">Must select one file in the IDE or set test.class</fail>
+ <fail unless="test.method">Must select some method in the IDE or set test.method</fail>
+ <j2seproject3:test-debug excludes="" includes="${javac.includes}" testClass="${test.class}" testMethod="${test.method}" testincludes="${test.class}" testmethods="${test.method}"/>
+ </target>
+ <target depends="init,compile-test" if="netbeans.home+have.tests" name="-debug-start-debugger-test">
+ <j2seproject1:nbjpdastart classpath="${debug.test.classpath}" name="${test.class}"/>
+ </target>
+ <target depends="init,compile-test-single,-debug-start-debugger-test,-debug-start-debuggee-test" name="debug-test"/>
+ <target depends="init,compile-test-single,-debug-start-debugger-test,-debug-start-debuggee-test-method" name="debug-test-method"/>
+ <target depends="init,-pre-debug-fix,compile-test-single" if="netbeans.home" name="-do-debug-fix-test">
+ <j2seproject1:nbjpdareload dir="${build.test.classes.dir}"/>
+ </target>
+ <target depends="init,-pre-debug-fix,-do-debug-fix-test" if="netbeans.home" name="debug-fix-test"/>
+ <!--
+ =========================
+ APPLET EXECUTION SECTION
+ =========================
+ -->
+ <target depends="init,compile-single" name="run-applet">
+ <fail unless="applet.url">Must select one file in the IDE or set applet.url</fail>
+ <j2seproject1:java classname="sun.applet.AppletViewer">
+ <customize>
+ <arg value="${applet.url}"/>
+ </customize>
+ </j2seproject1:java>
+ </target>
+ <!--
+ =========================
+ APPLET DEBUGGING SECTION
+ =========================
+ -->
+ <target depends="init,compile-single" if="netbeans.home" name="-debug-start-debuggee-applet">
+ <fail unless="applet.url">Must select one file in the IDE or set applet.url</fail>
+ <j2seproject3:debug classname="sun.applet.AppletViewer">
+ <customize>
+ <arg value="${applet.url}"/>
+ </customize>
+ </j2seproject3:debug>
+ </target>
+ <target depends="init,compile-single,-debug-start-debugger,-debug-start-debuggee-applet" if="netbeans.home" name="debug-applet"/>
+ <!--
+ ===============
+ CLEANUP SECTION
+ ===============
+ -->
+ <target name="-deps-clean-init" unless="built-clean.properties">
+ <property location="${build.dir}/built-clean.properties" name="built-clean.properties"/>
+ <delete file="${built-clean.properties}" quiet="true"/>
+ </target>
+ <target if="already.built.clean.${basedir}" name="-warn-already-built-clean">
+ <echo level="warn" message="Cycle detected: TileZ was already built"/>
+ </target>
+ <target depends="init,-deps-clean-init" name="deps-clean" unless="no.deps">
+ <mkdir dir="${build.dir}"/>
+ <touch file="${built-clean.properties}" verbose="false"/>
+ <property file="${built-clean.properties}" prefix="already.built.clean."/>
+ <antcall target="-warn-already-built-clean"/>
+ <propertyfile file="${built-clean.properties}">
+ <entry key="${basedir}" value=""/>
+ </propertyfile>
+ <antcall target="-maybe-call-dep">
+ <param name="call.built.properties" value="${built-clean.properties}"/>
+ <param location="${project.DuskServer}" name="call.subproject"/>
+ <param location="${project.DuskServer}/build.xml" name="call.script"/>
+ <param name="call.target" value="clean"/>
+ <param name="transfer.built-clean.properties" value="${built-clean.properties}"/>
+ </antcall>
+ <antcall target="-maybe-call-dep">
+ <param name="call.built.properties" value="${built-clean.properties}"/>
+ <param location="${project.DuskZ}" name="call.subproject"/>
+ <param location="${project.DuskZ}/build.xml" name="call.script"/>
+ <param name="call.target" value="clean"/>
+ <param name="transfer.built-clean.properties" value="${built-clean.properties}"/>
+ </antcall>
+ </target>
+ <target depends="init" name="-do-clean">
+ <delete dir="${build.dir}"/>
+ <delete dir="${dist.dir}" followsymlinks="false" includeemptydirs="true"/>
+ </target>
+ <target name="-post-clean">
+ <!-- Empty placeholder for easier customization. -->
+ <!-- You can override this target in the ../build.xml file. -->
+ </target>
+ <target depends="init,deps-clean,-do-clean,-post-clean" description="Clean build products." name="clean"/>
+ <target name="-check-call-dep">
+ <property file="${call.built.properties}" prefix="already.built."/>
+ <condition property="should.call.dep">
+ <and>
+ <not>
+ <isset property="already.built.${call.subproject}"/>
+ </not>
+ <available file="${call.script}"/>
+ </and>
+ </condition>
+ </target>
+ <target depends="-check-call-dep" if="should.call.dep" name="-maybe-call-dep">
+ <ant antfile="${call.script}" inheritall="false" target="${call.target}">
+ <propertyset>
+ <propertyref prefix="transfer."/>
+ <mapper from="transfer.*" to="*" type="glob"/>
+ </propertyset>
+ </ant>
+ </target>
+</project>
--- /dev/null
+# Do not modify this property in this configuration. It can be re-generated.
+$label=Run as WebStart
--- /dev/null
+# Do not modify this property in this configuration. It can be re-generated.
+$label=Run in Browser
--- /dev/null
+build.xml.data.CRC32=79945bc4
+build.xml.script.CRC32=80e8c13b
+build.xml.stylesheet.CRC32=28e38971@1.56.1.46
+# This file is used by a NetBeans-based IDE to track changes in generated files such as build-impl.xml.
+# Do not edit this file. You may delete it but then the IDE will never regenerate such files for you.
+nbproject/build-impl.xml.data.CRC32=75566cc4
+nbproject/build-impl.xml.script.CRC32=fd7d9148
+nbproject/build-impl.xml.stylesheet.CRC32=c6d2a60f@1.56.1.46
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+*** GENERATED FROM TEMPLATE - DO NOT EDIT ***
+*** EDIT ../build.xml INSTEAD ***
+-->
+
+<project name="jfx-impl" default="jfx-deployment" basedir=".." xmlns:j2seproject1="http://www.netbeans.org/ns/j2se-project/1"
+ xmlns:j2seproject3="http://www.netbeans.org/ns/j2se-project/3" xmlns:fx="javafx:com.sun.javafx.tools.ant">
+ <description>JavaFX-specific Ant calls</description>
+
+
+ <!-- Empty placeholders for easier customization in ../build.xml -->
+
+ <target name="-pre-jfx-jar">
+ <!-- Called right before <fx:jar> task. You can override this target in the ../build.xml file. -->
+ </target>
+
+ <target name="-post-jfx-jar">
+ <!-- Called right after <fx:jar> task. You can override this target in the ../build.xml file. -->
+ </target>
+
+ <target name="-pre-jfx-deploy">
+ <!-- Called right before <fx:deploy> task. You can override this target in the ../build.xml file. -->
+ </target>
+
+ <target name="-post-jfx-deploy">
+ <!-- Called right after <fx:deploy> task. You can override this target in the ../build.xml file. -->
+ </target>
+
+ <target name="-pre-jfx-native">
+ <!-- Called right before the call to native packager (just after -pre-jfx-deploy). You can override this target in the ../build.xml file. -->
+ </target>
+
+ <target name="-post-jfx-native">
+ <!-- Called right after the call to native packager (just after -post-jfx-deploy). You can override this target in the ../build.xml file. -->
+ </target>
+
+
+ <!-- Check system and JDK version -->
+
+ <target name="-check-operating-system">
+ <condition property="running.on.mac">
+ <os family="mac"/>
+ </condition>
+ <condition property="running.on.unix">
+ <os family="unix"/>
+ </condition>
+ <condition property="running.on.windows">
+ <os family="windows"/>
+ </condition>
+ <echo message="running.on.mac = ${running.on.mac}" level="verbose"/>
+ <echo message="running.on.unix = ${running.on.unix}" level="verbose"/>
+ <echo message="running.on.windows = ${running.on.windows}" level="verbose"/>
+ </target>
+
+ <target name="-check-platform-home-fxsdk-java" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.platform.home.fxsdk.java">
+ <and>
+ <not><isset property="active.platform.home.java.executable"/></not>
+ <or>
+ <available file="${javafx.sdk}${file.separator}bin${file.separator}java"/>
+ <available file="${javafx.sdk}${file.separator}bin${file.separator}java.exe"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-platform-home-fxsdk-java" depends="-check-platform-home-fxsdk-java" if="do.set.platform.home.fxsdk.java">
+ <property name="active.platform.home.java.executable" value="${javafx.sdk}${file.separator}bin${file.separator}java"/>
+ </target>
+ <target name="-check-platform-home-java" if="platform.home">
+ <condition property="do.set.platform.home.java">
+ <and>
+ <not><isset property="active.platform.home.java.executable"/></not>
+ <or>
+ <available file="${platform.home}${file.separator}bin${file.separator}java"/>
+ <available file="${platform.home}${file.separator}bin${file.separator}java.exe"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-platform-home-java" depends="-set-platform-home-fxsdk-java,-check-platform-home-java" if="do.set.platform.home.java">
+ <property name="active.platform.home.java.executable" value="${platform.home}${file.separator}bin${file.separator}java"/>
+ </target>
+ <target name="-check-platform-home-probjdk-java" unless="active.platform.home.java.executable">
+ <condition property="do.set.platform.home.probjdk.java">
+ <and>
+ <not><isset property="active.platform.home.java.executable"/></not>
+ <or>
+ <available file="${java.home}${file.separator}..${file.separator}bin${file.separator}java"/>
+ <available file="${java.home}${file.separator}..${file.separator}bin${file.separator}java.exe"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-platform-home-probjdk-java" depends="-set-platform-home-java,-check-platform-home-probjdk-java" if="do.set.platform.home.probjdk.java">
+ <property name="active.platform.home.java.executable" value="${java.home}${file.separator}..${file.separator}bin${file.separator}java"/>
+ </target>
+ <target name="-check-platform-home-envjdk-java" unless="active.platform.home.java.executable">
+ <property environment="env"/>
+ <condition property="do.set.platform.home.envjdk.java">
+ <and>
+ <not><isset property="active.platform.home.java.executable"/></not>
+ <or>
+ <available file="${env.JAVA_HOME}${file.separator}bin${file.separator}java"/>
+ <available file="${env.JAVA_HOME}${file.separator}bin${file.separator}java.exe"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-platform-home-envjdk-java" depends="-set-platform-home-probjdk-java,-check-platform-home-envjdk-java" if="do.set.platform.home.envjdk.java">
+ <property environment="env"/>
+ <property name="active.platform.home.java.executable" value="${env.JAVA_HOME}${file.separator}bin${file.separator}java"/>
+ </target>
+ <target name="-check-platform-home-fxrt-java" depends="-check-property-javafx.runtime" if="javafx.runtime.defined">
+ <condition property="do.set.platform.home.fxrt.java">
+ <and>
+ <not><isset property="active.platform.home.java.executable"/></not>
+ <or>
+ <available file="${javafx.runtime}${file.separator}bin${file.separator}java"/>
+ <available file="${javafx.runtime}${file.separator}bin${file.separator}java.exe"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-platform-home-fxrt-java" depends="-set-platform-home-envjdk-java,-check-platform-home-fxrt-java" if="do.set.platform.home.fxrt.java">
+ <property name="active.platform.home.java.executable" value="${javafx.runtime}${file.separator}bin${file.separator}java"/>
+ <echo message="Warning: java executable not found in JDK, evaluating java executable in RT instead." level="info"/>
+ </target>
+ <target name="-check-platform-home-jre-java" unless="active.platform.home.java.executable">
+ <condition property="do.set.platform.home.jre.java">
+ <and>
+ <not><isset property="active.platform.home.java.executable"/></not>
+ <or>
+ <available file="${java.home}${file.separator}bin${file.separator}java"/>
+ <available file="${java.home}${file.separator}bin${file.separator}java.exe"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-platform-home-jre-java" depends="-set-platform-home-fxrt-java,-check-platform-home-jre-java" if="do.set.platform.home.jre.java">
+ <property name="active.platform.home.java.executable" value="${java.home}${file.separator}bin${file.separator}java"/>
+ <echo message="Warning: java executable not found in JDK, evaluating java executable in RT instead." level="info"/>
+ </target>
+ <target name="-check-platform-home" depends="-set-platform-home-jre-java">
+ <echo message="active.platform.home.java.executable = ${active.platform.home.java.executable}" level="verbose"/>
+ <fail message="Error:${line.separator}java executable not found !" unless="active.platform.home.java.executable"/>
+ </target>
+
+ <target name="-check-jdk-version" depends="-do-init,-check-platform-home" unless="jdk-version-checked-in-jfximpl">
+ <local name="version-output"/>
+ <exec executable="${active.platform.home.java.executable}" outputproperty="version-output">
+ <arg value="-version"/>
+ </exec>
+ <echo message="version-output:${line.separator}${version-output}" level="verbose"/>
+ <condition property="have-jdk-older-than-1.6">
+ <or>
+ <contains string="${version-output}" substring="java version "1.0"/>
+ <contains string="${version-output}" substring="java version "1.1"/>
+ <contains string="${version-output}" substring="java version "1.2"/>
+ <contains string="${version-output}" substring="java version "1.3"/>
+ <contains string="${version-output}" substring="java version "1.4"/>
+ <contains string="${version-output}" substring="java version "1.5"/>
+ </or>
+ </condition>
+ <fail message="Error:${line.separator}JavaFX 2.0+ projects require JDK version 1.6+ !" if="have-jdk-older-than-1.6"/>
+ <condition property="have-jdk-7u4or5-mac">
+ <and>
+ <or>
+ <contains string="${version-output}" substring="java version "1.7.0_04"/>
+ <contains string="${version-output}" substring="java version "1.7.0_05"/>
+ </or>
+ <os family="mac"/>
+ </and>
+ </condition>
+ <condition property="have-jdk-pre7u6">
+ <or>
+ <isset property="have-jdk-older-than-1.6"/>
+ <contains string="${version-output}" substring="java version "1.6"/>
+ <contains string="${version-output}" substring="java version "1.7.0""/>
+ <contains string="${version-output}" substring="java version "1.7.0_01"/>
+ <contains string="${version-output}" substring="java version "1.7.0_02"/>
+ <contains string="${version-output}" substring="java version "1.7.0_03"/>
+ <contains string="${version-output}" substring="java version "1.7.0_04"/>
+ <contains string="${version-output}" substring="java version "1.7.0_05"/>
+ </or>
+ </condition>
+ <condition property="have-jdk7-css2bin-bug">
+ <or>
+ <contains string="${version-output}" substring="java version "1.7.0_04"/>
+ <contains string="${version-output}" substring="java version "1.7.0_05"/>
+ <contains string="${version-output}" substring="java version "1.7.0_06"/>
+ <contains string="${version-output}" substring="java version "1.7.0_07"/>
+ <contains string="${version-output}" substring="java version "1.7.0_08"/>
+ <contains string="${version-output}" substring="java version "1.7.0_09"/>
+ <contains string="${version-output}" substring="java version "1.7.0_10"/>
+ <contains string="${version-output}" substring="java version "1.7.0_11"/>
+ </or>
+ </condition>
+ <property name="jdk-version-checked-in-jfximpl" value="true"/>
+ <echo message="have-jdk-7u4or5-mac = ${have-jdk-7u4or5-mac}" level="verbose"/>
+ <echo message="have-jdk-pre7u6 = ${have-jdk-pre7u6}" level="verbose"/>
+ <echo message="have-jdk7-css2bin-bug = ${have-jdk7-css2bin-bug}" level="verbose"/>
+ </target>
+
+ <target name="-check-ant-jre-version" unless="ant-jre-version-checked-in-jfximpl">
+ <local name="version-output"/>
+ <exec executable="${java.home}${file.separator}bin${file.separator}java" outputproperty="version-output">
+ <arg value="-version"/>
+ </exec>
+ <echo message="version-output:${line.separator}${version-output}" level="verbose"/>
+ <condition property="have-ant-jre-pre7u6">
+ <or>
+ <contains string="${version-output}" substring="java version "1.0"/>
+ <contains string="${version-output}" substring="java version "1.1"/>
+ <contains string="${version-output}" substring="java version "1.2"/>
+ <contains string="${version-output}" substring="java version "1.3"/>
+ <contains string="${version-output}" substring="java version "1.4"/>
+ <contains string="${version-output}" substring="java version "1.5"/>
+ <contains string="${version-output}" substring="java version "1.6"/>
+ <contains string="${version-output}" substring="java version "1.7.0""/>
+ <contains string="${version-output}" substring="java version "1.7.0_01"/>
+ <contains string="${version-output}" substring="java version "1.7.0_02"/>
+ <contains string="${version-output}" substring="java version "1.7.0_03"/>
+ <contains string="${version-output}" substring="java version "1.7.0_04"/>
+ <contains string="${version-output}" substring="java version "1.7.0_05"/>
+ </or>
+ </condition>
+ <property name="ant-jre-version-checked-in-jfximpl" value="true"/>
+ <echo message="have-ant-jre-pre7u6 = ${have-ant-jre-pre7u6}" level="verbose"/>
+ </target>
+
+ <target name="-check-jdk-7u4or5-mac" depends="-check-jdk-version" if="have-jdk-7u4or5-mac">
+ <fail message="Error:${line.separator}JDK 7u4 Mac and 7u5 Mac do not support WebStart and JavaFX 2.0+ browser plugin technologies.${line.separator}Please upgrade to JDK 7u6 or later."/>
+ </target>
+
+
+ <!-- Check availability of JavaFX SDK deployment support (ant-javafx.jar) -->
+
+ <target name="-check-endorsed-javafx-ant-classpath">
+ <condition property="endorsed-javafx-ant-classpath-available">
+ <and>
+ <isset property="endorsed.javafx.ant.classpath"/>
+ <not>
+ <equals arg1="${endorsed.javafx.ant.classpath}" arg2=""/>
+ </not>
+ </and>
+ </condition>
+ <echo message="endorsed-javafx-ant-classpath-available = ${endorsed-javafx-ant-classpath-available}" level="verbose"/>
+ </target>
+
+ <target name="-check-property-javafx.sdk">
+ <echo message="javafx.sdk = ${javafx.sdk}" level="verbose"/>
+ <condition property="javafx.sdk.defined">
+ <and>
+ <isset property="javafx.sdk"/>
+ <not><contains string="${javafx.sdk}" substring="$${platform" casesensitive="false"/></not>
+ </and>
+ </condition>
+ <condition property="javafx.sdk.missing+default">
+ <and>
+ <equals arg1="${platform.active}" arg2="Default_JavaFX_Platform" trim="true"/>
+ <not><isset property="javafx.sdk.defined"/></not>
+ </and>
+ </condition>
+ <condition property="javafx.sdk.missing-default">
+ <and>
+ <not><equals arg1="${platform.active}" arg2="Default_JavaFX_Platform" trim="true"/></not>
+ <not><isset property="javafx.sdk.defined"/></not>
+ </and>
+ </condition>
+ <echo message="javafx.sdk.defined = ${javafx.sdk.defined}" level="verbose"/>
+ <echo message="javafx.sdk.missing+default = ${javafx.sdk.missing+default}" level="verbose"/>
+ <echo message="javafx.sdk.missing-default = ${javafx.sdk.missing-default}" level="verbose"/>
+ </target>
+
+ <target name="-check-ant-javafx-in-fxsdk-lib" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.ant-javafx.in.fxsdk.lib">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${javafx.sdk}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-fxsdk-lib" depends="-check-ant-javafx-in-fxsdk-lib" if="do.set.ant-javafx.in.fxsdk.lib">
+ <property name="ant-javafx.jar.location" value="${javafx.sdk}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-fxsdk-tools" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.ant-javafx.in.fxsdk.tools">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${javafx.sdk}${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-fxsdk-tools" depends="-set-ant-javafx-in-fxsdk-lib,-check-ant-javafx-in-fxsdk-tools" if="do.set.ant-javafx.in.fxsdk.tools">
+ <property name="ant-javafx.jar.location" value="${javafx.sdk}${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-platform-home-lib" if="platform.home">
+ <condition property="do.set.ant-javafx.in.platform.home.lib">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${platform.home}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-platform-home-lib" depends="-set-ant-javafx-in-fxsdk-tools,-check-ant-javafx-in-platform-home-lib" if="do.set.ant-javafx.in.platform.home.lib">
+ <property name="ant-javafx.jar.location" value="${platform.home}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-platform-home-tools" if="platform.home">
+ <condition property="do.set.ant-javafx.in.platform.home.tools">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${platform.home}${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-platform-home-tools" depends="-set-ant-javafx-in-platform-home-lib,-check-ant-javafx-in-platform-home-tools" if="do.set.ant-javafx.in.platform.home.tools">
+ <property name="ant-javafx.jar.location" value="${platform.home}${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-probjdk-lib" unless="ant-javafx.jar.location">
+ <condition property="do.set.ant-javafx.in.probjdk.lib">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${java.home}${file.separator}..${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-probjdk-lib" depends="-set-ant-javafx-in-platform-home-tools,-check-ant-javafx-in-probjdk-lib" if="do.set.ant-javafx.in.probjdk.lib">
+ <property name="ant-javafx.jar.location" value="${java.home}${file.separator}..${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-probjdk-tools" unless="ant-javafx.jar.location">
+ <condition property="do.set.ant-javafx.in.probjdk.tools">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${java.home}${file.separator}..${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-probjdk-tools" depends="-set-ant-javafx-in-probjdk-lib,-check-ant-javafx-in-probjdk-tools" if="do.set.ant-javafx.in.probjdk.tools">
+ <property name="ant-javafx.jar.location" value="${java.home}${file.separator}..${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-macjdk-lib" unless="ant-javafx.jar.location">
+ <condition property="do.set.ant-javafx.in.macjdk.lib">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${java.home}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-macjdk-lib" depends="-set-ant-javafx-in-probjdk-tools,-check-ant-javafx-in-macjdk-lib" if="do.set.ant-javafx.in.macjdk.lib">
+ <property name="ant-javafx.jar.location" value="${java.home}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-envjdk-lib" unless="ant-javafx.jar.location">
+ <property environment="env"/>
+ <condition property="do.set.ant-javafx.in.envjdk.lib">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${env.JAVA_HOME}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-envjdk-lib" depends="-set-ant-javafx-in-macjdk-lib,-check-ant-javafx-in-envjdk-lib" if="do.set.ant-javafx.in.envjdk.lib">
+ <property name="ant-javafx.jar.location" value="${env.JAVA_HOME}${file.separator}lib${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-check-ant-javafx-in-envjdk-tools" unless="ant-javafx.jar.location">
+ <property environment="env"/>
+ <condition property="do.set.ant-javafx.in.envjdk.tools">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${env.JAVA_HOME}${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-ant-javafx-in-envjdk-tools" depends="-set-ant-javafx-in-envjdk-lib,-check-ant-javafx-in-envjdk-tools" if="do.set.ant-javafx.in.envjdk.tools">
+ <property name="ant-javafx.jar.location" value="${env.JAVA_HOME}${file.separator}tools${file.separator}ant-javafx.jar"/>
+ </target>
+ <target name="-pre-check-ant-javafx-version" depends="-set-ant-javafx-in-envjdk-tools" unless="ant-javafx-version-already-checked-in-jfximpl">
+ <condition property="do.check.ant-javafx.version">
+ <and>
+ <isset property="ant-javafx.jar.location"/>
+ <not><isset property="ant-javafx-version-already-checked-in-jfximpl"/></not>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-endorsed-javafx-ant-classpath" depends="-check-endorsed-javafx-ant-classpath,-pre-check-ant-javafx-version" if="endorsed-javafx-ant-classpath-available">
+ <property name="javafx.ant.classpath" value="${endorsed.javafx.ant.classpath}:${ant-javafx.jar.location}"/>
+ </target>
+ <target name="-set-javafx-ant-classpath" depends="-check-endorsed-javafx-ant-classpath,-pre-check-ant-javafx-version" unless="endorsed-javafx-ant-classpath-available">
+ <property name="javafx.ant.classpath" value="${ant-javafx.jar.location}"/>
+ </target>
+ <target name="-check-ant-javafx-version" depends="-pre-check-ant-javafx-version,
+ -set-endorsed-javafx-ant-classpath,-set-javafx-ant-classpath" if="do.check.ant-javafx.version">
+ <echo message="ant-javafx.jar.location = ${ant-javafx.jar.location}" level="verbose"/>
+ <echo message="javafx.ant.classpath = ${javafx.ant.classpath}" level="verbose"/>
+ <taskdef resource="com/sun/javafx/tools/ant/antlib.xml"
+ uri="javafx:com.sun.javafx.tools.ant"
+ classpath="${javafx.ant.classpath}"/>
+ <condition property="have-fx-ant-init">
+ <typefound name="javafx:com.sun.javafx.tools.ant:init-ant"/>
+ </condition>
+ <property name="ant-javafx-version-already-checked-in-jfximpl" value="true"/>
+ <echo message="have-fx-ant-init = ${have-fx-ant-init}" level="verbose"/>
+ </target>
+ <target name="-check-jfx-sdk-version-old" depends="-check-ant-javafx-version" unless="have-fx-ant-init">
+ <property name="javafx.ant.version" value="1.0"/>
+ </target>
+ <target name="-check-jfx-sdk-version-new" depends="-check-ant-javafx-version" if="have-fx-ant-init">
+ <fx:init-ant/>
+ <condition property="have-fx-ant-api-1.1">
+ <!-- new features from JavaFX 2.0.2 are available in API version 1.1 or later -->
+ <matches pattern="1.[1-9]" string="${javafx.ant.version}"/>
+ </condition>
+ <condition property="have-fx-ant-api-1.2">
+ <!-- new features from JavaFX 2.2 are available in API version 1.2 or later -->
+ <matches pattern="1.[2-9]" string="${javafx.ant.version}"/>
+ </condition>
+ </target>
+ <target name="-check-jfx-sdk-version" depends="-check-jfx-sdk-version-old, -check-jfx-sdk-version-new" unless="jfx.sdk.version.checked">
+ <echo message="Detected JavaFX Ant API version ${javafx.ant.version}" level="info"/>
+ <echo message="have-fx-ant-api-1.1 = ${have-fx-ant-api-1.1}" level="verbose"/>
+ <echo message="have-fx-ant-api-1.2 = ${have-fx-ant-api-1.2}" level="verbose"/>
+ <echo message="javafx.ant.classpath = ${javafx.ant.classpath}" level="verbose"/>
+ <property name="jfx.sdk.version.checked" value="true"/>
+ </target>
+
+ <target name="-check-jfx-deployment" depends="-check-jdk-version,-check-jfx-sdk-version">
+ <condition property="jfx-deployment-available">
+ <and>
+ <or>
+ <isset property="do.set.ant-javafx.in.fxsdk.lib"/>
+ <isset property="do.set.ant-javafx.in.fxsdk.tools"/>
+ <isset property="do.set.ant-javafx.in.platform.home.lib"/>
+ <isset property="do.set.ant-javafx.in.platform.home.tools"/>
+ <isset property="do.set.ant-javafx.in.probjdk.lib"/>
+ <isset property="do.set.ant-javafx.in.probjdk.tools"/>
+ <isset property="do.set.ant-javafx.in.envjdk.lib"/>
+ <isset property="do.set.ant-javafx.in.envjdk.tools"/>
+ </or>
+ <isset property="ant-javafx.jar.location"/>
+ </and>
+ </condition>
+ <condition property="jfx-deployment-missing+jdk7u6">
+ <and>
+ <not><isset property="jfx-deployment-available"/></not>
+ <not><isset property="have-jdk-pre7u6"/></not>
+ </and>
+ </condition>
+ <condition property="jfx-deployment-missing+javafx.sdk.missing+default">
+ <and>
+ <not><isset property="jfx-deployment-available"/></not>
+ <isset property="have-jdk-pre7u6"/>
+ <isset property="javafx.sdk.missing+default"/>
+ </and>
+ </condition>
+ <condition property="jfx-deployment-missing+javafx.sdk.missing-default">
+ <and>
+ <not><isset property="jfx-deployment-available"/></not>
+ <isset property="have-jdk-pre7u6"/>
+ <isset property="javafx.sdk.missing-default"/>
+ </and>
+ </condition>
+ <fail message="Error:${line.separator}JavaFX deployment library not found in active JDK.${line.separator}Please check that the JDK is correctly installed and its version is at least 7u4 on Mac or 7u6 on other systems." if="jfx-deployment-missing+jdk7u6"/>
+ <fail message="Error:${line.separator}JavaFX deployment library not found.${line.separator}JavaFX SDK path undefined. Check the definition of ${platform.active} in Java Platform Manager${line.separator}(or directly the properties platform.active and javafx.sdk in project.properties file).${line.separator}Note: If missing, the default JavaFX-enabled platform gets created automatically when creating a new JavaFX Project." if="jfx-deployment-missing+javafx.sdk.missing+default"/>
+ <fail message="Error:${line.separator}JavaFX deployment library not found.${line.separator}JavaFX SDK path undefined. Check the definition of ${platform.active} in Java Platform Manager${line.separator}(or directly the properties platform.active and javafx.sdk in project.properties file)." if="jfx-deployment-missing+javafx.sdk.missing-default"/>
+ <fail message="Error:${line.separator}JavaFX deployment library not found." unless="jfx-deployment-available"/>
+ <echo message="jfx-deployment-available = ${jfx-deployment-available}" level="verbose"/>
+ </target>
+
+
+ <!-- Check availability of main JavaFX runtime jar (jfxrt.jar) -->
+
+ <target name="-check-property-javafx.runtime">
+ <echo message="javafx.runtime = ${javafx.runtime}" level="verbose"/>
+ <condition property="javafx.runtime.defined">
+ <and>
+ <isset property="javafx.runtime"/>
+ <not><contains string="${javafx.runtime}" substring="$${platform" casesensitive="false"/></not>
+ </and>
+ </condition>
+ <condition property="javafx.runtime.missing+default">
+ <and>
+ <equals arg1="${platform.active}" arg2="Default_JavaFX_Platform" trim="true"/>
+ <not><isset property="javafx.runtime.defined"/></not>
+ </and>
+ </condition>
+ <condition property="javafx.runtime.missing-default">
+ <and>
+ <not><equals arg1="${platform.active}" arg2="Default_JavaFX_Platform" trim="true"/></not>
+ <not><isset property="javafx.runtime.defined"/></not>
+ </and>
+ </condition>
+ <echo message="javafx.runtime.defined = ${javafx.runtime.defined}" level="verbose"/>
+ <echo message="javafx.runtime.missing+default = ${javafx.runtime.missing+default}" level="verbose"/>
+ <echo message="javafx.runtime.missing-default = ${javafx.runtime.missing-default}" level="verbose"/>
+ </target>
+
+ <target name="-check-jfxrt-in-fxrt" depends="-check-property-javafx.runtime" if="javafx.runtime.defined">
+ <condition property="do.set.jfxrt.in.fxrt">
+ <and>
+ <not><isset property="jfxrt.jar.location"/></not>
+ <available file="${javafx.runtime}${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-fxrt" depends="-check-jfxrt-in-fxrt" if="do.set.jfxrt.in.fxrt">
+ <property name="jfxrt.jar.location" value="${javafx.runtime}${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-check-jfxrt-in-fxsdk-jre" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.jfxrt.in.fxsdk.jre">
+ <and>
+ <not><isset property="jfxrt.jar.location"/></not>
+ <available file="${javafx.sdk}${file.separator}jre${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-fxsdk-jre" depends="-set-jfxrt-in-fxrt,-check-jfxrt-in-fxsdk-jre" if="do.set.jfxrt.in.fxsdk.jre">
+ <property name="jfxrt.jar.location" value="${javafx.sdk}${file.separator}jre${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-check-jfxrt-in-fxsdk-rt" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.jfxrt.in.fxsdk.rt">
+ <and>
+ <not><isset property="jfxrt.jar.location"/></not>
+ <available file="${javafx.sdk}${file.separator}rt${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-fxsdk-rt" depends="-set-jfxrt-in-fxsdk-jre,-check-jfxrt-in-fxsdk-rt" if="do.set.jfxrt.in.fxsdk.rt">
+ <property name="jfxrt.jar.location" value="${javafx.sdk}${file.separator}rt${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-check-jfxrt-in-platform-home-jre" if="platform.home">
+ <condition property="do.set.jfxrt.in.platform.home.jre">
+ <and>
+ <not><isset property="jfxrt.jar.location"/></not>
+ <available file="${platform.home}${file.separator}jre${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-platform-home-jre" depends="-set-jfxrt-in-fxsdk-rt,-check-jfxrt-in-platform-home-jre" if="do.set.jfxrt.in.platform.home.jre">
+ <property name="jfxrt.jar.location" value="${platform.home}${file.separator}jre${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-check-jfxrt-in-platform-home-rt" if="platform.home">
+ <condition property="do.set.jfxrt.in.platform.home.rt">
+ <and>
+ <not><isset property="jfxrt.jar.location"/></not>
+ <available file="${platform.home}${file.separator}rt${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-platform-home-rt" depends="-set-jfxrt-in-platform-home-jre,-check-jfxrt-in-platform-home-rt" if="do.set.jfxrt.in.platform.home.rt">
+ <property name="jfxrt.jar.location" value="${platform.home}${file.separator}rt${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-check-jfxrt-in-jre" unless="jfxrt.jar.location">
+ <condition property="do.set.jfxrt.in.jre">
+ <and>
+ <not><isset property="jfxrt.jar.location"/></not>
+ <available file="${java.home}${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-jre" depends="-set-jfxrt-in-platform-home-rt,-check-jfxrt-in-jre" if="do.set.jfxrt.in.jre">
+ <property name="jfxrt.jar.location" value="${java.home}${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-check-jfxrt-in-envjdk-jre" unless="jfxrt.jar.location">
+ <property environment="env"/>
+ <condition property="do.set.jfxrt.in.envjdk.jre">
+ <and>
+ <not><isset property="ant-javafx.jar.location"/></not>
+ <available file="${env.JAVA_HOME}${file.separator}jre${file.separator}lib${file.separator}jfxrt.jar"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-jfxrt-in-envjdk-jre" depends="-set-jfxrt-in-jre,-check-jfxrt-in-envjdk-jre" if="do.set.jfxrt.in.envjdk.jre">
+ <property name="jfxrt.jar.location" value="${env.JAVA_HOME}${file.separator}jre${file.separator}lib${file.separator}jfxrt.jar"/>
+ </target>
+ <target name="-pre-check-jfx-runtime" depends="-set-jfxrt-in-envjdk-jre">
+ <echo message="jfxrt.jar.location = ${jfxrt.jar.location}" level="verbose"/>
+ </target>
+
+ <target name="-check-jfx-runtime" depends="-check-jdk-version, -pre-check-jfx-runtime">
+ <condition property="jfx-runtime-available">
+ <and>
+ <or>
+ <isset property="do.set.jfxrt.in.fxrt"/>
+ <isset property="do.set.jfxrt.in.fxsdk.jre"/>
+ <isset property="do.set.jfxrt.in.fxsdk.rt"/>
+ <isset property="do.set.jfxrt.in.platform.home.jre"/>
+ <isset property="do.set.jfxrt.in.platform.home.rt"/>
+ <isset property="do.set.jfxrt.in.jre"/>
+ <isset property="do.set.jfxrt.in.envjdk.jre"/>
+ </or>
+ <isset property="jfxrt.jar.location"/>
+ </and>
+ </condition>
+ <fail message="Error:${line.separator}JavaFX runtime JAR not found." unless="jfx-runtime-available"/>
+ <echo message="jfx-runtime-available = ${jfx-runtime-available}" level="verbose"/>
+ </target>
+
+
+ <!-- Check availability of WebStart executable -->
+
+ <target name="-check-webstart-in-fxrt" depends="-check-property-javafx.runtime" if="javafx.runtime.defined">
+ <condition property="do.set.webstart.in.fxrt">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <isset property="javafx.runtime.defined"/>
+ <or>
+ <available file="${javafx.runtime}${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${javafx.runtime}${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-fxrt" depends="-check-webstart-in-fxrt" if="do.set.webstart.in.fxrt">
+ <property name="active.webstart.executable" value="${javafx.runtime}${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-fxsdk-jre" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.webstart.in.fxsdk.jre">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <isset property="javafx.sdk.defined"/>
+ <or>
+ <available file="${javafx.sdk}${file.separator}jre${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${javafx.sdk}${file.separator}jre${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-fxsdk-jre" depends="-set-webstart-in-fxrt,-check-webstart-in-fxsdk-jre" if="do.set.webstart.in.fxsdk.jre">
+ <property name="active.webstart.executable" value="${javafx.sdk}${file.separator}jre${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-fxsdk" depends="-check-property-javafx.sdk" if="javafx.sdk.defined">
+ <condition property="do.set.webstart.in.fxsdk">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <isset property="javafx.sdk.defined"/>
+ <or>
+ <available file="${javafx.sdk}${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${javafx.sdk}${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-fxsdk" depends="-set-webstart-in-fxsdk-jre,-check-webstart-in-fxsdk" if="do.set.webstart.in.fxsdk">
+ <property name="active.webstart.executable" value="${javafx.sdk}${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-platform-home-jre" if="platform.home">
+ <condition property="do.set.webstart.in.platform.home.jre">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <or>
+ <available file="${platform.home}${file.separator}jre${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${platform.home}${file.separator}jre${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-platform-home-jre" depends="-set-webstart-in-fxsdk,-check-webstart-in-platform-home-jre" if="do.set.webstart.in.platform.home.jre">
+ <property name="active.webstart.executable" value="${platform.home}${file.separator}jre${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-platform-home" if="platform.home">
+ <condition property="do.set.webstart.in.platform.home">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <or>
+ <available file="${platform.home}${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${platform.home}${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-platform-home" depends="-set-webstart-in-platform-home-jre,-check-webstart-in-platform-home" if="do.set.webstart.in.platform.home">
+ <property name="active.webstart.executable" value="${platform.home}${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-jre" unless="active.webstart.executable">
+ <condition property="do.set.webstart.in.jre">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <or>
+ <available file="${java.home}${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${java.home}${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-jre" depends="-set-webstart-in-platform-home,-check-webstart-in-jre" if="do.set.webstart.in.jre">
+ <property name="active.webstart.executable" value="${java.home}${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-probjdk" unless="active.webstart.executable">
+ <condition property="do.set.webstart.in.probjdk">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <or>
+ <available file="${java.home}${file.separator}..${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${java.home}${file.separator}..${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-probjdk" depends="-set-webstart-in-jre,-check-webstart-in-probjdk" if="do.set.webstart.in.probjdk">
+ <property name="active.webstart.executable" value="${java.home}${file.separator}..${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-check-webstart-in-envjdk" unless="active.webstart.executable">
+ <property environment="env"/>
+ <condition property="do.set.webstart.in.envjdk">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <or>
+ <available file="${env.JAVA_HOME}${file.separator}bin${file.separator}javaws.exe"/>
+ <available file="${env.JAVA_HOME}${file.separator}bin${file.separator}javaws"/>
+ </or>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-webstart-in-envjdk" depends="-set-webstart-in-probjdk,-check-webstart-in-envjdk" if="do.set.webstart.in.envjdk">
+ <property name="active.webstart.executable" value="${env.JAVA_HOME}${file.separator}bin${file.separator}javaws"/>
+ </target>
+ <target name="-pre-check-webstart-in-unix" depends="-check-operating-system,-set-webstart-in-envjdk" unless="active.webstart.executable">
+ <condition property="running.on.unix-active.webstart.executable">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <isset property="running.on.unix"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-check-webstart-in-unix" depends="-pre-check-webstart-in-unix" if="running.on.unix-active.webstart.executable">
+ <local name="exec.which.javaws.result"/>
+ <exec executable="which" failifexecutionfails="false" failonerror="false" resultproperty="exec.which.javaws.result" outputproperty="exec.which.javaws.output">
+ <arg value="javaws"/>
+ </exec>
+ <condition property="do.set.webstart.in.unix">
+ <and>
+ <not><isset property="active.webstart.executable"/></not>
+ <isset property="exec.which.javaws.result"/>
+ <equals arg1="${exec.which.javaws.result}" arg2="0"/>
+ <isset property="exec.which.javaws.output"/>
+ <not><equals arg1="${exec.which.javaws.output}" arg2=""/></not>
+ </and>
+ </condition>
+ <echo message="do.set.webstart.in.unix = ${do.set.webstart.in.unix}" level="verbose"/>
+ </target>
+ <target name="-set-webstart-in-unix" depends="-set-webstart-in-envjdk,-check-webstart-in-unix" if="do.set.webstart.in.unix">
+ <property name="active.webstart.executable" value="${exec.which.javaws.output}"/>
+ </target>
+ <target name="-pre-check-jfx-webstart" depends="-set-webstart-in-unix">
+ <echo message="active.webstart.executable = ${active.webstart.executable}" level="verbose"/>
+ </target>
+
+ <target name="-check-jfx-webstart" depends="-pre-check-jfx-webstart">
+ <condition property="jfx-webstart-available">
+ <and>
+ <or>
+ <isset property="do.set.webstart.in.fxrt"/>
+ <isset property="do.set.webstart.in.fxsdk.jre"/>
+ <isset property="do.set.webstart.in.fxsdk"/>
+ <isset property="do.set.webstart.in.platform.home.jre"/>
+ <isset property="do.set.webstart.in.platform.home"/>
+ <isset property="do.set.webstart.in.jre"/>
+ <isset property="do.set.webstart.in.probjdk"/>
+ <isset property="do.set.webstart.in.envjdk"/>
+ <isset property="do.set.webstart.in.unix"/>
+ </or>
+ <isset property="active.webstart.executable"/>
+ </and>
+ </condition>
+ <condition property="jfx-webstart-missing+jdk7u6">
+ <and>
+ <not><isset property="jfx-webstart-available"/></not>
+ <not><isset property="have-jdk-pre7u6"/></not>
+ </and>
+ </condition>
+ <condition property="jfx-webstart-missing+javafx.runtime.missing+default">
+ <and>
+ <not><isset property="jfx-webstart-available"/></not>
+ <isset property="have-jdk-pre7u6"/>
+ <isset property="javafx.runtime.missing+default"/>
+ </and>
+ </condition>
+ <condition property="jfx-webstart-missing+javafx.runtime.missing-default">
+ <and>
+ <not><isset property="jfx-webstart-available"/></not>
+ <isset property="have-jdk-pre7u6"/>
+ <isset property="javafx.runtime.missing-default"/>
+ </and>
+ </condition>
+ <fail message="Error:${line.separator}WebStart executable could not be found in active JDK.${line.separator}Please check that the JDK is correctly installed and its version is at least 7u6." if="jfx-webstart-missing+jdk7u6"/>
+ <fail message="Error:${line.separator}WebStart executable could not be found.${line.separator}JavaFX RT path undefined. Check the definition of ${platform.active} in Java Platform Manager${line.separator}(or directly the properties platform.active and javafx.runtime in project.properties file).${line.separator}Note: If missing, the default JavaFX-enabled platform gets created automatically when creating a new JavaFX Project." if="jfx-webstart-missing+javafx.runtime.missing+default"/>
+ <fail message="Error:${line.separator}WebStart executable could not be found.${line.separator}JavaFX RT path undefined. Check the definition of ${platform.active} in Java Platform Manager${line.separator}(or directly the properties platform.active and javafx.runtime in project.properties file)." if="jfx-webstart-missing+javafx.runtime.missing-default"/>
+ <fail message="Error:${line.separator}WebStart executable could not be found." unless="jfx-webstart-available"/>
+ <echo message="jfx-webstart-available = ${jfx-webstart-available}" level="verbose"/>
+ </target>
+
+
+ <!-- Legacy targets kept for compatibility with older build-impl.xml scripts -->
+
+ <!-- Note: target "-check-javafx" is not necessary any more but is referenced from NB 7.1 build-impl.xml -->
+ <target name="-check-javafx"/>
+ <!-- Note: target "-javafx-check-error" is not necessary any more but is referenced from NB 7.1 build-impl.xml -->
+ <target name="-javafx-check-error"/>
+ <!-- Note: target "-init-javafx" is not necessary any more but is referenced from NB 7.1 build-impl.xml -->
+ <target name="-init-javafx"/>
+
+
+ <!-- Check project properties -->
+
+ <target name="-check-default-run-config" unless="config">
+ <property name="config" value="<default config>"/>
+ </target>
+
+ <target name="-check-project">
+ <condition property="main-class-available">
+ <isset property="javafx.main.class"/>
+ </condition>
+ <condition property="vmargs-available">
+ <and>
+ <isset property="run.jvmargs"/>
+ <not><equals arg1="${run.jvmargs}" arg2=""/></not>
+ </and>
+ </condition>
+ <condition property="preloader-available">
+ <and>
+ <isset property="javafx.preloader.enabled"/>
+ <equals arg1="${javafx.preloader.enabled}" arg2="true"/>
+ <isset property="javafx.preloader.class"/>
+ <not><equals arg1="${javafx.preloader.class}" arg2=""/></not>
+ <isset property="javafx.preloader.jar.filename"/>
+ <not><equals arg1="${javafx.preloader.jar.filename}" arg2=""/></not>
+ </and>
+ </condition>
+ <condition property="app-with-preloader">
+ <and>
+ <istrue value="${preloader-available}"/>
+ <istrue value="${main-class-available}"/>
+ </and>
+ </condition>
+ <condition property="app-with-external-preloader-jar">
+ <and>
+ <isset property="app-with-preloader"/>
+ <isset property="javafx.preloader.type"/>
+ <equals arg1="${javafx.preloader.type}" arg2="jar" trim="true"/>
+ </and>
+ </condition>
+ <condition property="app-without-preloader">
+ <and>
+ <not>
+ <istrue value="${preloader-available}"/>
+ </not>
+ <istrue value="${main-class-available}"/>
+ </and>
+ </condition>
+ <condition property="preloader-app">
+ <and>
+ <isset property="javafx.preloader"/>
+ <equals arg1="${javafx.preloader}" arg2="true"/>
+ </and>
+ </condition>
+ <condition property="fx-in-swing-app">
+ <and>
+ <isset property="javafx.swing"/>
+ <equals arg1="${javafx.swing}" arg2="true"/>
+ </and>
+ </condition>
+ <condition property="fx-in-swing-workaround-app">
+ <and>
+ <istrue value="${fx-in-swing-app}"/>
+ <istrue value="${preloader-app}"/>
+ </and>
+ </condition>
+ <condition property="preloader-app-no-workaround">
+ <and>
+ <istrue value="${preloader-app}"/>
+ <not><istrue value="${fx-in-swing-app}"/></not>
+ </and>
+ </condition>
+ <condition property="html-template-available">
+ <and>
+ <isset property="javafx.run.htmltemplate"/>
+ <not>
+ <equals arg1="${javafx.run.htmltemplate}" arg2=""/>
+ </not>
+ </and>
+ </condition>
+ <condition property="icon-available">
+ <and>
+ <isset property="javafx.deploy.icon"/>
+ <not>
+ <equals arg1="${javafx.deploy.icon}" arg2=""/>
+ </not>
+ </and>
+ </condition>
+ <condition property="dimensions-available">
+ <and>
+ <isset property="javafx.run.width"/>
+ <isset property="javafx.run.height"/>
+ <not><equals arg1="${javafx.run.width}" arg2=""/></not>
+ <not><equals arg1="${javafx.run.height}" arg2=""/></not>
+ </and>
+ </condition>
+ <condition property="update-mode-background">
+ <and>
+ <isset property="javafx.deploy.backgroundupdate"/>
+ <equals arg1="${javafx.deploy.backgroundupdate}" arg2="true" trim="true"/>
+ </and>
+ </condition>
+ <condition property="offline-allowed">
+ <and>
+ <isset property="javafx.deploy.allowoffline"/>
+ <equals arg1="${javafx.deploy.allowoffline}" arg2="true" trim="true"/>
+ </and>
+ </condition>
+ <condition property="permissions-elevated">
+ <and>
+ <isset property="javafx.deploy.permissionselevated"/>
+ <equals arg1="${javafx.deploy.permissionselevated}" arg2="true" trim="true"/>
+ </and>
+ </condition>
+ <condition property="binary-encode-css">
+ <and>
+ <isset property="javafx.binarycss"/>
+ <equals arg1="${javafx.binarycss}" arg2="true" trim="true"/>
+ </and>
+ </condition>
+ <condition property="rebase-lib-jars">
+ <and>
+ <isset property="javafx.rebase.libs"/>
+ <equals arg1="${javafx.rebase.libs}" arg2="true" trim="true"/>
+ </and>
+ </condition>
+ <echo message="main-class-available = ${main-class-available}" level="verbose"/>
+ <echo message="vmargs-available = ${vmargs-available}" level="verbose"/>
+ <echo message="preloader-available = ${preloader-available}" level="verbose"/>
+ <echo message="app-with-preloader = ${app-with-preloader}" level="verbose"/>
+ <echo message="app-with-preloader-without-project = ${app-with-preloader-without-project}" level="verbose"/>
+ <echo message="app-without-preloader = ${app-without-preloader}" level="verbose"/>
+ <echo message="preloader-app = ${preloader-app}" level="verbose"/>
+ <echo message="fx-in-swing-app = ${fx-in-swing-app}" level="verbose"/>
+ <echo message="fx-in-swing-workaround-app = ${fx-in-swing-workaround-app}" level="verbose"/>
+ <echo message="preloader-app-no-workaround = ${preloader-app-no-workaround}" level="verbose"/>
+ <echo message="html-template-available = ${html-template-available}" level="verbose"/>
+ <echo message="icon-available = ${icon-available}" level="verbose"/>
+ <echo message="dimensions-available = ${dimensions-available}" level="verbose"/>
+ <echo message="update-mode-background = ${update-mode-background}" level="verbose"/>
+ <echo message="offline-allowed = ${offline-allowed}" level="verbose"/>
+ <echo message="permissions-elevated = ${permissions-elevated}" level="verbose"/>
+ <echo message="binary-encode-css = ${binary-encode-css}" level="verbose"/>
+ <echo message="rebase-lib-jars = ${rebase-lib-jars}" level="verbose"/>
+ </target>
+
+ <target name="-swing-api-check" depends="-check-project,-check-jfx-deployment" if="fx-in-swing-app">
+ <condition property="fx-in-swing-app-workaround">
+ <and>
+ <isset property="fx-in-swing-app"/>
+ <not><isset property="have-fx-ant-api-1.2"/></not>
+ </and>
+ </condition>
+ </target>
+ <target name="-swing-api-warning" depends="-swing-api-check" if="fx-in-swing-app-workaround">
+ <echo message="Info: No support for FX-in-Swing deployment detected in current JavaFX SDK. Using workaround instead."/>
+ </target>
+
+ <target name="-icon-deployment-check" depends="-check-project,-check-jfx-deployment" if="icon-available">
+ <condition property="icon-deployment-may-not-be-supported">
+ <and>
+ <isset property="icon-available"/>
+ <not><isset property="have-fx-ant-api-1.1"/></not>
+ </and>
+ </condition>
+ </target>
+ <target name="-icon-warning" depends="-icon-deployment-check" if="icon-deployment-may-not-be-supported">
+ <echo message="Warning: Note that due to a bug in early JavaFX 2.0 SDK distributions the icon may not be properly set in deployment files."/>
+ </target>
+
+ <target name="-set-dimensions" depends="-check-project" if="dimensions-available">
+ <property name="javafx.width" value="${javafx.run.width}"/>
+ <property name="javafx.height" value="${javafx.run.height}"/>
+ </target>
+ <target name="-reset-dimensions" depends="-check-project" unless="dimensions-available">
+ <property name="javafx.width" value="800"/>
+ <property name="javafx.height" value="600"/>
+ </target>
+
+ <target name="-set-update-mode-background" depends="-check-project" if="update-mode-background">
+ <property name="update-mode" value="background"/>
+ </target>
+ <target name="-set-update-mode-eager" depends="-check-project" unless="update-mode-background">
+ <property name="update-mode" value="eager"/>
+ </target>
+
+ <target name="-set-permissions-elevated" depends="-check-project" if="permissions-elevated">
+ <property name="permissions.elevated" value="true"/>
+ </target>
+ <target name="-reset-permissions-elevated" depends="-check-project" unless="permissions-elevated">
+ <property name="permissions.elevated" value="false"/>
+ </target>
+
+ <target name="-set-binary-css" depends="-check-project,-init-css-conversion" if="do.copy.binary.css">
+ <property name="css-include-ext" value="bss"/>
+ <property name="css-exclude-ext" value="css"/>
+ </target>
+ <target name="-unset-binary-css" depends="-check-project,-init-css-conversion" unless="do.copy.binary.css">
+ <property name="css-include-ext" value="css"/>
+ <property name="css-exclude-ext" value="bss"/>
+ </target>
+ <target name="-copy-binary-css" depends="-init-css-conversion,-set-binary-css,-unset-binary-css,-copy-binary-css-bypass,-copy-binary-css-impl"/>
+ <target name="-init-css-conversion" depends="-check-project,-check-jdk-version">
+ <fileset id="cssfiles" dir="${basedir}${file.separator}${build.classes.dir}">
+ <include name="**${file.separator}*.css"/>
+ </fileset>
+ <pathconvert refid="cssfiles" property="cssfileset.notempty" setonempty="false"/>
+ <condition property="do.copy.binary.css">
+ <and>
+ <isset property="binary-encode-css"/>
+ <isset property="cssfileset.notempty"/>
+ <not><isset property="have-jdk7-css2bin-bug"/></not>
+ </and>
+ </condition>
+ <condition property="do.bypass.binary.css">
+ <and>
+ <isset property="binary-encode-css"/>
+ <isset property="cssfileset.notempty"/>
+ <isset property="have-jdk7-css2bin-bug"/>
+ </and>
+ </condition>
+ <echo message="do.copy.binary.css = ${do.copy.binary.css}" level="verbose"/>
+ <echo message="do.bypass.binary.css = ${do.bypass.binary.css}" level="verbose"/>
+ </target>
+ <target name="-copy-binary-css-bypass" depends="-init-css-conversion" if="do.bypass.binary.css">
+ <echo message="Warning: Bypassing FX CSS to BSS conversion due to a bug in <fx:csstobin> task in current JDK platform" level="warning"/>
+ </target>
+ <target name="-copy-binary-css-impl" depends="-init-css-conversion" if="do.copy.binary.css">
+ <property name="cssfileslist" refid="cssfiles"/>
+ <echo message="css files to binary convert: " level="verbose">${cssfileslist}</echo>
+ <fx:csstobin outdir="${basedir}${file.separator}${build.classes.dir}">
+ <fileset refid="cssfiles"/>
+ </fx:csstobin>
+ </target>
+
+
+ <!-- Copy dependent libraries -->
+
+ <!-- Note: target "-jfx-copylibs" is referenced from NB 7.1 build-impl.xml -->
+ <target name="-jfx-copylibs" depends="init,compile,-pre-pre-jar,-pre-jar,-jfx-copylibs-warning" unless="fallback.no.javascript">
+ <jfx-copylibs-js-impl/>
+ </target>
+ <target name="-jfx-copylibs-warning" if="fallback.no.javascript">
+ <echo message="Warning: Dependent Libraries copy (-jfx-copylibs) skipped in fallback build mode due to JDK missing JavaScript support."/>
+ </target>
+ <macrodef name="jfx-copylibs-js-impl">
+ <sequential>
+ <local name="run.classpath.without.build.classes.and.dist.dir"/>
+ <pathconvert property="run.classpath.without.build.classes.and.dist.dir">
+ <path path="${run.classpath}"/>
+ <map from="${basedir}${file.separator}${build.classes.dir}" to=""/>
+ <map from="${basedir}${file.separator}${dist.jar}" to=""/>
+ <map from="${javafx.runtime}${file.separator}lib${file.separator}jfxrt.jar" to=""/>
+ <map from="${javafx.runtime}${file.separator}lib${file.separator}deploy.jar" to=""/>
+ <map from="${javafx.runtime}${file.separator}lib${file.separator}javaws.jar" to=""/>
+ <map from="${javafx.runtime}${file.separator}lib${file.separator}plugin.jar" to=""/>
+ </pathconvert>
+ <!-- add possibly missing dependencies at distance 2 (build system logic thus provides transitive closure) -->
+ <local name="run.and.lib.classpath"/>
+ <echo message="JavaScript: -jfx-copylibs" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ var pathConvert = project.createTask("pathconvert");
+ pathConvert.setProperty("run.and.lib.classpath");
+ var classPath = project.getProperty("run.classpath.without.build.classes.and.dist.dir");
+ var fileSeparator = project.getProperty("file.separator");
+ if(classPath != null) {
+ var classPathCopy = pathConvert.createPath();
+ classPathCopy.setPath(classPath);
+ if(classPath.indexOf(";") != -1) {
+ var pathArray = classPath.split(";");
+ } else {
+ var pathArray = classPath.split(":");
+ }
+ var added = "";
+ for (var i=0; i<pathArray.length; i++) {
+ var index = pathArray[i].lastIndexOf(fileSeparator);
+ if (index >=0) {
+ var onePath = pathArray[i].substr(0,index+1) + "lib";
+ var oneDir = new java.io.File(onePath);
+ if(oneDir.exists()) {
+ var fs = project.createDataType("fileset");
+ fs.setDir( oneDir );
+ fs.setIncludes("*.jar");
+ var ds = fs.getDirectoryScanner(project);
+ var srcFiles = ds.getIncludedFiles();
+ for (j=0; j<srcFiles.length; j++) {
+ if(classPath.indexOf(srcFiles[j]) == -1 && added.indexOf(srcFiles[j]) == -1) {
+ var path = pathConvert.createPath();
+ path.setPath(onePath + fileSeparator + srcFiles[j]);
+ added += srcFiles[j];
+ }
+ }
+ }
+ }
+ }
+ }
+ pathConvert.perform();
+ ]]>
+ </script>
+ <echo message="run.and.lib.classpath = ${run.and.lib.classpath}" level="verbose"/>
+ <delete dir="${dist.dir}${file.separator}lib" includeEmptyDirs="true" quiet="true"/>
+ <copy todir="${dist.dir}${file.separator}lib" flatten="true" preservelastmodified="true" overwrite="true">
+ <path>
+ <pathelement path="${run.and.lib.classpath}"/>
+ </path>
+ </copy>
+ </sequential>
+ </macrodef>
+
+ <target name="-copy-external-preloader-jar" depends="-check-project" if="app-with-external-preloader-jar">
+ <copy file="${javafx.preloader.jar.path}" todir="${dist.dir}${file.separator}lib"/>
+ </target>
+
+
+ <!-- Optional classpath re-base of dependent JAR manifests after copy to lib/, required by GlassFish -->
+
+ <!-- Note: target "-rebase-libs" is referenced from NB 7.1 build-impl.xml -->
+ <target name="-rebase-libs" depends="-check-project, -jfx-copylibs, -check-rebase-libs, -rebase-libs-warning" if="do-rebase-lib-jars">
+ <rebase-libs-js-impl/>
+ </target>
+ <target name="-check-rebase-libs">
+ <condition property="do-rebase-lib-jars">
+ <and>
+ <isset property="rebase-lib-jars"/>
+ <not><isset property="fallback.no.javascript"/></not>
+ </and>
+ </condition>
+ <condition property="do-skip-rebase-libs">
+ <and>
+ <isset property="rebase-lib-jars"/>
+ <isset property="fallback.no.javascript"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-rebase-libs-warning" depends="-check-rebase-libs" if="do-skip-rebase-libs">
+ <echo message="Warning: Dependent Libraries JARs rebase (-rebase-libs) skipped in fallback build mode due to JDK missing JavaScript support."/>
+ </target>
+
+ <macrodef name="rebase-libs-js-impl">
+ <sequential>
+ <property name="pp_rebase_dir" value="${basedir}${file.separator}${dist.dir}${file.separator}lib"/>
+ <property name="pp_rebase_fs" value="*.jar"/>
+ <echo message="JavaScript: -rebase-libs-js-impl" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ var dir = project.getProperty("pp_rebase_dir");
+ var fDir = new java.io.File(dir);
+ if( fDir.exists() ) {
+ var callTask = project.createTask("antcall");
+ callTask.setTarget("-rebase-libs-macro-call");
+ var param = callTask.createParam();
+ param.setName("jar.file.to.rebase");
+ var includes = project.getProperty("pp_rebase_fs");
+ var fs = project.createDataType("fileset");
+ fs.setDir( fDir );
+ fs.setIncludes(includes);
+ var ds = fs.getDirectoryScanner(project);
+ var srcFiles = ds.getIncludedFiles();
+ for (i=0; i<srcFiles.length; i++) {
+ param.setValue(dir + "${file.separator}" + srcFiles[i]);
+ callTask.perform();
+ }
+ }
+ ]]>
+ </script>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="rebase-lib">
+ <attribute name="jarfile"/>
+ <sequential>
+ <local name="tmpdir"/>
+ <property name="tmpdir" value="${java.io.tmpdir}${file.separator}${user.name}_${ant.project.name}_rebase" />
+ <echo message="tmpdir = ${tmpdir}" level="verbose"/>
+ <delete dir="${tmpdir}" quiet="true"/>
+ <mkdir dir="${tmpdir}"/>
+ <unzip src="@{jarfile}" dest="${tmpdir}">
+ <patternset>
+ <include name="META-INF${file.separator}MANIFEST.MF"/>
+ </patternset>
+ </unzip>
+ <local name="manifest.file.temp"/>
+ <property name="manifest.file.temp" value="${tmpdir}${file.separator}META-INF${file.separator}MANIFEST.MF" />
+ <echo message="manifest.file.temp = ${manifest.file.temp}" level="verbose"/>
+ <!-- edited manifest file -->
+ <local name="manifest.file.temp.new"/>
+ <property name="manifest.file.temp.new" value="${manifest.file.temp}_new" />
+ <echo message="manifest.file.temp.new = ${manifest.file.temp.new}" level="verbose"/>
+ <echo message="JavaScript: rebase-lib" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ var UTF_8 = "UTF-8";
+ var ATTR_CLASS_PATH = "Class-Path";
+ var ATTR_CLASS_PATH_FX = "JavaFX-Class-Path";
+ function isSigned(manifest) {
+ var sections = manifest.getSectionNames();
+ while(sections.hasMoreElements()) {
+ var sectionname = sections.nextElement();
+ var section = manifest.getSection(sectionname);
+ if(section != null) {
+ var sectionKeys = section.getAttributeKeys();
+ while (sectionKeys.hasMoreElements()) {
+ var element = sectionKeys.nextElement();
+ if (element.endsWith("-Digest") || element.endsWith("-digest")) {
+ return true;
+ }
+ }
+ }
+ }
+ return false;
+ }
+ var src = project.getProperty("manifest.file.temp");
+ var srf = new java.io.File(src);
+ try {
+ var fis = new java.io.FileInputStream(srf);
+ try {
+ var isr = new java.io.InputStreamReader(fis, UTF_8);
+ try {
+ var manifest = new org.apache.tools.ant.taskdefs.Manifest(isr);
+ } finally {
+ isr.close();
+ }
+ } finally {
+ fis.close();
+ }
+ } catch(e) {
+ var manifest = null;
+ }
+ if(manifest != null) {
+ if(isSigned(manifest)) {
+ println("Warning: Signed JAR can not be rebased.");
+ } else {
+ var mainSection = manifest.getMainSection();
+ var classPath = mainSection.getAttributeValue(ATTR_CLASS_PATH);
+ if (classPath != null) {
+ var classPathAttr = ATTR_CLASS_PATH;
+ } else {
+ classPath = mainSection.getAttributeValue(ATTR_CLASS_PATH_FX);
+ if(classPath != null) {
+ var classPathAttr = ATTR_CLASS_PATH_FX;
+ }
+ }
+ if(classPath != null) {
+ var result = new java.lang.StringBuilder();
+ var changed = false;
+ var pathArray = classPath.split(" ");
+ for (var i=0; i<pathArray.length; i++) {
+ if (result.length() > 0) {
+ result.append(' ');
+ }
+ var index = pathArray[i].lastIndexOf('/');
+ if (index >=0 && index < pathArray[i].length()-1) {
+ pathArray[i] = pathArray[i].substring(index+1);
+ changed = true;
+ }
+ result.append(pathArray[i]);
+ }
+ mainSection.removeAttribute(classPathAttr);
+ mainSection.addAttributeAndCheck(new org.apache.tools.ant.taskdefs.Manifest.Attribute(classPathAttr, result.toString()));
+ var tgt = project.getProperty("manifest.file.temp.new");
+ var tgf = new java.io.File(tgt);
+ try {
+ var fos = new java.io.FileOutputStream(tgf);
+ try {
+ var osw = new java.io.OutputStreamWriter(fos, UTF_8);
+ try {
+ var manifestOut = new java.io.PrintWriter(osw);
+ manifest.write(manifestOut);
+ manifestOut.close();
+ } finally {
+ osw.close();
+ }
+ } finally {
+ fos.close();
+ }
+ } catch(e) {
+ println("Warning: problem storing rebased manifest file.");
+ }
+ }
+ }
+ }
+ ]]>
+ </script>
+ <antcall target="-move-new-manifest-if-exists">
+ <param name="move.file.from" value="${manifest.file.temp.new}"/>
+ <param name="move.file.to" value="${manifest.file.temp}"/>
+ </antcall>
+ <zip destfile="@{jarfile}" basedir="${tmpdir}" update="true"/>
+ <delete dir="${tmpdir}" quiet="true"/>
+ </sequential>
+ </macrodef>
+
+ <target name="-new-temp-mainfest-existence">
+ <condition property="new-temp-manifest-exists">
+ <available file="${move.file.from}"/>
+ </condition>
+ <echo message="new-temp-manifest-exists = ${new-temp-manifest-exists}" level="verbose"/>
+ </target>
+
+ <target name="-move-new-manifest-if-exists" depends="-new-temp-mainfest-existence" if="new-temp-manifest-exists">
+ <move file="${move.file.from}" tofile="${move.file.to}" failonerror="false"/>
+ </target>
+
+ <target name="-rebase-libs-macro-call">
+ <echo message="Rebase jarfile = ${jar.file.to.rebase}" level="verbose"/>
+ <rebase-lib jarfile="${jar.file.to.rebase}"/>
+ </target>
+
+
+ <!-- Main Deployment Target -->
+
+ <!-- Note: target "jfx-deployment" is referenced from NB 7.1+ build-impl.xml -->
+ <target name="jfx-deployment" depends="-check-jfx-deployment-launch,-do-jfx-deployment-script,-do-jfx-deployment-noscript" if="jfx-deployment-available"/>
+
+ <target name="-check-dist-lib-exists">
+ <deploy-defines/>
+ <available file="${jfx.deployment.dir}${file.separator}lib" type="dir" property="dist.lib.exists"/>
+ </target>
+ <target name="-check-jfx-deployment-jar-current-nolib" depends="-check-dist-lib-exists" unless="dist.lib.exists">
+ <uptodate property="jfx-deployment-jar-current" targetfile="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}" >
+ <srcfiles dir="${basedir}${file.separator}${build.classes.dir}" includes="**${file.separator}*"/>
+ <srcfiles dir="${basedir}${file.separator}nbproject" includes="**${file.separator}*"/>
+ </uptodate>
+ </target>
+ <target name="-check-jfx-deployment-jar-current-lib" depends="-check-dist-lib-exists" if="dist.lib.exists">
+ <uptodate property="jfx-deployment-jar-current" targetfile="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}" >
+ <srcfiles dir="${basedir}${file.separator}${build.classes.dir}" includes="**${file.separator}*"/>
+ <srcfiles dir="${jfx.deployment.dir}${file.separator}lib" includes="**${file.separator}*"/>
+ <srcfiles dir="${basedir}${file.separator}nbproject" includes="**${file.separator}*"/>
+ </uptodate>
+ </target>
+ <target name="-check-jfx-deployment-launch" depends="-check-jfx-deployment,-check-jfx-deployment-jar-current-nolib,-check-jfx-deployment-jar-current-lib">
+ <condition property="do-jfx-deployment-script">
+ <and>
+ <isset property="jfx-deployment-available"/>
+ <not><isset property="fallback.no.javascript"/></not>
+ <not><isset property="jfx-deployment-jar-current"/></not>
+ </and>
+ </condition>
+ <condition property="do-jfx-deployment-noscript">
+ <and>
+ <isset property="jfx-deployment-available"/>
+ <isset property="fallback.no.javascript"/>
+ <not><isset property="jfx-deployment-jar-current"/></not>
+ </and>
+ </condition>
+ </target>
+ <target name="-do-jfx-deployment-script" depends="-check-jfx-deployment-launch" if="do-jfx-deployment-script">
+ <antcall target="jfx-deployment-script"/>
+ </target>
+ <target name="-do-jfx-deployment-noscript" depends="-check-jfx-deployment-launch" if="do-jfx-deployment-noscript">
+ <antcall target="jfx-deployment-noscript"/>
+ </target>
+
+ <target name="jfx-deployment-script" depends="-check-jfx-deployment,-check-project,
+ -swing-api-warning,-icon-warning,
+ -set-dimensions,-reset-dimensions,-set-update-mode-background,-set-update-mode-eager,
+ -set-permissions-elevated,-reset-permissions-elevated,
+ -copy-external-preloader-jar,-copy-binary-css,
+ -deploy-app-sign-nopreloader-notemplate,
+ -deploy-app-sign-preloader-notemplate,
+ -deploy-app-sign-nopreloader-template,
+ -deploy-app-sign-preloader-template,
+ -deploy-app-sign-nopreloader-notemplate-swing,
+ -deploy-app-sign-nopreloader-template-swing,
+ -deploy-app-nosign-nopreloader-notemplate,
+ -deploy-app-nosign-preloader-notemplate,
+ -deploy-app-nosign-nopreloader-template,
+ -deploy-app-nosign-preloader-template,
+ -deploy-app-nosign-nopreloader-notemplate-swing,
+ -deploy-app-nosign-nopreloader-template-swing"
+ if="jfx-deployment-available">
+ </target>
+
+ <target name="jfx-deployment-noscript" depends="-check-jfx-deployment,-check-project,
+ -swing-api-warning,-icon-warning,
+ -set-dimensions,-reset-dimensions,-set-update-mode-background,-set-update-mode-eager,
+ -set-permissions-elevated,-reset-permissions-elevated,
+ -copy-external-preloader-jar,-copy-binary-css,
+ -fallback-deploy-app-sign-nopreloader-notemplate,
+ -fallback-deploy-app-sign-preloader-notemplate,
+ -fallback-deploy-app-sign-nopreloader-template,
+ -fallback-deploy-app-sign-preloader-template,
+ -fallback-deploy-app-sign-nopreloader-notemplate-swing,
+ -fallback-deploy-app-sign-nopreloader-template-swing,
+ -fallback-deploy-app-nosign-nopreloader-notemplate,
+ -fallback-deploy-app-nosign-preloader-notemplate,
+ -fallback-deploy-app-nosign-nopreloader-template,
+ -fallback-deploy-app-nosign-preloader-template,
+ -fallback-deploy-app-nosign-nopreloader-notemplate-swing,
+ -fallback-deploy-app-nosign-nopreloader-template-swing"
+ if="jfx-deployment-available">
+ </target>
+
+
+ <!-- Security / Signing -->
+
+ <target name="-unavailable-signjars-task" depends="-check-jfx-deployment" unless="jfx-deployment-available">
+ <echo message="Warning: Task required to sign JAR file is missing, check the availability of JavaFX 2.0 deployment tasks. JAR files will not be signed."/>
+ </target>
+
+ <target name="-security-props-check">
+ <condition property="javafx.signed.true">
+ <istrue value="${javafx.signing.enabled}"/>
+ </condition>
+ </target>
+
+ <target name="-check-signing-possible" depends="-security-props-check,-check-jfx-deployment,-unavailable-signjars-task">
+ <condition property="javafx.signed.true+signjars.task.available">
+ <and>
+ <isset property="javafx.signed.true"/>
+ <isset property="jfx-deployment-available"/>
+ </and>
+ </condition>
+ </target>
+
+ <target name="-javafx-init-keystore" depends="-check-signing-possible,-javafx-init-signing,-javafx-init-keystore1,-javafx-init-keystore2,-check-keystore-exists"
+ if="javafx.signed.true+signjars.task.available" unless="javafx.signjar.keystore.exists">
+ <property name="javafx.signjar.vendor" value="CN=${application.vendor}"/>
+ <echo message="Going to create default keystore in ${javafx.signjar.keystore}"/>
+ <genkey dname="${javafx.signjar.vendor}" alias="${javafx.signjar.alias}" keystore="${javafx.signjar.keystore}"
+ storepass="${javafx.signjar.storepass}" keypass="${javafx.signjar.keypass}"/>
+ </target>
+
+ <target name="-check-keystore-exists">
+ <available property="javafx.signjar.keystore.exists" file="${javafx.signjar.keystore}"/>
+ </target>
+
+ <target name="-javafx-init-signing">
+ <condition property="generated.key.signing">
+ <equals arg1="${javafx.signing.type}" arg2="self" trim="true"/>
+ </condition>
+ </target>
+
+ <target name="-javafx-init-keystore1" depends="-javafx-init-signing" if="generated.key.signing">
+ <property name="javafx.signjar.keystore" value="${basedir}${file.separator}build${file.separator}nb-jfx.jks" />
+ <property name="javafx.signjar.storepass" value="storepass"/>
+ <property name="javafx.signjar.keypass" value="keypass"/>
+ <property name="javafx.signjar.alias" value="nb-jfx"/>
+ </target>
+
+ <target name="-javafx-init-keystore2" depends="-javafx-init-signing" unless="generated.key.signing">
+ <property name="javafx.signjar.keystore" value="${javafx.signing.keystore}" />
+ <property name="javafx.signjar.storepass" value="${javafx.signing.keystore.password}"/>
+ <property name="javafx.signjar.keypass" value="${javafx.signing.keyalias.password}"/>
+ <property name="javafx.signjar.alias" value="${javafx.signing.keyalias}"/>
+ </target>
+
+
+ <!-- Project Deployment Macros -->
+
+ <macrodef name="deploy-defines">
+ <sequential>
+ <basename property="jfx.deployment.jar" file="${dist.jar}"/>
+ <property name="jfx.deployment.dir" location="${dist.dir}"/>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="deploy-preprocess">
+ <sequential>
+ <delete includeEmptyDirs="true" quiet="true">
+ <fileset dir="${jfx.deployment.dir}${file.separator}lib">
+ <exclude name="**${file.separator}*.jar"/>
+ </fileset>
+ </delete>
+ </sequential>
+ </macrodef>
+
+ <!-- fx:jar scripted call enables passing of arbitrarily long list of params and fx-version dependent behavior -->
+ <macrodef name="deploy-jar">
+ <sequential>
+ <antcall target="-pre-jfx-jar"/>
+ <echo message="javafx.ant.classpath = ${javafx.ant.classpath}" level="verbose"/>
+ <typedef name="fx_jar" classname="com.sun.javafx.tools.ant.FXJar" classpath="${javafx.ant.classpath}"/>
+ <echo message="Launching <fx:jar> task from ${ant-javafx.jar.location}" level="info"/>
+ <property name="pp_jar_destfile" value="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}"/>
+ <property name="pp_jar_buildclasses" value="${basedir}${file.separator}${build.classes.dir}"/>
+ <property name="pp_jar_cssbss" value="**${file.separator}*.${css-exclude-ext}"/>
+ <property name="pp_jar_dir" value="${jfx.deployment.dir}"/>
+ <property name="pp_jar_fs1" value="lib${file.separator}${javafx.preloader.jar.filename}"/>
+ <property name="pp_jar_fs2" value="lib${file.separator}*.jar"/>
+ <echo message="deploy_jar: pp_jar_destfile = ${pp_jar_destfile}" level="verbose"/>
+ <echo message="deploy_jar: pp_jar_buildclasses = ${pp_jar_buildclasses}" level="verbose"/>
+ <echo message="deploy_jar: pp_jar_cssbss = ${pp_jar_cssbss}" level="verbose"/>
+ <echo message="deploy_jar: pp_jar_dir = ${pp_jar_dir}" level="verbose"/>
+ <echo message="deploy_jar: pp_jar_fs1 = ${pp_jar_fs1}" level="verbose"/>
+ <echo message="deploy_jar: pp_jar_fs2 = ${pp_jar_fs2}" level="verbose"/>
+ <echo message="JavaScript: deploy-jar" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ var S = java.io.File.separator;
+ var JFXPAR = "javafx.param";
+ var JFXPARN = "name";
+ var JFXPARV = "value";
+ var JFXLAZY = "download.mode.lazy.jar";
+ var withpreloader = project.getProperty("app-with-preloader");
+ var fx_ant_api_1_1 = project.getProperty("have-fx-ant-api-1.1");
+ var fx_ant_api_1_2 = project.getProperty("have-fx-ant-api-1.2");
+ var fx_in_swing_app = project.getProperty("fx-in-swing-app");
+
+ // get jars with lazy download mode property set
+ function getLazyJars() {
+ var jars = new Array();
+ var keys = project.getProperties().keys();
+ while(keys.hasMoreElements()) {
+ var pn = keys.nextElement();
+ if(pn.substr(0,JFXLAZY.length) == JFXLAZY) {
+ var fname = pn.substring(JFXLAZY.length+1);
+ jars.push(fname);
+ }
+ }
+ return jars.length > 0 ? jars : null;
+ }
+ // set download mode of dependent libraries
+ function setDownloadMode(fsEager, fsLazy, jars) {
+ for(i = 0; i < jars.length; i++) {
+ fsEager.setExcludes("lib" + S + jars[i]);
+ fsLazy.setIncludes("lib" + S + jars[i]);
+ }
+ }
+
+ // fx:jar
+ var jar = project.createTask("fx_jar");
+ jar.setProject(project);
+ var destfile = project.getProperty("pp_jar_destfile");
+ jar.setDestfile(destfile);
+
+ // fx:application
+ var app = jar.createApplication();
+ app.setProject(project);
+ var title = project.getProperty("application.title");
+ if(fx_in_swing_app == "true" && fx_ant_api_1_2 == "true") {
+ var mainclass = project.getProperty("main.class");
+ app.setToolkit("swing");
+ } else {
+ var mainclass = project.getProperty("javafx.main.class");
+ }
+ var fallback = project.getProperty("javafx.fallback.class");
+ app.setName(title);
+ app.setMainClass(mainclass);
+ app.setFallbackClass(fallback);
+ if(withpreloader == "true") {
+ preloaderclass = project.getProperty("javafx.preloader.class");
+ app.setPreloaderClass(preloaderclass);
+ }
+ // fx:param, fx:argument
+ var keys = project.getProperties().keys();
+ while(keys.hasMoreElements()) {
+ var pn = keys.nextElement();
+ if(pn.substr(0,JFXPAR.length) == JFXPAR && pn.indexOf(JFXPARN) == (pn.length()-JFXPARN.length)) {
+ var propn = project.getProperty(pn);
+ if(propn != null && propn.length() > 0) {
+ var pv = pn.substr(0,pn.indexOf(JFXPARN)) + JFXPARV;
+ var propv = project.getProperty(pv);
+ if(propv != null && propv.length() > 0) {
+ var par = app.createParam();
+ par.setName(propn);
+ par.setValue(propv);
+ } else {
+ if(fx_ant_api_1_1 == "true") {
+ var arg = app.createArgument();
+ arg.addText(propn);
+ }
+ }
+ }
+ }
+ }
+
+ // fx:resources
+ var res = jar.createResources();
+ res.setProject(project);
+ var pdir = project.getProperty("pp_jar_dir");
+ if(withpreloader == "true") {
+ var f1 = res.createFileSet();
+ f1.setProject(project);
+ f1.setDir(new java.io.File(pdir));
+ var i1 = project.getProperty("pp_jar_fs1");
+ f1.setIncludes(i1);
+ f1.setRequiredFor("preloader");
+ var f2 = res.createFileSet();
+ f2.setProject(project);
+ f2.setDir(new java.io.File(pdir));
+ var i2a = project.getProperty("jfx.deployment.jar");
+ var i2b = project.getProperty("pp_jar_fs2");
+ var e2c = project.getProperty("pp_jar_fs1");
+ f2.setIncludes(i2a);
+ f2.setIncludes(i2b);
+ f2.setExcludes(e2c);
+ f2.setRequiredFor("startup");
+ var lazyjars = getLazyJars();
+ if(lazyjars != null) {
+ var f3 = res.createFileSet();
+ f3.setProject(project);
+ f3.setDir(new java.io.File(pdir));
+ f3.setRequiredFor("runtime");
+ setDownloadMode(f2,f3,lazyjars);
+ }
+ } else {
+ var fn = res.createFileSet();
+ fn.setProject(project);
+ fn.setDir(new java.io.File(pdir));
+ var ia = project.getProperty("jfx.deployment.jar");
+ var ib = project.getProperty("pp_jar_fs2");
+ fn.setIncludes(ia);
+ fn.setIncludes(ib);
+ fn.setRequiredFor("startup");
+ var lazyjars = getLazyJars();
+ if(lazyjars != null) {
+ var fn2 = res.createFileSet();
+ fn2.setProject(project);
+ fn2.setDir(new java.io.File(pdir));
+ fn2.setRequiredFor("runtime");
+ setDownloadMode(fn,fn2,lazyjars);
+ }
+ }
+
+ // fileset to exclude *.css or *.bss
+ var fs = jar.createFileSet();
+ fs.setProject(project);
+ var buildcls = project.getProperty("pp_jar_buildclasses");
+ var exc = project.getProperty("pp_jar_cssbss");
+ fs.setDir(new java.io.File(buildcls));
+ fs.setExcludes(exc);
+
+ // manifest
+ var man = jar.createManifest();
+ var a1val = project.getProperty("application.vendor");
+ var a1 = new org.apache.tools.ant.taskdefs.Manifest.Attribute();
+ a1.setName("Implementation-Vendor");
+ a1.setValue(a1val);
+ man.addConfiguredAttribute(a1);
+ var a2val = project.getProperty("application.title");
+ var a2 = new org.apache.tools.ant.taskdefs.Manifest.Attribute();
+ a2.setName("Implementation-Title");
+ a2.setValue(a2val);
+ man.addConfiguredAttribute(a2);
+ var a3 = new org.apache.tools.ant.taskdefs.Manifest.Attribute();
+ a3.setName("Implementation-Version");
+ a3.setValue("1.0");
+ man.addConfiguredAttribute(a3);
+
+ jar.perform();
+ ]]>
+ </script>
+ <antcall target="-post-jfx-jar"/>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="deploy-sign">
+ <sequential>
+ <echo message="keystore=${javafx.signjar.keystore}" level="verbose"/>
+ <echo message="storepass=${javafx.signjar.storepass}" level="verbose"/>
+ <echo message="alias=${javafx.signjar.alias}" level="verbose"/>
+ <echo message="keypass=${javafx.signjar.keypass}" level="verbose"/>
+ <signjar keystore="${javafx.signjar.keystore}"
+ storepass="${javafx.signjar.storepass}"
+ alias="${javafx.signjar.alias}"
+ keypass="${javafx.signjar.keypass}">
+ <fileset dir="${jfx.deployment.dir}">
+ <include name="${jfx.deployment.jar}"/>
+ <include name="lib${file.separator}*.jar"/>
+ </fileset>
+ </signjar>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="deploy-sign-preloader">
+ <sequential>
+ <echo message="keystore=${javafx.signjar.keystore}" level="verbose"/>
+ <echo message="storepass=${javafx.signjar.storepass}" level="verbose"/>
+ <echo message="alias=${javafx.signjar.alias}" level="verbose"/>
+ <echo message="keypass=${javafx.signjar.keypass}" level="verbose"/>
+ <signjar keystore="${javafx.signjar.keystore}"
+ storepass="${javafx.signjar.storepass}"
+ alias="${javafx.signjar.alias}"
+ keypass="${javafx.signjar.keypass}">
+ <fileset dir="${jfx.deployment.dir}">
+ <include name="lib${file.separator}${javafx.preloader.jar.filename}"/>
+ </fileset>
+ </signjar>
+ <signjar keystore="${javafx.signjar.keystore}"
+ storepass="${javafx.signjar.storepass}"
+ alias="${javafx.signjar.alias}"
+ keypass="${javafx.signjar.keypass}">
+ <fileset dir="${jfx.deployment.dir}">
+ <include name="${jfx.deployment.jar}"/>
+ <include name="lib${file.separator}*.jar"/>
+ <exclude name="lib${file.separator}${javafx.preloader.jar.filename}"/>
+ </fileset>
+ </signjar>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="deploy-process-template">
+ <sequential>
+ <echo message="javafx.run.htmltemplate = ${javafx.run.htmltemplate}" level="verbose"/>
+ <pathconvert property="javafx.run.htmltemplate.processed">
+ <path path="${javafx.run.htmltemplate}"/>
+ <mapper>
+ <chainedmapper>
+ <flattenmapper/>
+ <globmapper from="*" to="${jfx.deployment.dir}${file.separator}*" casesensitive="no"/>
+ </chainedmapper>
+ </mapper>
+ </pathconvert>
+ <echo message="javafx.run.htmltemplate.processed = ${javafx.run.htmltemplate.processed}" level="verbose"/>
+ </sequential>
+ </macrodef>
+
+ <!-- fx:deploy scripted call enables passing of arbitrarily long lists of params, vmoptions and callbacks and fx-version dependent behavior -->
+ <macrodef name="deploy-deploy">
+ <sequential>
+ <antcall target="-pre-jfx-deploy"/>
+ <antcall target="-call-pre-jfx-native"/>
+ <echo message="javafx.ant.classpath = ${javafx.ant.classpath}" level="verbose"/>
+ <typedef name="fx_deploy" classname="com.sun.javafx.tools.ant.DeployFXTask" classpath="${javafx.ant.classpath}"/>
+ <echo message="Launching <fx:deploy> task from ${ant-javafx.jar.location}" level="info"/>
+ <property name="pp_deploy_dir" value="${jfx.deployment.dir}"/>
+ <property name="pp_deploy_fs1" value="lib${file.separator}${javafx.preloader.jar.filename}"/>
+ <property name="pp_deploy_fs2" value="lib${file.separator}*.jar"/>
+ <echo message="deploy_deploy: pp_deploy_dir = ${pp_deploy_dir}" level="verbose"/>
+ <echo message="deploy_deploy: pp_deploy_fs1 = ${pp_deploy_fs1}" level="verbose"/>
+ <echo message="deploy_deploy: pp_deploy_fs2 = ${pp_deploy_fs2}" level="verbose"/>
+ <echo message="JavaScript: deploy-deploy" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ function isTrue(prop) {
+ return prop != null &&
+ (prop.toLowerCase()=="true" || prop.toLowerCase()=="yes" || prop.toLowerCase()=="on");
+ }
+ var S = java.io.File.separator;
+ var JFXPAR = "javafx.param";
+ var JFXPARN = "name";
+ var JFXPARV = "value";
+ var JFXCALLB = "javafx.jscallback";
+ var JFXLAZY = "download.mode.lazy.jar";
+ var withpreloader = project.getProperty("app-with-preloader");
+ var fx_ant_api_1_1 = project.getProperty("have-fx-ant-api-1.1");
+ var fx_ant_api_1_2 = project.getProperty("have-fx-ant-api-1.2");
+ var fx_in_swing_app = project.getProperty("fx-in-swing-app");
+
+ // get jars with lazy download mode property set
+ function getLazyJars() {
+ var jars = new Array();
+ var keys = project.getProperties().keys();
+ while(keys.hasMoreElements()) {
+ var pn = keys.nextElement();
+ if(pn.substr(0,JFXLAZY.length) == JFXLAZY) {
+ var fname = pn.substring(JFXLAZY.length+1);
+ jars.push(fname);
+ }
+ }
+ return jars.length > 0 ? jars : null;
+ }
+ // set download mode of dependent libraries
+ function setDownloadMode(fsEager, fsLazy, jars) {
+ for(i = 0; i < jars.length; i++) {
+ fsEager.setExcludes("lib" + S + jars[i]);
+ fsLazy.setIncludes("lib" + S + jars[i]);
+ }
+ }
+
+ // fx:deploy
+ var deploy = project.createTask("fx_deploy");
+ deploy.setProject(project);
+ var width = project.getProperty("javafx.width");
+ var height = project.getProperty("javafx.height");
+ var outdir = project.getProperty("jfx.deployment.dir");
+ var embedJNLP = project.getProperty("javafx.deploy.embedJNLP");
+ var updatemode = project.getProperty("update-mode");
+ var outfile = project.getProperty("application.title");
+ var includeDT = project.getProperty("javafx.deploy.includeDT");
+ var offline = project.getProperty("javafx.deploy.allowoffline");
+ deploy.setWidth(width);
+ deploy.setHeight(height);
+ deploy.setOutdir(outdir);
+ deploy.setEmbedJNLP(isTrue(embedJNLP));
+ deploy.setUpdateMode(updatemode);
+ deploy.setOutfile(outfile);
+ deploy.setIncludeDT(isTrue(includeDT));
+ if(offline != null) {
+ if(fx_ant_api_1_1 == "true") {
+ deploy.setOfflineAllowed(isTrue(offline));
+ } else {
+ println("Warning: offlineAllowed not supported by this version of JavaFX SDK deployment Ant task. Please upgrade JavaFX to 2.0.2 or higher.");
+ }
+ }
+ // native packaging (time consuming, thus applied in explicit build only)
+ var nativeEnabled = project.getProperty("do.build.native.package");
+ var nativeType = project.getProperty("javafx.native.bundling.type");
+ var projStateRun = project.getProperty("project.state.running");
+ var projStateDbg = project.getProperty("project.state.debugging");
+ var projStatePrf = project.getProperty("project.state.profiling");
+ if(isTrue(nativeEnabled) && nativeType != null && nativeType != "none") {
+ if(!isTrue(projStateRun) && !isTrue(projStateDbg) && !isTrue(projStatePrf)) {
+ if(fx_ant_api_1_2 == "true") {
+ deploy.setNativeBundles(nativeType);
+ println("Note: To create native bundles the <fx:deploy> task may require external tools. See JavaFX 2.2+ documentation for details.");
+ println("");
+ println("Launching <fx:deploy> in native packager mode...");
+ } else {
+ println("Warning: Native packaging is not supported by this version of JavaFX SDK deployment Ant task. Please upgrade to JDK 7u6 or higher.");
+ }
+ }
+ }
+
+ // fx:application
+ var app = deploy.createApplication();
+ app.setProject(project);
+ var title = project.getProperty("application.title");
+ if(fx_in_swing_app == "true" && fx_ant_api_1_2 == "true") {
+ var mainclass = project.getProperty("main.class");
+ app.setToolkit("swing");
+ } else {
+ var mainclass = project.getProperty("javafx.main.class");
+ }
+ var fallback = project.getProperty("javafx.fallback.class");
+ app.setName(title);
+ app.setMainClass(mainclass);
+ app.setFallbackClass(fallback);
+ if(withpreloader == "true") {
+ preloaderclass = project.getProperty("javafx.preloader.class");
+ app.setPreloaderClass(preloaderclass);
+ }
+ // fx:param, fx:argument
+ var keys = project.getProperties().keys();
+ while(keys.hasMoreElements()) {
+ var pn = keys.nextElement();
+ if(pn.substr(0,JFXPAR.length) == JFXPAR && pn.indexOf(JFXPARN) == (pn.length()-JFXPARN.length)) {
+ var propn = project.getProperty(pn);
+ if(propn != null && propn.length() > 0) {
+ var pv = pn.substr(0,pn.indexOf(JFXPARN)) + JFXPARV;
+ var propv = project.getProperty(pv);
+ if(propv != null && propv.length() > 0) {
+ var par = app.createParam();
+ par.setName(propn);
+ par.setValue(propv);
+ } else {
+ if(fx_ant_api_1_1 == "true") {
+ var arg = app.createArgument();
+ arg.addText(propn);
+ } else {
+ println("Warning: Unnamed parameters not supported by this version of JavaFX SDK deployment Ant tasks. Upgrade JavaFX to 2.0.2 or higher.");
+ }
+ }
+ }
+ }
+ }
+
+ // fx:resources
+ var res = deploy.createResources();
+ res.setProject(project);
+ var deploydir = project.getProperty("pp_deploy_dir");
+ if(withpreloader == "true") {
+ var f1 = res.createFileSet();
+ f1.setProject(project);
+ f1.setDir(new java.io.File(deploydir));
+ var i1 = project.getProperty("pp_deploy_fs1");
+ f1.setIncludes(i1);
+ f1.setRequiredFor("preloader");
+ var f2 = res.createFileSet();
+ f2.setProject(project);
+ f2.setDir(new java.io.File(deploydir));
+ var i2a = project.getProperty("jfx.deployment.jar");
+ var i2b = project.getProperty("pp_deploy_fs2");
+ var e2c = project.getProperty("pp_deploy_fs1");
+ f2.setIncludes(i2a);
+ f2.setIncludes(i2b);
+ f2.setExcludes(e2c);
+ f2.setRequiredFor("startup");
+ var lazyjars = getLazyJars();
+ if(lazyjars != null) {
+ var f3 = res.createFileSet();
+ f3.setProject(project);
+ f3.setDir(new java.io.File(deploydir));
+ f3.setRequiredFor("runtime");
+ setDownloadMode(f2,f3,lazyjars);
+ }
+ } else {
+ var fn = res.createFileSet();
+ fn.setProject(project);
+ fn.setDir(new java.io.File(deploydir));
+ var ia = project.getProperty("jfx.deployment.jar");
+ var ib = project.getProperty("pp_deploy_fs2");
+ fn.setIncludes(ia);
+ fn.setIncludes(ib);
+ fn.setRequiredFor("startup");
+ var lazyjars = getLazyJars();
+ if(lazyjars != null) {
+ var fn2 = res.createFileSet();
+ fn2.setProject(project);
+ fn2.setDir(new java.io.File(deploydir));
+ fn2.setRequiredFor("runtime");
+ setDownloadMode(fn,fn2,lazyjars);
+ }
+ }
+
+ // fx:info
+ var info = deploy.createInfo();
+ info.setProject(project);
+ var vendor = project.getProperty("application.vendor");
+ var description = project.getProperty("application.desc");
+ info.setTitle(title); // title known from before
+ info.setVendor(vendor);
+ info.setDescription(description);
+ var icon = project.getProperty("javafx.deploy.icon");
+ if(icon != null) {
+ if(fx_ant_api_1_1 == "true") {
+ var iicon = info.createIcon();
+ iicon.setHref(icon);
+ } else {
+ println("Warning: Icon not supported by this version of JavaFX SDK deployment Ant task. Please upgrade JavaFX to 2.0.2 or higher.");
+ }
+ }
+
+ // fx:permissions
+ var perm = deploy.createPermissions();
+ perm.setProject(project);
+ var elev = project.getProperty("permissions.elevated");
+ perm.setElevated(isTrue(elev));
+
+ // fx:preferences
+ var pref = deploy.createPreferences();
+ pref.setProject(project);
+ var scut = project.getProperty("javafx.deploy.adddesktopshortcut");
+ var instp = project.getProperty("javafx.deploy.installpermanently");
+ var smenu = project.getProperty("javafx.deploy.addstartmenushortcut");
+ pref.setShortcut(isTrue(scut));
+ pref.setInstall(isTrue(instp));
+ pref.setMenu(isTrue(smenu));
+
+ // fx:template
+ var templ = project.getProperty("javafx.run.htmltemplate");
+ var templp = project.getProperty("javafx.run.htmltemplate.processed");
+ if(templ != null && templp != null && templ.length() > 0 && templp.length() > 0) {
+ var temp = deploy.createTemplate();
+ temp.setProject(project);
+ temp.setFile(new java.io.File(templ));
+ temp.setTofile(new java.io.File(templp));
+ }
+
+ // fx:platform
+ var plat = deploy.createPlatform();
+ plat.setProject(project);
+ var jvmargs = project.getProperty("run.jvmargs");
+ if(jvmargs != null && jvmargs.length() > 0) {
+ var jvmargss = jvmargs.split(" ");
+ for(i = 0; i < jvmargss.length; i++) {
+ if(jvmargss[i] != null && jvmargss[i].length() > 0) {
+ var vmarg = plat.createJvmarg();
+ vmarg.setValue(jvmargss[i]);
+ }
+ }
+ }
+
+ // fx:callbacks
+ var callbs = deploy.createCallbacks();
+ callbs.setProject(project);
+ var keys = project.getProperties().keys();
+ while(keys.hasMoreElements()) {
+ var pn = keys.nextElement();
+ if(pn.substr(0,JFXCALLB.length) == JFXCALLB) {
+ var prop = project.getProperty(pn);
+ if(prop != null && prop.length() > 0) {
+ var cname = pn.substring(JFXCALLB.length+1);
+ var cb = callbs.createCallback();
+ cb.setProject(project);
+ cb.setName(cname);
+ cb.addText(prop);
+ }
+ }
+ }
+
+ deploy.perform();
+ ]]>
+ </script>
+ <antcall target="-post-jfx-deploy"/>
+ <antcall target="-call-post-jfx-native"/>
+ </sequential>
+ </macrodef>
+
+ <!-- JavaFX SDK 2.0.x and 2.1.x deploy task can not generate pre-FX jnlp which is needed for FX-in-Swing projects-->
+ <macrodef name="deploy-deploy-swing">
+ <sequential>
+ <antcall target="-pre-jfx-deploy"/>
+ <local name="permissions-elevated-token"/>
+ <condition property="permissions-elevated-token" value="${line.separator} <security>${line.separator} <all-permissions/>${line.separator} </security>" else="">
+ <isset property="permissions-elevated"/>
+ </condition>
+ <local name="offline-allowed-token"/>
+ <condition property="offline-allowed-token" value="${line.separator} <offline-allowed/>" else="">
+ <isset property="offline-allowed"/>
+ </condition>
+ <local name="update-mode-background-token"/>
+ <condition property="update-mode-background-token" value="background" else="always">
+ <isset property="update-mode-background"/>
+ </condition>
+ <local name="html-template-processed-available"/>
+ <condition property="html-template-processed-available">
+ <and>
+ <isset property="javafx.run.htmltemplate.processed"/>
+ <not>
+ <equals arg1="${javafx.run.htmltemplate.processed}" arg2=""/>
+ </not>
+ </and>
+ </condition>
+ <local name="javafx.deploy.icon.basename"/>
+ <basename property="javafx.deploy.icon.basename" file="${javafx.deploy.icon}"/>
+ <local name="local-icon-filename-available"/>
+ <condition property="local-icon-filename-available">
+ <and>
+ <isset property="icon-available"/>
+ <isset property="javafx.deploy.icon.basename"/>
+ <not><equals arg1="${javafx.deploy.icon.basename}" arg2=""/></not>
+ <not><contains string="${javafx.deploy.icon.basename}" substring="$${javafx" casesensitive="false"/></not>
+ <not><contains string="${javafx.deploy.icon}" substring="http:" casesensitive="false"/></not>
+ </and>
+ </condition>
+ <local name="icon-token"/>
+ <condition property="icon-token" value="${line.separator} <icon href="${javafx.deploy.icon.basename}" kind="default"/>">
+ <isset property="local-icon-filename-available"/>
+ </condition>
+ <condition property="icon-token" value="${line.separator} <icon href="${javafx.deploy.icon}" kind="default"/>" else="">
+ <isset property="icon-available"/>
+ </condition>
+ <basename property="dist.filename" file="${dist.jar}" suffix=".jar"/>
+ <length file="${dist.jar}" property="dist.jar.size" />
+ <local name="vmargs-token"/>
+ <condition property="vmargs-token" value="java-vm-args="${run.jvmargs}" " else="">
+ <isset property="vmargs-available"/>
+ </condition>
+ <local name="applet-params-token"/>
+ <local name="application-args-token"/>
+ <echo message="JavaScript: deploy-deploy-swing 1" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ var JFXPAR = "javafx.param";
+ var JFXPARN = "name";
+ var JFXPARV = "value";
+
+ var params = "";
+ var args = "";
+ var keys = project.getProperties().keys();
+ while(keys.hasMoreElements()) {
+ var pn = keys.nextElement();
+ if(pn.substr(0,JFXPAR.length) == JFXPAR && pn.indexOf(JFXPARN) == (pn.length()-JFXPARN.length)) {
+ var propn = project.getProperty(pn);
+ if(propn != null && propn.length() > 0) {
+ var pv = pn.substr(0,pn.indexOf(JFXPARN)) + JFXPARV;
+ var propv = project.getProperty(pv);
+ if(propv != null && propv.length() > 0) {
+ params += "\n <param name=\"" + propn + "\" value=\"" + propv + "\"/>";
+ args += "\n <argument>" + propn + "=" + propv + "</argument>";
+ } else {
+ params += "\n <param name=\"" + propn + "\" value=\"\"/>";
+ args += "\n <argument>" + propn + "</argument>";
+ }
+ }
+ }
+ }
+ project.setProperty("applet-params-token", params);
+ project.setProperty("application-args-token", args);
+ ]]>
+ </script>
+ <local name="application.desc.processed"/>
+ <condition property="application.desc.processed" value="${application.desc}" else="Swing applet embedding JavaFX components.">
+ <isset property="application.desc"/>
+ </condition>
+ <filterchain id="jnlp.template.filter">
+ <replacetokens>
+ <token key="NAME" value="${dist.filename}"/>
+ <token key="MAINCLASS" value="${main.class}"/>
+ <token key="FILESIZE" value="${dist.jar.size}"/>
+ <token key="VENDOR" value="${application.vendor}"/>
+ <token key="TITLE" value="${application.title}"/>
+ <token key="DESCRIPTION" value="${application.desc.processed}"/>
+ <token key="WIDTH" value="${javafx.run.width}"/>
+ <token key="HEIGHT" value="${javafx.run.height}"/>
+ <token key="PERMISSIONS" value="${permissions-elevated-token}"/>
+ <token key="OFFLINE" value="${offline-allowed-token}"/>
+ <token key="UPDATEMODE" value="${update-mode-background-token}"/>
+ <token key="ICON" value="${icon-token}"/>
+ <token key="VMARGS" value="${vmargs-token}"/>
+ <token key="PARAMETERS" value="${applet-params-token}"/>
+ <token key="ARGUMENTS" value="${application-args-token}"/>
+ </replacetokens>
+ </filterchain>
+ <copy file="${basedir}${file.separator}nbproject${file.separator}templates${file.separator}FXSwingTemplateApplication.jnlp"
+ tofile="${dist.dir}${file.separator}${dist.filename}_application.jnlp" >
+ <filterchain refid="jnlp.template.filter"/>
+ </copy>
+ <copy file="${basedir}${file.separator}nbproject${file.separator}templates${file.separator}FXSwingTemplateApplet.jnlp"
+ tofile="${dist.dir}${file.separator}${dist.filename}_applet.jnlp" >
+ <filterchain refid="jnlp.template.filter"/>
+ </copy>
+ <copy file="${basedir}${file.separator}nbproject${file.separator}templates${file.separator}FXSwingTemplate.html"
+ tofile="${dist.dir}${file.separator}${dist.filename}.html" >
+ <filterchain refid="jnlp.template.filter"/>
+ </copy>
+ <echo message="JavaScript: deploy-deploy-swing 2" level="verbose"/>
+ <script language="javascript">
+ <![CDATA[
+ var PREF = "file:";
+ var doCopyIcon = project.getProperty("local-icon-filename-available");
+ if(doCopyIcon != null) {
+ var iconProp = project.getProperty("javafx.deploy.icon");
+ if(iconProp.indexOf(PREF) == 0) {
+ iconProp = iconProp.slice(PREF.length);
+ }
+ while(iconProp.charAt(0) == "/") {
+ iconProp = iconProp.slice(1);
+ }
+ var S = java.io.File.separator;
+ var baseDir = project.getProperty("basedir");
+ var distDir = project.getProperty("dist.dir");
+ var copyTask = project.createTask("copy");
+ var source = new java.io.File(iconProp);
+ var target = new java.io.File(baseDir + S + distDir);
+ copyTask.setFile(source);
+ copyTask.setTodir(target);
+ copyTask.setFlatten(true);
+ copyTask.setFailOnError(false);
+ copyTask.perform();
+ }
+ var doCopyHTMLFrom = project.getProperty("html-template-available");
+ var doCopyHTMLTo = project.getProperty("html-template-processed-available");
+ if(doCopyHTMLFrom != null && doCopyHTMLTo != null) {
+ var htmlFrom = project.getProperty("javafx.run.htmltemplate");
+ if(htmlFrom.indexOf(PREF) == 0) {
+ htmlFrom = htmlFrom.slice(PREF.length);
+ }
+ while(htmlFrom.charAt(0) == "/") {
+ htmlFrom = htmlFrom.slice(1);
+ }
+ var htmlTo = project.getProperty("javafx.run.htmltemplate.processed");
+ if(htmlTo.indexOf(PREF) == 0) {
+ htmlTo = htmlTo.slice(PREF.length);
+ }
+ while(htmlTo.charAt(0) == "/") {
+ htmlTo = htmlTo.slice(1);
+ }
+ var copyTask = project.createTask("copy");
+ var source = new java.io.File(htmlFrom);
+ var target = new java.io.File(htmlTo);
+ copyTask.setFile(source);
+ copyTask.setTofile(target);
+ copyTask.setFailOnError(false);
+ copyTask.perform();
+ }
+ ]]>
+ </script>
+ <antcall target="-post-jfx-deploy"/>
+ </sequential>
+ </macrodef>
+
+
+ <!-- Fallback Project Deployment Macros To Support At Least Partially JDKs Without JavaScript Support -->
+
+ <macrodef name="fallback-deploy-application-def">
+ <sequential>
+ <echo message="Warning: Parameters (if any) not passed to <fx:application> in fallback build mode due to JDK missing JavaScript support."/>
+ <fx:application id="fxApp"
+ name="${application.title}"
+ mainClass="${javafx.main.class}"
+ fallbackClass="${javafx.fallback.class}">
+ <!-- PARAMETERS NOT PASSED IN FALLBACK -->
+ </fx:application>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-application-def-preloader">
+ <sequential>
+ <echo message="Warning: Parameters (if any) not passed to <fx:application> in fallback build mode due to JDK missing JavaScript support."/>
+ <fx:application id="fxApp"
+ name="${application.title}"
+ mainClass="${javafx.main.class}"
+ preloaderClass="${javafx.preloader.class}"
+ fallbackClass="${javafx.fallback.class}">
+ <!-- PARAMETERS NOT PASSED IN FALLBACK -->
+ </fx:application>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-application-def-swing">
+ <sequential>
+ <echo message="Warning: Parameters (if any) not passed to <fx:application> in fallback build mode due to JDK missing JavaScript support."/>
+ <fx:application id="fxApp"
+ name="${application.title}"
+ mainClass="${main.class}"
+ fallbackClass="${javafx.fallback.class}"
+ toolkit="swing">
+ <!-- PARAMETERS NOT PASSED IN FALLBACK -->
+ </fx:application>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-resources">
+ <sequential>
+ <fx:resources id="appRes">
+ <fx:fileset requiredFor="startup" dir="${jfx.deployment.dir}">
+ <include name="${jfx.deployment.jar}"/>
+ <include name="lib${file.separator}*.jar"/>
+ <exclude name="lib${file.separator}${jfx.deployment.jar}"/>
+ </fx:fileset>
+ </fx:resources>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-resources-preloader">
+ <sequential>
+ <fx:resources id="appRes">
+ <fx:fileset requiredFor="preloader" dir="${jfx.deployment.dir}">
+ <include name="lib${file.separator}${javafx.preloader.jar.filename}"/>
+ </fx:fileset>
+ <fx:fileset requiredFor="startup" dir="${jfx.deployment.dir}">
+ <include name="${jfx.deployment.jar}"/>
+ <include name="lib${file.separator}*.jar"/>
+ <exclude name="lib${file.separator}${javafx.preloader.jar.filename}"/>
+ <exclude name="lib${file.separator}${jfx.deployment.jar}"/>
+ </fx:fileset>
+ </fx:resources>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-jar">
+ <sequential>
+ <antcall target="-pre-jfx-jar"/>
+ <fx:jar destfile="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}">
+ <fx:application refid="fxApp"/>
+ <fx:resources refid="appRes"/>
+ <fileset dir="${build.classes.dir}">
+ <exclude name="**${file.separator}*.${css-exclude-ext}"/>
+ </fileset>
+ <manifest>
+ <attribute name="Implementation-Vendor" value="${application.vendor}"/>
+ <attribute name="Implementation-Title" value="${application.title}"/>
+ <attribute name="Implementation-Version" value="1.0"/>
+ </manifest>
+ </fx:jar>
+ <antcall target="-post-jfx-jar"/>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-deploy">
+ <sequential>
+ <antcall target="-pre-jfx-deploy"/>
+ <echo message="Warning: JVM Arguments and Callbacks (if any) not passed to <fx:deploy> in fallback build mode due to JDK missing JavaScript support."/>
+ <fx:deploy width="${javafx.width}" height="${javafx.height}"
+ outdir="${jfx.deployment.dir}" embedjnlp="true" updatemode="${update-mode}"
+ outfile="${application.title}" includeDT="${javafx.deploy.includeDT}">
+ <fx:application refid="fxApp"/>
+ <fx:resources refid="appRes"/>
+ <fx:info title="${application.title}" vendor="${application.vendor}"/>
+ <fx:permissions elevated="${permissions.elevated}"/>
+ <fx:preferences shortcut="${javafx.deploy.adddesktopshortcut}" install="${javafx.deploy.installpermanently}" menu="${javafx.deploy.addstartmenushortcut}"/>
+ <!-- PLATFORM NOT PASSED IN FALLBACK -->
+ <!-- CALLBACKS NOT PASSED IN FALLBACK -->
+ </fx:deploy>
+ <antcall target="-post-jfx-deploy"/>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="fallback-deploy-deploy-template">
+ <sequential>
+ <antcall target="-pre-jfx-deploy"/>
+ <echo message="Warning: JVM Arguments and Callbacks (if any) not passed to <fx:deploy> in fallback build mode due to JDK missing JavaScript support."/>
+ <deploy-process-template/>
+ <fx:deploy width="${javafx.width}" height="${javafx.height}"
+ outdir="${jfx.deployment.dir}" embedjnlp="true" updatemode="${update-mode}"
+ outfile="${application.title}" includeDT="${javafx.deploy.includeDT}">
+ <fx:application refid="fxApp"/>
+ <fx:resources refid="appRes"/>
+ <fx:info title="${application.title}" vendor="${application.vendor}"/>
+ <fx:permissions elevated="${permissions.elevated}"/>
+ <fx:preferences shortcut="${javafx.deploy.adddesktopshortcut}" install="${javafx.deploy.installpermanently}" menu="${javafx.deploy.addstartmenushortcut}"/>
+ <fx:template file="${javafx.run.htmltemplate}" tofile="${javafx.run.htmltemplate.processed}"/>
+ <!-- PLATFORM NOT PASSED IN FALLBACK -->
+ <!-- CALLBACKS NOT PASSED IN FALLBACK -->
+ </fx:deploy>
+ <antcall target="-post-jfx-deploy"/>
+ </sequential>
+ </macrodef>
+
+
+ <!-- Project Deployment Targets -->
+
+ <target name="-check-sign" depends="-check-project,-javafx-init-keystore" if="javafx.signed.true+signjars.task.available">
+ <condition property="sign-nopreloader-notemplate">
+ <and>
+ <isset property="app-without-preloader"/>
+ <not><isset property="html-template-available"/></not>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="sign-preloader-notemplate">
+ <and>
+ <isset property="app-with-preloader"/>
+ <not><isset property="html-template-available"/></not>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="sign-nopreloader-template">
+ <and>
+ <isset property="app-without-preloader"/>
+ <isset property="html-template-available"/>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="sign-preloader-template">
+ <and>
+ <isset property="app-with-preloader"/>
+ <isset property="html-template-available"/>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="sign-nopreloader-notemplate-swing">
+ <and>
+ <isset property="app-without-preloader"/>
+ <not><isset property="html-template-available"/></not>
+ <isset property="fx-in-swing-app-workaround"/>
+ </and>
+ </condition>
+ <condition property="sign-nopreloader-template-swing">
+ <and>
+ <isset property="app-without-preloader"/>
+ <isset property="html-template-available"/>
+ <isset property="fx-in-swing-app-workaround"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-check-nosign" depends="-check-project">
+ <condition property="nosign-nopreloader-notemplate">
+ <and>
+ <isset property="app-without-preloader"/>
+ <not><isset property="html-template-available"/></not>
+ <not><isset property="javafx.signed.true"/></not>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="nosign-preloader-notemplate">
+ <and>
+ <isset property="app-with-preloader"/>
+ <not><isset property="html-template-available"/></not>
+ <not><isset property="javafx.signed.true"/></not>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="nosign-nopreloader-template">
+ <and>
+ <isset property="app-without-preloader"/>
+ <isset property="html-template-available"/>
+ <not><isset property="javafx.signed.true"/></not>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="nosign-preloader-template">
+ <and>
+ <isset property="app-with-preloader"/>
+ <isset property="html-template-available"/>
+ <not><isset property="javafx.signed.true"/></not>
+ <not><isset property="fx-in-swing-app-workaround"/></not>
+ </and>
+ </condition>
+ <condition property="nosign-nopreloader-notemplate-swing">
+ <and>
+ <isset property="app-without-preloader"/>
+ <not><isset property="html-template-available"/></not>
+ <not><isset property="javafx.signed.true"/></not>
+ <isset property="fx-in-swing-app-workaround"/>
+ </and>
+ </condition>
+ <condition property="nosign-nopreloader-template-swing">
+ <and>
+ <isset property="app-without-preloader"/>
+ <isset property="html-template-available"/>
+ <not><isset property="javafx.signed.true"/></not>
+ <isset property="fx-in-swing-app-workaround"/>
+ </and>
+ </condition>
+ </target>
+
+
+ <!-- WITH SIGNING -->
+
+ <!-- project without preloader -->
+ <!-- no html template -->
+ <target name="-deploy-app-sign-nopreloader-notemplate" depends="-check-sign" if="sign-nopreloader-notemplate" unless="preloader-app">
+ <echo message="-deploy-app-sign-nopreloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-sign/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project with preloader -->
+ <!-- no html template -->
+ <target name="-deploy-app-sign-preloader-notemplate" depends="-check-sign" if="sign-preloader-notemplate" unless="preloader-app">
+ <echo message="-deploy-app-sign-preloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-sign-preloader/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project without preloader -->
+ <!-- html template -->
+ <target name="-deploy-app-sign-nopreloader-template" depends="-check-sign" if="sign-nopreloader-template" unless="preloader-app">
+ <echo message="-deploy-app-sign-nopreloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-sign/>
+ <deploy-process-template/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project with preloader -->
+ <!-- html template -->
+ <target name="-deploy-app-sign-preloader-template" depends="-check-sign" if="sign-preloader-template" unless="preloader-app">
+ <echo message="-deploy-app-sign-preloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-sign-preloader/>
+ <deploy-process-template/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project without preloader -->
+ <!-- no html template -->
+ <!-- FX in Swing app -->
+ <target name="-deploy-app-sign-nopreloader-notemplate-swing" depends="-check-sign" if="sign-nopreloader-notemplate-swing" unless="preloader-app-no-workaround">
+ <echo message="-deploy-app-sign-nopreloader-notemplate-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-sign/>
+ <deploy-deploy-swing/>
+ </target>
+
+ <!-- project without preloader -->
+ <!-- html template -->
+ <!-- FX in Swing app -->
+ <target name="-deploy-app-sign-nopreloader-template-swing" depends="-check-sign" if="sign-nopreloader-template-swing" unless="preloader-app-no-workaround">
+ <echo message="-deploy-app-sign-nopreloader-template-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-sign/>
+ <deploy-process-template/>
+ <deploy-deploy-swing/>
+ </target>
+
+
+ <!-- NO SIGNING -->
+
+ <!-- project without preloader -->
+ <!-- no html template -->
+ <target name="-deploy-app-nosign-nopreloader-notemplate" depends="-check-nosign" if="nosign-nopreloader-notemplate" unless="preloader-app">
+ <echo message="-deploy-app-nosign-nopreloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project with preloader -->
+ <!-- no html template -->
+ <target name="-deploy-app-nosign-preloader-notemplate" depends="-check-nosign" if="nosign-preloader-notemplate" unless="preloader-app">
+ <echo message="-deploy-app-nosign-preloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project without preloader -->
+ <!-- html template -->
+ <target name="-deploy-app-nosign-nopreloader-template" depends="-check-nosign" if="nosign-nopreloader-template" unless="preloader-app">
+ <echo message="-deploy-app-nosign-nopreloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-process-template/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project with preloader -->
+ <!-- html template -->
+ <target name="-deploy-app-nosign-preloader-template" depends="-check-nosign" if="nosign-preloader-template" unless="preloader-app">
+ <echo message="-deploy-app-nosign-preloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-process-template/>
+ <deploy-deploy/>
+ </target>
+
+ <!-- project without preloader -->
+ <!-- no html template -->
+ <!-- FX in Swing app -->
+ <target name="-deploy-app-nosign-nopreloader-notemplate-swing" depends="-check-nosign" if="nosign-nopreloader-notemplate-swing" unless="preloader-app-no-workaround">
+ <echo message="-deploy-app-nosign-nopreloader-notemplate-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-deploy-swing/>
+ </target>
+
+ <!-- project without preloader -->
+ <!-- html template -->
+ <!-- FX in Swing app -->
+ <target name="-deploy-app-nosign-nopreloader-template-swing" depends="-check-nosign" if="nosign-nopreloader-template-swing" unless="preloader-app-no-workaround">
+ <echo message="-deploy-app-nosign-nopreloader-template-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <deploy-jar/>
+ <deploy-process-template/>
+ <deploy-deploy-swing/>
+ </target>
+
+
+ <!-- FALLBACK (NO JAVASCRIPT) TARGETS WITH SIGNING -->
+
+ <target name="-check-fallback-sign-deploy-swing-possible" depends="-check-sign">
+ <local name="fail-deploy-swing-possible"/>
+ <condition property="fail-deploy-swing-possible">
+ <and>
+ <or>
+ <isset property="sign-nopreloader-notemplate-swing"/>
+ <isset property="sign-nopreloader-template-swing"/>
+ </or>
+ <not><isset property="have-fx-ant-api-1.2"/></not>
+ </and>
+ </condition>
+ <fail message="Error: JavaFX SDK version 2.2 or newer is needed to deploy FX-in-Swing on JDK without JavaScript support."
+ if="fail-deploy-swing-possible"/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK no html template -->
+ <target name="-fallback-deploy-app-sign-nopreloader-notemplate" depends="-check-sign" if="sign-nopreloader-notemplate" unless="preloader-app">
+ <echo message="-fallback-deploy-app-sign-nopreloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <deploy-sign/>
+ <fallback-deploy-deploy/>
+ </target>
+
+ <!-- FALLBACK project with preloader -->
+ <!-- FALLBACK no html template -->
+ <target name="-fallback-deploy-app-sign-preloader-notemplate" depends="-check-sign" if="sign-preloader-notemplate" unless="preloader-app">
+ <echo message="-fallback-deploy-app-sign-preloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-preloader/>
+ <fallback-deploy-resources-preloader/>
+ <fallback-deploy-jar/>
+ <deploy-sign-preloader/>
+ <fallback-deploy-deploy/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK html template -->
+ <target name="-fallback-deploy-app-sign-nopreloader-template" depends="-check-sign" if="sign-nopreloader-template" unless="preloader-app">
+ <echo message="-fallback-deploy-app-sign-nopreloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <deploy-sign/>
+ <fallback-deploy-deploy-template/>
+ </target>
+
+ <!-- FALLBACK project with preloader -->
+ <!-- FALLBACK html template -->
+ <target name="-fallback-deploy-app-sign-preloader-template" depends="-check-sign" if="sign-preloader-template" unless="preloader-app">
+ <echo message="-fallback-deploy-app-sign-preloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-preloader/>
+ <fallback-deploy-resources-preloader/>
+ <fallback-deploy-jar/>
+ <deploy-sign-preloader/>
+ <fallback-deploy-deploy-template/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK no html template -->
+ <!-- FALLBACK FX in Swing app -->
+ <target name="-fallback-deploy-app-sign-nopreloader-notemplate-swing" depends="-check-fallback-sign-deploy-swing-possible" if="sign-nopreloader-notemplate-swing" unless="preloader-app-no-workaround">
+ <echo message="-fallback-deploy-app-sign-nopreloader-notemplate-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-swing/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <deploy-sign/>
+ <fallback-deploy-deploy/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK html template -->
+ <!-- FALLBACK FX in Swing app -->
+ <target name="-fallback-deploy-app-sign-nopreloader-template-swing" depends="-check-fallback-sign-deploy-swing-possible" if="sign-nopreloader-template-swing" unless="preloader-app-no-workaround">
+ <echo message="-fallback-deploy-app-sign-nopreloader-template-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-swing/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <deploy-sign/>
+ <fallback-deploy-deploy-template/>
+ </target>
+
+
+ <!-- FALLBACK (NO JAVASCRIPT) TARGETS NO SIGNING -->
+
+ <target name="-check-fallback-nosign-deploy-swing-possible" depends="-check-nosign">
+ <local name="fail-deploy-swing-possible"/>
+ <condition property="fail-deploy-swing-possible">
+ <and>
+ <or>
+ <isset property="nosign-nopreloader-notemplate-swing"/>
+ <isset property="nosign-nopreloader-template-swing"/>
+ </or>
+ <not><isset property="have-fx-ant-api-1.2"/></not>
+ </and>
+ </condition>
+ <fail message="Error: JavaFX SDK version 2.2 or newer is needed to deploy FX-in-Swing on JDK without JavaScript support."
+ if="fail-deploy-swing-possible"/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK no html template -->
+ <target name="-fallback-deploy-app-nosign-nopreloader-notemplate" depends="-check-nosign" if="nosign-nopreloader-notemplate" unless="preloader-app">
+ <echo message="-fallback-deploy-app-nosign-nopreloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <fallback-deploy-deploy/>
+ </target>
+
+ <!-- FALLBACK project with preloader -->
+ <!-- FALLBACK no html template -->
+ <target name="-fallback-deploy-app-nosign-preloader-notemplate" depends="-check-nosign" if="nosign-preloader-notemplate" unless="preloader-app">
+ <echo message="-fallback-deploy-app-nosign-preloader-notemplate" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-preloader/>
+ <fallback-deploy-resources-preloader/>
+ <fallback-deploy-jar/>
+ <fallback-deploy-deploy/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK html template -->
+ <target name="-fallback-deploy-app-nosign-nopreloader-template" depends="-check-nosign" if="nosign-nopreloader-template" unless="preloader-app">
+ <echo message="-fallback-deploy-app-nosign-nopreloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <fallback-deploy-deploy-template/>
+ </target>
+
+ <!-- FALLBACK project with preloader -->
+ <!-- FALLBACK html template -->
+ <target name="-fallback-deploy-app-nosign-preloader-template" depends="-check-nosign" if="nosign-preloader-template" unless="preloader-app">
+ <echo message="-fallback-deploy-app-nosign-preloader-template" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-preloader/>
+ <fallback-deploy-resources-preloader/>
+ <fallback-deploy-jar/>
+ <fallback-deploy-deploy-template/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK no html template -->
+ <!-- FALLBACK FX in Swing app -->
+ <target name="-fallback-deploy-app-nosign-nopreloader-notemplate-swing" depends="-check-fallback-nosign-deploy-swing-possible" if="nosign-nopreloader-notemplate-swing" unless="preloader-app-no-workaround">
+ <echo message="-fallback-deploy-app-nosign-nopreloader-notemplate-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-swing/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <fallback-deploy-deploy/>
+ </target>
+
+ <!-- FALLBACK project without preloader -->
+ <!-- FALLBACK html template -->
+ <!-- FALLBACK FX in Swing app -->
+ <target name="-fallback-deploy-app-nosign-nopreloader-template-swing" depends="-check-fallback-nosign-deploy-swing-possible" if="nosign-nopreloader-template-swing" unless="preloader-app-no-workaround">
+ <echo message="-fallback-deploy-app-nosign-nopreloader-template-swing" level="verbose"/>
+ <deploy-defines/>
+ <deploy-preprocess/>
+ <fallback-deploy-application-def-swing/>
+ <fallback-deploy-resources/>
+ <fallback-deploy-jar/>
+ <fallback-deploy-deploy-template/>
+ </target>
+
+
+ <!-- Project Build Targets -->
+
+ <target name="jfx-build" depends="-jfx-do-compile, -jfx-do-jar, -jfx-do-post-jar"/>
+ <target name="jfx-build-noscript" depends="-set-fallback-no-javascript, -jfx-do-compile, -jfx-do-jar, -jfx-do-post-jar"/>
+
+ <target name="jfx-rebuild" depends="clean, -jfx-do-compile, -jfx-do-jar, -jfx-do-post-jar"/>
+ <target name="jfx-rebuild-noscript" depends="-set-fallback-no-javascript, clean, -jfx-do-compile, -jfx-do-jar, -jfx-do-post-jar"/>
+
+ <target name="jfx-build-native" depends="-set-do-build-native-package, -check-ant-jre-supports-native-packaging, -check-native-packager-external-tools, jfx-rebuild"/>
+ <target name="jfx-build-native-noscript" depends="-set-do-build-native-package, -check-ant-jre-supports-native-packaging, -check-native-packager-external-tools, jfx-rebuild-noscript"/>
+
+ <target name="-check-do-jar">
+ <condition property="do-jar-false">
+ <and>
+ <isset property="do.jar"/>
+ <equals arg1="${do.jar}" arg2="false"/>
+ </and>
+ </condition>
+ </target>
+ <target name="-set-fallback-no-javascript">
+ <property name="fallback.no.javascript" value="true"/>
+ <echo message="Warning: Using fallback build infrastructure due to default JDK missing JavaScript support."/>
+ </target>
+ <target name="-jfx-do-compile" depends="-check-do-jar" if="do-jar-false">
+ <antcall target="compile"/>
+ </target>
+ <target name="-jfx-do-jar" depends="-check-do-jar" unless="do-jar-false">
+ <antcall target="jar"/>
+ </target>
+ <target name="-jfx-do-post-jar" depends="-init-check,-check-project" if="preloader-app">
+ <!-- Preloaders are created using SE copylibs task that creates readme file relevant for SE only -->
+ <delete file="${basedir}${file.separator}${dist.dir}${file.separator}README.TXT"/>
+ </target>
+
+ <target name="-set-do-build-native-package">
+ <property name="do.build.native.package" value="true"/>
+ <echo message="do.build.native.package = ${do.build.native.package}" level="verbose"/>
+ </target>
+ <target name="-check-ant-jre-supports-native-packaging" depends="-check-ant-jre-version">
+ <fail message="Error:${line.separator}JavaFX native packager requires NetBeans to run on JDK 1.7u6 or later !" if="have-ant-jre-pre7u6"/>
+ </target>
+
+ <target name="-call-pre-jfx-native" if="do.build.native.package">
+ <antcall target="-pre-jfx-native"/>
+ </target>
+ <target name="-call-post-jfx-native" if="do.build.native.package">
+ <antcall target="-post-jfx-native"/>
+ </target>
+
+ <target name="-check-native-bundling-type" depends="-check-operating-system" if="do.build.native.package">
+ <condition property="need.Inno.presence">
+ <and>
+ <isset property="running.on.windows"/>
+ <isset property="javafx.native.bundling.type"/>
+ <or>
+ <equals arg1="${javafx.native.bundling.type}" arg2="all" casesensitive="false"/>
+ <equals arg1="${javafx.native.bundling.type}" arg2="installer" casesensitive="false"/>
+ </or>
+ </and>
+ </condition>
+ <condition property="need.WiX.presence">
+ <and>
+ <isset property="running.on.windows"/>
+ <isset property="javafx.native.bundling.type"/>
+ <or>
+ <equals arg1="${javafx.native.bundling.type}" arg2="all" casesensitive="false"/>
+ <equals arg1="${javafx.native.bundling.type}" arg2="installer" casesensitive="false"/>
+ </or>
+ </and>
+ </condition>
+ <echo message="need.Inno.presence:${need.Inno.presence}" level="verbose"/>
+ <echo message="need.WiX.presence:${need.WiX.presence}" level="verbose"/>
+ </target>
+ <target name="-check-Inno-presence" depends="-check-native-bundling-type" if="need.Inno.presence">
+ <local name="exec-output"/>
+ <local name="exec-error"/>
+ <local name="exec-result"/>
+ <exec executable="iscc" outputproperty="exec-output" failifexecutionfails="false" errorproperty="exec-error" resultproperty="exec-result"/>
+ <echo message="exec-output:${exec-output}" level="verbose"/>
+ <echo message="exec-error:${exec-error}" level="verbose"/>
+ <echo message="exec-result:${exec-result}" level="verbose"/>
+ <condition property="missing.Inno">
+ <not><and>
+ <contains string="${exec-output}" substring="Inno Setup"/>
+ <not><contains string="${exec-output}" substring="Inno Setup 1"/></not>
+ <not><contains string="${exec-output}" substring="Inno Setup 2"/></not>
+ <not><contains string="${exec-output}" substring="Inno Setup 3"/></not>
+ <not><contains string="${exec-output}" substring="Inno Setup 4"/></not>
+ </and></not>
+ </condition>
+ </target>
+ <target name="-check-WiX-presence" depends="-check-native-bundling-type" if="need.WiX.presence">
+ <local name="exec-output"/>
+ <local name="exec-error"/>
+ <local name="exec-result"/>
+ <exec executable="candle" outputproperty="exec-output" failifexecutionfails="false" errorproperty="exec-error" resultproperty="exec-result">
+ <arg value="-?"/>
+ </exec>
+ <echo message="exec-output:${exec-output}" level="verbose"/>
+ <echo message="exec-error:${exec-error}" level="verbose"/>
+ <echo message="exec-result:${exec-result}" level="verbose"/>
+ <condition property="missing.WiX">
+ <not><and>
+ <contains string="${exec-output}" substring="Windows Installer Xml Compiler version"/>
+ <not><contains string="${exec-output}" substring="Windows Installer Xml Compiler version 1"/></not>
+ <not><contains string="${exec-output}" substring="Windows Installer Xml Compiler version 2"/></not>
+ </and></not>
+ </condition>
+ </target>
+ <target name="-check-native-packager-external-tools" depends="-check-Inno-presence, -check-WiX-presence">
+ <property name="missing.Inno.message" value="JavaFX native packager requires external Inno Setup 5+ tools installed and included on PATH. See http://www.jrsoftware.org/"/>
+ <property name="missing.WiX.message" value="JavaFX native packager requires external WiX 3.0+ tools installed and included on PATH. See http://wix.sourceforge.net/"/>
+ <condition property="missing.Inno.WiX">
+ <and>
+ <isset property="missing.Inno"/>
+ <isset property="missing.WiX"/>
+ </and>
+ </condition>
+ <fail message="Error:${line.separator}${missing.Inno.message}${line.separator}${missing.WiX.message}" if="missing.Inno.WiX"/>
+ <fail message="Error:${line.separator}${missing.Inno.message}" if="missing.Inno"/>
+ <fail message="Error:${line.separator}${missing.WiX.message}" if="missing.WiX"/>
+ </target>
+
+ <!-- Project Run Support -->
+
+ <target name="-warn-of-preloader" depends="-check-project" if="preloader-app-no-workaround">
+ <fail message="Error:${line.separator}JavaFX 2 Preloader Project can not be executed directly.${line.separator}Please execute instead a JavaFX Application that uses the Preloader."/>
+ </target>
+
+ <target name="-mark-project-state-running">
+ <property name="project.state.running" value="true"/>
+ <echo message="project.state.running = ${project.state.running}" level="verbose"/>
+ </target>
+ <target name="-mark-project-state-debugging">
+ <property name="project.state.debugging" value="true"/>
+ <echo message="project.state.debugging = ${project.state.debugging}" level="verbose"/>
+ </target>
+ <target name="-mark-project-state-profiling">
+ <property name="project.state.profiling" value="true"/>
+ <echo message="project.state.profiling = ${project.state.profiling}" level="verbose"/>
+ </target>
+ <target name="-mark-project-needs-jnlp">
+ <property name="project.needs.jnlp" value="true"/>
+ <echo message="project.needs.jnlp = ${project.needs.jnlp}" level="verbose"/>
+ </target>
+
+ <!-- set property javafx.disable.concurrent.runs=true to disable runs from temporary directory -->
+ <target name="-check-concurrent-runs">
+ <condition property="disable-concurrent-runs">
+ <and>
+ <isset property="javafx.disable.concurrent.runs"/>
+ <equals arg1="${javafx.disable.concurrent.runs}" arg2="true" trim="true"/>
+ </and>
+ </condition>
+ <condition property="temp.run.jar" value="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}">
+ <isset property="disable-concurrent-runs"/>
+ </condition>
+ <condition property="temp.run.jnlp" value="${jfx.deployment.jnlp}">
+ <isset property="disable-concurrent-runs"/>
+ </condition>
+ <condition property="temp.run.html" value="${jfx.deployment.html}">
+ <isset property="disable-concurrent-runs"/>
+ </condition>
+ </target>
+ <target name="-create-temp-run-dir" depends="-check-concurrent-runs" unless="disable-concurrent-runs">
+ <echo message="Creating temp run dir" level="verbose"/>
+ <tempfile property="temp.run.dir" destDir="${basedir}${file.separator}${dist.dir}${file.separator}" prefix="run"/>
+ <echo message="temp.run.dir = ${temp.run.dir}" level="verbose"/>
+ <copy todir="${temp.run.dir}" includeemptydirs="true" overwrite="true">
+ <fileset dir="${basedir}${file.separator}${dist.dir}">
+ <exclude name="**${file.separator}bundles${file.separator}**"/>
+ <exclude name="**${file.separator}run*${file.separator}**"/>
+ </fileset>
+ </copy>
+ <property name="temp.run.jar" value="${temp.run.dir}${file.separator}${jfx.deployment.jar}"/>
+ <basename property="jfx.deployment.base" file="${jfx.deployment.jar}" suffix=".jar"/>
+ <property name="temp.run.jnlp" value="${temp.run.dir}${file.separator}${jfx.deployment.base}.jnlp"/>
+ <property name="temp.run.html" value="${temp.run.dir}${file.separator}${jfx.deployment.base}.html"/>
+ </target>
+ <target name="-remove-temp-run-dir" if="temp.run.dir">
+ <echo message="Removing temp run dir" level="verbose"/>
+ <delete dir="${temp.run.dir}" quiet="true" failonerror="false"/>
+ </target>
+ <target depends="init,compile,jar,-create-temp-run-dir" description="Run JavaFX project standalone." name="jfx-project-run">
+ <echo message="Executing ${main.class} from ${temp.run.jar} using platform ${platform.java}"/>
+ <property name="run.jvmargs" value=""/>
+ <property name="run.jvmargs.ide" value=""/>
+ <java classname="${main.class}" dir="${work.dir}" fork="true" jvm="${platform.java}">
+ <jvmarg line="${endorsed.classpath.cmd.line.arg}"/>
+ <jvmarg value="-Dfile.encoding=${runtime.encoding}"/>
+ <redirector errorencoding="${runtime.encoding}" inputencoding="${runtime.encoding}" outputencoding="${runtime.encoding}"/>
+ <jvmarg line="${run.jvmargs}"/>
+ <jvmarg line="${run.jvmargs.ide}"/>
+ <classpath>
+ <path path="${temp.run.jar}:${javac.classpath}"/>
+ </classpath>
+ <arg line="${application.args}"/>
+ <syspropertyset>
+ <propertyref prefix="run-sys-prop."/>
+ <mapper from="run-sys-prop.*" to="*" type="glob"/>
+ </syspropertyset>
+ </java>
+ <antcall target="-remove-temp-run-dir"/>
+ </target>
+
+
+ <!-- Running/Debugging/Profiling Standalone -->
+
+ <target name="jfxsa-run" depends="-mark-project-state-running,-clean-if-config-changed,-check-jfx-runtime,-warn-of-preloader,jfx-project-run"/>
+ <target name="jfxsa-run-noscript" depends="-set-fallback-no-javascript, jfxsa-run"/>
+
+ <target name="jfxsa-debug" depends="-mark-project-state-debugging,-clean-if-config-changed,jar,-check-jfx-runtime,-warn-of-preloader,debug"/>
+ <target name="jfxsa-debug-noscript" depends="-set-fallback-no-javascript, jfxsa-debug"/>
+
+ <target name="jfxsa-profile" depends="-mark-project-state-profiling,-check-jfx-runtime,-warn-of-preloader,profile"/>
+ <target name="jfxsa-profile-noscript" depends="-set-fallback-no-javascript, jfxsa-profile"/>
+
+ <target name="-check-clean-if-config-changed" depends="-init-project">
+ <deploy-defines/>
+ <uptodate property="jfx.deployment.jar.newer.than.nbproject" targetfile="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}" >
+ <srcfiles dir="${basedir}${file.separator}nbproject" includes="**${file.separator}*"/>
+ </uptodate>
+ <echo message="jfx.deployment.jar.newer.than.nbproject = ${jfx.deployment.jar.newer.than.nbproject}" level="verbose"/>
+ <available file="${jfx.deployment.dir}${file.separator}${jfx.deployment.jar}" type="file" property="jfx.deployment.jar.exists"/>
+ <condition property="request.clean.due.to.config.change">
+ <and>
+ <isset property="jfx.deployment.jar.exists"/>
+ <not><isset property="jfx.deployment.jar.newer.than.nbproject"/></not>
+ </and>
+ </condition>
+ </target>
+ <target name="-clean-if-config-changed" depends="-check-clean-if-config-changed" if="request.clean.due.to.config.change">
+ <echo message="Config change detected. Invoking clean." level="verbose"/>
+ <antcall target="clean"/>
+ </target>
+
+
+ <!-- Shared Debugging init -->
+
+ <target name="-init-debug-args">
+ <property name="version-output" value="java version "${ant.java.version}"/>
+ <condition property="have-jdk-older-than-1.4">
+ <or>
+ <contains string="${version-output}" substring="java version "1.0"/>
+ <contains string="${version-output}" substring="java version "1.1"/>
+ <contains string="${version-output}" substring="java version "1.2"/>
+ <contains string="${version-output}" substring="java version "1.3"/>
+ </or>
+ </condition>
+ <condition else="-Xdebug" property="debug-args-line" value="-Xdebug -Xnoagent -Djava.compiler=none">
+ <istrue value="${have-jdk-older-than-1.4}"/>
+ </condition>
+ <condition else="dt_socket" property="debug-transport-by-os" value="dt_shmem">
+ <os family="windows"/>
+ </condition>
+ <condition else="${debug-transport-by-os}" property="debug-transport" value="${debug.transport}">
+ <isset property="debug.transport"/>
+ </condition>
+ </target>
+
+
+ <!-- Running/Debugging/Profiling as WebStart -->
+
+ <target name="-check-jnlp-file-fx" depends="-swing-api-check" unless="fx-in-swing-app-workaround">
+ <basename property="jfx.deployment.base" file="${jfx.deployment.jar}" suffix=".jar"/>
+ <property name="jfx.deployment.jnlp" location="${jfx.deployment.dir}${file.separator}${jfx.deployment.base}.jnlp"/>
+ </target>
+ <target name="-check-jnlp-file-swing" depends="-swing-api-check" if="fx-in-swing-app-workaround">
+ <basename property="jfx.deployment.base" file="${jfx.deployment.jar}" suffix=".jar"/>
+ <property name="jfx.deployment.jnlp" location="${jfx.deployment.dir}${file.separator}${jfx.deployment.base}_application.jnlp"/>
+ </target>
+ <target name="-check-jnlp-file" depends="-check-jnlp-file-fx,-check-jnlp-file-swing">
+ <condition property="jnlp-file-exists">
+ <available file="${jfx.deployment.jnlp}"/>
+ </condition>
+ <condition property="jnlp-file-exists+netbeans.home">
+ <and>
+ <isset property="jnlp-file-exists"/>
+ <isset property="netbeans.home"/>
+ </and>
+ </condition>
+ </target>
+
+ <target name="-resolve-jnlp-file" depends="-check-jnlp-file" unless="jnlp-file-exists">
+ <antcall target="jfx-deployment"/>
+ <antcall target="-check-jnlp-file"/>
+ </target>
+
+ <!-- set property javafx.enable.concurrent.external.runs=true to enable multiple runs of the same WebStart or Run-in-Browser project -->
+ <target name="-check-concurrent-jnlp-runs" depends="-resolve-jnlp-file">
+ <condition property="disable-concurrent-runs">
+ <not>
+ <and>
+ <isset property="javafx.enable.concurrent.external.runs"/>
+ <equals arg1="${javafx.enable.concurrent.external.runs}" arg2="true" trim="true"/>
+ </and>
+ </not>
+ </condition>
+ <condition property="temp.run.jnlp" value="${jfx.deployment.jnlp}">
+ <isset property="disable-concurrent-runs"/>
+ </condition>
+ </target>
+ <target name="-warn-concurrent-jnlp-runs" unless="disable-concurrent-runs">
+ <echo message="Note: Concurrent Run as WebStart enabled.${line.separator}Temporary directory ${temp.run.dir}${line.separator}will remain unused when WebStart execution has finished. Use project Clean to delete unused directories."/>
+ </target>
+
+ <target name="jfxws-run" if="jnlp-file-exists" depends="-mark-project-state-running,-clean-if-config-changed,-mark-project-needs-jnlp,-check-jdk-7u4or5-mac,jar,
+ -check-jfx-webstart,-resolve-jnlp-file,-check-jfx-runtime,-check-concurrent-jnlp-runs,-create-temp-run-dir"
+ description="Start JavaFX javaws execution">
+ <echo message="Executing ${temp.run.jnlp} using ${active.webstart.executable}"/>
+ <exec executable="${active.webstart.executable}">
+ <arg file="${temp.run.jnlp}"/>
+ </exec>
+ <antcall target="-warn-concurrent-jnlp-runs"/>
+ </target>
+
+ <target name="jfxws-debug" if="jnlp-file-exists+netbeans.home" depends="-mark-project-state-debugging,-clean-if-config-changed,-mark-project-needs-jnlp,
+ -check-jdk-7u4or5-mac,jar,-check-jfx-webstart,-resolve-jnlp-file,-check-jfx-runtime,
+ -debug-start-debugger,-debug-javaws-debuggee" description="Debug JavaFX javaws project in IDE"/>
+
+ <target name="-debug-javaws-debuggee" depends="-init-debug-args">
+ <echo message="Executing ${jfx.deployment.jnlp} in debug mode using ${active.webstart.executable}"/>
+ <exec executable="${active.webstart.executable}">
+ <env key="JAVAWS_VM_ARGS" value="${debug-args-line} -Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/>
+ <arg value="-wait"/>
+ <arg file="${jfx.deployment.jnlp}"/>
+ </exec>
+ </target>
+
+ <target name="-profile-check-1">
+ <property name="run.jvmargs.ide" value=""/>
+ <condition property="profiler.configured">
+ <or>
+ <contains casesensitive="true" string="${run.jvmargs.ide}" substring="-agentpath:"/>
+ <contains casesensitive="true" string="${run.jvmargs.ide}" substring="-javaagent:"/>
+ </or>
+ </condition>
+ </target>
+
+ <target if="jnlp-file-exists+netbeans.home" name="-profile-check-jnlp">
+ <antcall target="-profile-check-1"/>
+ </target>
+
+ <target name="-do-jfxws-profile" depends="-mark-project-state-profiling,-mark-project-needs-jnlp,
+ -check-jdk-7u4or5-mac,jar,-check-jfx-webstart,-resolve-jnlp-file,-check-jfx-runtime">
+ <echo message="Executing ${jfx.deployment.jnlp} in profile mode using ${active.webstart.executable}"/>
+ <property name="run.jvmargs.ide" value=""/>
+ <exec executable="${active.webstart.executable}">
+ <env key="JAVAWS_VM_ARGS" value="${run.jvmargs.ide}"/>
+ <arg value="-wait"/>
+ <arg file="${jfx.deployment.jnlp}"/>
+ </exec>
+ </target>
+
+ <target name="jfxws-profile" if="profiler.configured"
+ depends="-profile-check-1"
+ description="Profile JavaFX javaws project in IDE">
+ <startprofiler/>
+ <antcall target="-do-jfxws-profile"/>
+ </target>
+
+ <target name="jfxws-run-noscript" depends="-set-fallback-no-javascript, jfxws-run"/>
+
+ <target name="jfxws-debug-noscript" depends="-set-fallback-no-javascript, jfxws-debug"/>
+
+ <target name="jfxws-profile-noscript" depends="-set-fallback-no-javascript, jfxws-profile"/>
+
+
+ <!-- Running/Debugging/Profiling in Browser -->
+
+ <target name="-check-selected-browser-path" depends="-check-default-run-config">
+ <condition property="javafx.run.inbrowser.undefined">
+ <or>
+ <and>
+ <isset property="javafx.run.inbrowser"/>
+ <equals arg1="${javafx.run.inbrowser}" arg2="undefined"/>
+ </and>
+ <and>
+ <isset property="javafx.run.inbrowser.path"/>
+ <equals arg1="${javafx.run.inbrowser.path}" arg2="undefined"/>
+ </and>
+ </or>
+ </condition>
+ <condition property="javafx.run.inbrowser.path-exists">
+ <and>
+ <isset property="javafx.run.inbrowser.path"/>
+ <available file="${javafx.run.inbrowser.path}"/>
+ </and>
+ </condition>
+ <fail message="Error:${line.separator}Browser selection not recognizable from ${config} run configuration.${line.separator}Please go to Project Properties dialog, category Run, to select a valid browser." unless="javafx.run.inbrowser.path"/>
+ <fail message="Error:${line.separator}No browser defined in ${config} run configuration.${line.separator}Please verify in Tools->Options dialog that NetBeans recognizes a valid browser, then go to Project Properties dialog, category Run, to select a valid browser." if="javafx.run.inbrowser.undefined"/>
+ <fail message="Error:${line.separator}Browser ${javafx.run.inbrowser.path} referred from ${config} run configuration can not be found.${line.separator}(This can happen, e.g, when the JavaFX Project is transferred to another system.)${line.separator}Please go to Project Properties dialog, category Run, to select a valid browser." unless="javafx.run.inbrowser.path-exists"/>
+ </target>
+
+ <target name="-substitute-template-processed-html-file" depends="-check-project" if="html-template-available">
+ <deploy-process-template/>
+ </target>
+ <target name="-check-template-processed-html-file" depends="-substitute-template-processed-html-file">
+ <condition property="html-file-exists">
+ <and>
+ <isset property="html-template-available"/>
+ <available file="${javafx.run.htmltemplate.processed}"/>
+ </and>
+ </condition>
+ </target>
+
+ <target name="-set-template-processed-html-file" depends="-check-template-processed-html-file" if="html-file-exists">
+ <property name="jfx.deployment.html" location="${javafx.run.htmltemplate.processed}"/>
+ </target>
+
+ <target name="-set-html-file" depends="-set-template-processed-html-file" unless="html-file-exists">
+ <basename property="jfx.deployment.base" file="${jfx.deployment.jar}" suffix=".jar"/>
+ <property name="jfx.deployment.html" location="${jfx.deployment.dir}${file.separator}${jfx.deployment.base}.html"/>
+ <condition property="html-file-exists">
+ <available file="${jfx.deployment.html}"/>
+ </condition>
+ <condition property="html-file-exists+netbeans.home">
+ <and>
+ <isset property="html-file-exists"/>
+ <isset property="netbeans.home"/>
+ </and>
+ </condition>
+ </target>
+
+ <!-- set property javafx.enable.concurrent.external.runs=true to enable multiple runs of the same WebStart or Run-in-Browser project -->
+ <target name="-check-concurrent-html-runs" depends="-set-html-file">
+ <condition property="disable-concurrent-runs">
+ <or>
+ <not>
+ <and>
+ <isset property="javafx.enable.concurrent.external.runs"/>
+ <equals arg1="${javafx.enable.concurrent.external.runs}" arg2="true" trim="true"/>
+ </and>
+ </not>
+ <and>
+ <isset property="html-template-available"/>
+ <available file="${javafx.run.htmltemplate.processed}"/>
+ </and>
+ </or>
+ </condition>
+ <condition property="temp.run.html" value="${jfx.deployment.html}">
+ <isset property="disable-concurrent-runs"/>
+ </condition>
+ </target>
+ <target name="-warn-concurrent-html-runs" unless="disable-concurrent-runs">
+ <echo message="Note: Concurrent Run in Browser enabled.${line.separator}Temporary directory ${temp.run.dir}${line.separator}will remain unused when execution in browser has finished. Use project Clean to delete unused directories."/>
+ </target>
+
+ <target name="jfxbe-run" if="html-file-exists" depends="-mark-project-state-running,-clean-if-config-changed,-mark-project-needs-jnlp,-check-jdk-7u4or5-mac,jar,
+ -check-selected-browser-path,-set-html-file,-check-jfx-runtime,-check-concurrent-html-runs,-create-temp-run-dir"
+ description="Start JavaFX execution in browser">
+ <echo message="Executing ${temp.run.html} using ${javafx.run.inbrowser}"/>
+ <echo message="(${javafx.run.inbrowser.path})"/>
+ <exec executable="${javafx.run.inbrowser.path}">
+ <arg file="${temp.run.html}"/>
+ </exec>
+ <antcall target="-warn-concurrent-html-runs"/>
+ </target>
+
+ <target name="jfxbe-debug" if="html-file-exists+netbeans.home" depends="-mark-project-state-debugging,-clean-if-config-changed,-mark-project-needs-jnlp,
+ -check-jdk-7u4or5-mac,jar,-check-selected-browser-path,-set-html-file,-check-jfx-runtime,
+ -debug-start-debugger,-debug-jfxbe-debuggee" description="Debug JavaFX project in browser"/>
+
+ <target name="-debug-jfxbe-debuggee" depends="-init-debug-args">
+ <echo message="Executing ${jfx.deployment.html} in debug mode using ${javafx.run.inbrowser}"/>
+ <echo message="(${javafx.run.inbrowser.path})"/>
+ <exec executable="${javafx.run.inbrowser.path}">
+ <env key="_JPI_VM_OPTIONS" value="${debug-args-line} -Xrunjdwp:transport=${debug-transport},address=${jpda.address}"/>
+ <arg file="${jfx.deployment.html}"/>
+ </exec>
+ </target>
+
+ <target if="html-file-exists+netbeans.home" name="-profile-check-html">
+ <antcall target="-profile-check-1"/>
+ </target>
+
+ <target name="-do-jfxbe-profile" depends="-mark-project-state-profiling,-mark-project-needs-jnlp,
+ -check-jdk-7u4or5-mac,jar,-check-selected-browser-path,-set-html-file,-check-jfx-runtime">
+ <echo message="Executing ${jfx.deployment.html} in profile mode using ${javafx.run.inbrowser}"/>
+ <echo message="(${javafx.run.inbrowser.path})"/>
+ <property name="run.jvmargs.ide" value=""/>
+ <exec executable="${javafx.run.inbrowser.path}">
+ <env key="_JPI_VM_OPTIONS" value="${run.jvmargs.ide}"/>
+ <arg file="${jfx.deployment.html}"/>
+ </exec>
+ </target>
+
+ <target name="jfxbe-profile" if="profiler.configured"
+ depends="-profile-check-html"
+ description="Profile JavaFX project in browser">
+ <startprofiler/>
+ <antcall target="-do-jfxbe-profile"/>
+ </target>
+
+ <target name="jfxbe-run-noscript" depends="-set-fallback-no-javascript, jfxbe-run"/>
+
+ <target name="jfxbe-debug-noscript" depends="-set-fallback-no-javascript, jfxbe-debug"/>
+
+ <target name="jfxbe-profile-noscript" depends="-set-fallback-no-javascript, jfxbe-profile"/>
+
+
+</project>
--- /dev/null
+project.DuskServer=../DuskServer
+project.DuskZ=../DuskZ
+project.license=gpl30
+annotation.processing.enabled=true
+annotation.processing.enabled.in.editor=false
+annotation.processing.processors.list=
+annotation.processing.run.all.processors=true
+annotation.processing.source.output=${build.generated.sources.dir}/ap-source-output
+application.title=TileZ
+application.vendor=Michael Zucchi
+build.classes.dir=${build.dir}/classes
+build.classes.excludes=**/*.java,**/*.form
+# This directory is removed when the project is cleaned:
+build.dir=build
+build.generated.dir=${build.dir}/generated
+build.generated.sources.dir=${build.dir}/generated-sources
+# Only compile against the classpath explicitly listed here:
+build.sysclasspath=ignore
+build.test.classes.dir=${build.dir}/test/classes
+build.test.results.dir=${build.dir}/test/results
+compile.on.save=true
+compile.on.save.unsupported.javafx=true
+# Uncomment to specify the preferred debugger connection transport:
+#debug.transport=dt_socket
+debug.classpath=\
+ ${run.classpath}
+debug.test.classpath=\
+ ${run.test.classpath}
+# This directory is removed when the project is cleaned:
+dist.dir=dist
+dist.jar=${dist.dir}/TileZ.jar
+dist.javadoc.dir=${dist.dir}/javadoc
+endorsed.classpath=
+excludes=
+includes=**
+# Non-JavaFX jar file creation is deactivated in JavaFX 2.0+ projects
+jar.archive.disabled=true
+jar.compress=false
+javac.classpath=\
+ ${javafx.runtime}/lib/jfxrt.jar:\
+ ${javafx.runtime}/lib/deploy.jar:\
+ ${javafx.runtime}/lib/javaws.jar:\
+ ${javafx.runtime}/lib/plugin.jar:\
+ ${reference.DuskServer.jar}:\
+ ${reference.DuskZ.jar}
+# Space-separated list of extra javac options
+javac.compilerargs=
+javac.deprecation=false
+javac.processorpath=\
+ ${javac.classpath}
+javac.source=1.7
+javac.target=1.7
+javac.test.classpath=\
+ ${javac.classpath}:\
+ ${build.classes.dir}
+javac.test.processorpath=\
+ ${javac.test.classpath}
+javadoc.additionalparam=
+javadoc.author=false
+javadoc.encoding=${source.encoding}
+javadoc.noindex=false
+javadoc.nonavbar=false
+javadoc.notree=false
+javadoc.private=false
+javadoc.splitindex=true
+javadoc.use=true
+javadoc.version=false
+javadoc.windowtitle=
+javafx.binarycss=false
+javafx.deploy.adddesktopshortcut=false
+javafx.deploy.addstartmenushortcut=false
+javafx.deploy.allowoffline=true
+# If true, application update mode is set to 'background', if false, update mode is set to 'eager'
+javafx.deploy.backgroundupdate=false
+javafx.deploy.embedJNLP=true
+javafx.deploy.includeDT=true
+javafx.deploy.installpermanently=false
+javafx.deploy.permissionselevated=false
+# Set true to prevent creation of temporary copy of deployment artifacts before each run (disables concurrent runs)
+javafx.disable.concurrent.runs=false
+# Set true to enable multiple concurrent runs of the same WebStart or Run-in-Browser project
+javafx.enable.concurrent.external.runs=false
+# This is a JavaFX project
+javafx.enabled=true
+javafx.fallback.class=com.javafx.main.NoJavaFXFallback
+# Main class for JavaFX
+javafx.main.class=au.notzed.tilez.TileZ
+javafx.native.bundling.enabled=false
+javafx.native.bundling.type=none
+javafx.preloader.class=
+# This project does not use Preloader
+javafx.preloader.enabled=false
+javafx.preloader.jar.filename=
+javafx.preloader.jar.path=
+javafx.preloader.project.path=
+javafx.preloader.type=none
+# Set true for GlassFish only. Rebases manifest classpaths of JARs in lib dir. Not usable with signed JARs.
+javafx.rebase.libs=false
+javafx.run.height=600
+javafx.run.width=800
+javafx.runtime=${platforms.Default_JavaFX_Platform.javafx.runtime.home}
+javafx.sdk=${platforms.Default_JavaFX_Platform.javafx.sdk.home}
+javafx.signing.enabled=false
+javafx.signing.type=notsigned
+# Pre-JavaFX 2.0 WebStart is deactivated in JavaFX 2.0+ projects
+jnlp.enabled=false
+# Main class for Java launcher
+main.class=com.javafx.main.Main
+manifest.file=manifest.mf
+meta.inf.dir=${src.dir}/META-INF
+mkdist.disabled=false
+platform.active=Default_JavaFX_Platform
+reference.DuskServer.jar=${project.DuskServer}/dist/DuskServer.jar
+reference.DuskZ.jar=${project.DuskZ}/dist/DuskZ.jar
+run.classpath=\
+ ${dist.jar}:\
+ ${javac.classpath}
+run.test.classpath=\
+ ${javac.test.classpath}:\
+ ${build.test.classes.dir}
+source.encoding=UTF-8
+src.dir=src
+test.src.dir=test
--- /dev/null
+<?xml version="1.0" encoding="UTF-8"?>
+<project xmlns="http://www.netbeans.org/ns/project/1">
+ <type>org.netbeans.modules.java.j2seproject</type>
+ <configuration>
+ <buildExtensions xmlns="http://www.netbeans.org/ns/ant-build-extender/1">
+ <extension file="jfx-impl.xml" id="jfx">
+ <dependency dependsOn="-check-javafx" target="-init-check"/>
+ <dependency dependsOn="-jfx-copylibs" target="-post-jar"/>
+ <dependency dependsOn="-rebase-libs" target="-post-jar"/>
+ <dependency dependsOn="jfx-deployment" target="-post-jar"/>
+ <dependency dependsOn="jar" target="debug"/>
+ <dependency dependsOn="-jfx-copylibs" target="jar"/>
+ <dependency dependsOn="-rebase-libs" target="jar"/>
+ <dependency dependsOn="jar" target="profile"/>
+ <dependency dependsOn="jar" target="run"/>
+ </extension>
+ </buildExtensions>
+ <data xmlns="http://www.netbeans.org/ns/j2se-project/3">
+ <name>TileZ</name>
+ <explicit-platform explicit-source-supported="true"/>
+ <source-roots>
+ <root id="src.dir"/>
+ </source-roots>
+ <test-roots>
+ <root id="test.src.dir"/>
+ </test-roots>
+ </data>
+ <references xmlns="http://www.netbeans.org/ns/ant-project-references/1">
+ <reference>
+ <foreign-project>DuskServer</foreign-project>
+ <artifact-type>jar</artifact-type>
+ <script>build.xml</script>
+ <target>jar</target>
+ <clean-target>clean</clean-target>
+ <id>jar</id>
+ </reference>
+ <reference>
+ <foreign-project>DuskZ</foreign-project>
+ <artifact-type>jar</artifact-type>
+ <script>build.xml</script>
+ <target>jar</target>
+ <clean-target>clean</clean-target>
+ <id>jar</id>
+ </reference>
+ </references>
+ </configuration>
+</project>
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import java.io.File;
+import java.io.IOException;
+import java.nio.charset.Charset;
+import java.nio.file.Files;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javafx.scene.control.TextArea;
+import javafx.scene.control.TitledPane;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.VBox;
+
+/**
+ * Displays the old dusk format information
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class DuskInfoView extends BorderPane {
+
+ String oldmap = "/home/notzed/src/DuskRPG/DuskFiles/Dusk2.7.3";
+ TextArea action;
+ TextArea able;
+
+ public DuskInfoView() {
+ VBox vbox = new VBox();
+
+ action = new TextArea();
+ able = new TextArea();
+
+ action.setEditable(false);
+ able.setEditable(false);
+
+ vbox.getChildren().addAll(
+ new TitledPane("defMoveActions", action),
+ new TitledPane("defCanMoveScripts", able));
+
+ setCenter(vbox);
+ }
+
+ void set(TextArea text, File path) {
+ if (path.exists()) {
+ try {
+ byte[] data = Files.readAllBytes(path.toPath());
+ String string = new String(data, Charset.defaultCharset()).trim();
+
+ if (!string.equals(""))
+ text.setText(string);
+ else
+ text.setText("<empty file>");
+ } catch (IOException ex) {
+ Logger.getLogger(DuskInfoView.class.getName()).log(Level.SEVERE, null, ex);
+ }
+ } else {
+ text.setText("<nothing to see here>");
+ }
+ }
+
+ public void setLocation(int tx, int ty) {
+ set(action, new File(String.format("%s/defMoveActions/%d_%d", oldmap, tx, ty)));
+ set(able, new File(String.format("%s/defCanMoveScripts/%d_%d", oldmap, tx, ty)));
+ }
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import duskz.server.entityz.TileMap;
+import java.io.IOException;
+import java.nio.charset.Charset;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javafx.beans.property.IntegerProperty;
+import javafx.beans.property.SimpleIntegerProperty;
+import javafx.beans.value.ChangeListener;
+import javafx.beans.value.ObservableValue;
+import javafx.event.ActionEvent;
+import javafx.event.EventHandler;
+import javafx.scene.control.Button;
+import javafx.scene.control.TextArea;
+import javafx.scene.control.TextField;
+import javafx.scene.control.TitledPane;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.GridPane;
+
+/**
+ * Edit various shit at a location.
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class LocationEditor extends BorderPane implements ChangeListener<Number> {
+
+ String game = "/home/notzed/dusk/game";
+ int tx, ty;
+ TileMap map;
+ TextField alias;
+ TextField jumpto;
+ TextField able;
+ TextField action;
+ TextField visible;
+ TextArea ableScript;
+ TextArea actionScript;
+ TextArea visibleScript;
+ IntegerProperty tileX = new SimpleIntegerProperty();
+ IntegerProperty tileY = new SimpleIntegerProperty();
+
+ public LocationEditor() {
+ GridPane main = new GridPane();
+
+ alias = new TextField();
+ jumpto = new TextField();
+ able = new TextField();
+ action = new TextField();
+ visible = new TextField();
+
+ ableScript = new TextArea();
+ actionScript = new TextArea();
+ visibleScript = new TextArea();
+
+ Button aliasb, gotob, ableb, visibleb, actionb;
+ int r = 0;
+
+ TextField location;
+ main.add(new Button("Location"), 0, r);
+ main.add(location = new TextField(), 1, r++);
+ main.add(aliasb = new Button("Alias"), 0, r);
+ main.add(alias, 1, r++);
+ main.add(gotob = new Button("Goto"), 0, r);
+ main.add(jumpto, 1, r++);
+ main.add(actionb = new Button("Action"), 0, r);
+ main.add(action, 1, r++);
+ main.add(new TitledPane("Action Script", actionScript), 0, r++, 2, 1);
+ main.add(ableb = new Button("Able"), 0, r);
+ main.add(able, 1, r++);
+ main.add(new TitledPane("Able Script", ableScript), 0, r++, 2, 1);
+ main.add(visibleb = new Button("Visible"), 0, r);
+ main.add(visible, 1, r++);
+ main.add(new TitledPane("Visible Script", visibleScript), 0, r++, 2, 1);
+
+ location.textProperty().bind(tileX.asString().concat(", ").concat(tileY.asString()));
+
+ aliasb.setOnAction(new EventHandler<ActionEvent>() {
+ public void handle(ActionEvent t) {
+ // save the alias
+ String s = alias.getText();
+
+ if (s == null || (s = s.trim()).equals("")) {
+ // Clear it
+ map.setJumpAlias(tx, ty, null);
+ } else {
+ map.setJumpAlias(tx, ty, s);
+ }
+ }
+ });
+ gotob.setOnAction(new EventHandler<ActionEvent>() {
+ public void handle(ActionEvent t) {
+ // save the alias
+ String s = jumpto.getText();
+
+ if (s == null || (s = s.trim()).equals("")) {
+ // Clear it
+ map.setAlias(tx, ty, null);
+ } else {
+ map.setAlias(tx, ty, s);
+ }
+ }
+ });
+ ableb.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ editScript("onLocationAble", able.getText());
+ }
+ });
+ visibleb.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ editScript("onLocationVisible", visible.getText());
+ }
+ });
+ actionb.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ editScript("onLocationAction", action.getText());
+ }
+ });
+
+ setCenter(main);
+
+ tileX.addListener(this);
+ tileY.addListener(this);
+ }
+
+ void editScript(String type, String name) {
+ if (name == null)
+ return;
+
+ name = name.trim();
+ if (name.equals(""))
+ return;
+
+ try {
+ TextEditor te = new TextEditor();
+ te.setPath(Paths.get("/home/notzed/dusk/game", type, name));
+ te.show();
+ } catch (IOException ex) {
+ Logger.getLogger(LocationEditor.class.getName()).log(Level.SEVERE, null, ex);
+ }
+ /*
+ final Stage win = new Stage();
+ HBox buttons = new HBox();
+ BorderPane root = new BorderPane();
+ TextArea text = new TextArea();
+ text.setPrefRowCount(30);
+ try {
+ byte[] bytes = Files.readAllBytes(Paths.get("/home/notzed/dusk/game", type, name));
+ String string = new String(bytes, Charset.defaultCharset());
+
+ text.setText(string);
+ } catch (IOException ex) {
+ Logger.getLogger(LocationEditor.class.getName()).log(Level.SEVERE, null, ex);
+ }
+
+ Button save, cancel;
+ buttons.getChildren().addAll(cancel = new Button("Cancel"),
+ save = new Button("Save"));
+
+ save.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ }
+ });
+
+ cancel.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ win.close();
+ }
+ });
+
+ root.setCenter(text);
+ root.setTop(buttons);
+ Scene scene = new Scene(root);
+
+ win.setScene(scene);
+
+ win.show();
+ * */
+ }
+
+ public void setMap(TileMap map) {
+ this.map = map;
+ }
+
+ public int getTileX() {
+ return tileX.get();
+ }
+
+ public int getTileY() {
+ return tileY.get();
+ }
+
+ public void setTileX(int tx) {
+ this.tx = tx;
+ tileX.set(tx);
+ }
+
+ public void setTileY(int ty) {
+ this.ty = ty;
+ tileY.set(ty);
+ }
+
+ public IntegerProperty tileXProperty() {
+ return tileX;
+ }
+
+ public IntegerProperty tileYProperty() {
+ return tileY;
+ }
+
+ @Override
+ public void changed(ObservableValue<? extends Number> ov, Number t, Number t1) {
+ updateLocation();
+ }
+
+ void setContent(TextArea text, String type, String name) {
+ if (name == null) {
+ text.setText(null);
+ return;
+ }
+ Path path = Paths.get(game, type, name);
+ if (path.toFile().exists()) {
+ try {
+ text.setText(new String(Files.readAllBytes(path), Charset.defaultCharset()));
+ } catch (IOException ex) {
+ Logger.getLogger(LocationEditor.class.getName()).log(Level.SEVERE, null, ex);
+ }
+ } else {
+ text.setText(null);
+ }
+ }
+
+ void updateLocation() {
+ int tx = getTileX();
+ int ty = getTileY();
+
+ System.out.printf("updating editor for : %d,%d '%s'\n", tx, ty, map.aliasForLocation(tx, ty));
+
+ alias.setText(map.aliasForLocation(tx, ty));
+ jumpto.setText(map.jumpAlias(tx, ty));
+ able.setText(map.locationAbleScript(tx, ty));
+ action.setText(map.locationActionScript(tx, ty));
+ visible.setText(map.locationVisibleScript(tx, ty));
+
+ setContent(visibleScript, "onLocationVisible", visible.getText());
+ setContent(actionScript, "onLocationAction", action.getText());
+ setContent(ableScript, "onLocationAble", able.getText());
+
+ }
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import javafx.geometry.Orientation;
+import javafx.scene.control.ListView;
+import javafx.scene.control.ScrollBar;
+import javafx.scene.control.cell.ComboBoxListCell;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.Pane;
+import javafx.util.Callback;
+
+/**
+ * Layer of a map. i.e. a set of tiles.
+ *
+ * Hmm, should this virtualise it's view?
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class MapLayer extends BorderPane {
+ int[] mapArray;
+ ScrollBar hscroll, vscroll;
+
+ public MapLayer() {
+ hscroll = new ScrollBar();
+ vscroll = new ScrollBar();
+ vscroll.setOrientation(Orientation.VERTICAL);
+
+ setBottom(hscroll);
+ setRight(vscroll);
+ }
+
+
+ void main() {
+ ComboBoxListCell.forListView(null);
+
+ ListView lv = null;
+ lv.setCellFactory(new Callback() {
+
+ @Override
+ public Object call(Object p) {
+ throw new UnsupportedOperationException("Not supported yet.");
+ }
+ });
+
+ }
+
+ class MapView extends Pane {
+ // track/update visible portion?
+ }
+
+
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import javafx.beans.property.ObjectProperty;
+import javafx.beans.property.SimpleObjectProperty;
+
+/**
+ * Region selection
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class MapSelectionModel {
+
+ ObjectProperty<Bounds> boundsProperty = new SimpleObjectProperty<>();
+
+ // TODO: move this to where TileMap lives
+ public static class Bounds {
+
+ public int left, right, top, bottom;
+
+ public Bounds() {
+ }
+
+ public Bounds(int left, int right, int top, int bottom) {
+ this.left = left;
+ this.right = right;
+ this.top = top;
+ this.bottom = bottom;
+ }
+
+ public int getLeft() {
+ return left;
+ }
+
+ public int getRight() {
+ return right;
+ }
+
+ public int getTop() {
+ return top;
+ }
+
+ public int getBottom() {
+ return bottom;
+ }
+ }
+
+ public MapSelectionModel() {
+ }
+
+ public void setSelected(int tx, int ty) {
+ boundsProperty.set(new Bounds(tx, tx + 1, ty, ty + 1));
+ }
+
+ public Bounds getSelected() {
+ return boundsProperty.get();
+ }
+
+ public ObjectProperty<Bounds> boundsProperty() {
+ return boundsProperty;
+ }
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import duskz.client.fx.DataManagerFX;
+import duskz.server.entityz.TileMap;
+import java.io.File;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.concurrent.Future;
+import javafx.application.Platform;
+import javafx.beans.value.ChangeListener;
+import javafx.beans.value.ObservableValue;
+import javafx.collections.ObservableList;
+import javafx.event.EventHandler;
+import javafx.geometry.Orientation;
+import javafx.scene.Node;
+import javafx.scene.control.ScrollBar;
+import javafx.scene.image.ImageView;
+import javafx.scene.input.MouseEvent;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.Pane;
+import javafx.scene.layout.Region;
+import javafx.scene.layout.StackPane;
+import javafx.scene.paint.Color;
+import javafx.scene.shape.Rectangle;
+import javafx.scene.text.Text;
+
+/**
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class MapView extends Region implements ChangeListener<Number> {
+
+ String oldmap = "/home/notzed/src/DuskRPG/DuskFiles/Dusk2.7.3";
+ TileMap map;
+ DataManagerFX data;
+ // TODO: tilesize on DataManagerFX
+ int tileSize = 32;
+ double scale = 1;
+ Pane graphics;
+ Pane alias;
+ StackPane stack;
+ BorderPane overlay;
+ ScrollBar vbar;
+ ScrollBar hbar;
+ MapSelectionModel selectionModel = new MapSelectionModel();
+
+ public MapView() {
+
+ graphics = new Pane();
+ graphics.setManaged(false);
+ graphics.setScaleX(scale);
+ graphics.setScaleY(scale);
+
+ alias = new Pane();
+ alias.setManaged(false);
+ alias.setScaleX(scale);
+ alias.setScaleY(scale);
+
+ stack = new StackPane();
+
+ stack.getChildren().add(graphics);
+ stack.getChildren().add(alias);
+ overlay = new BorderPane();
+ overlay.setCenter(stack);
+ getChildren().add(overlay);
+
+ vbar = new ScrollBar();
+ vbar.setOrientation(Orientation.VERTICAL);
+ hbar = new ScrollBar();
+
+ overlay.setRight(vbar);
+ overlay.setBottom(hbar);
+
+ vbar.setUnitIncrement(32);
+ hbar.setUnitIncrement(32);
+
+ vbar.valueProperty().addListener(new ChangeListener<Number>() {
+ public void changed(ObservableValue<? extends Number> ov, Number t, Number t1) {
+ // blah blah update for position or some shit
+ }
+ });
+
+ stack.addEventHandler(MouseEvent.ANY, new EventHandler<MouseEvent>() {
+ public void handle(MouseEvent t) {
+ if (t.getEventType() == MouseEvent.MOUSE_CLICKED) {
+ int tx = (int) ((getOriginX() + t.getX()) / tileSize / scale);
+ int ty = (int) ((getOriginY() + t.getY()) / tileSize / scale);
+
+ //System.out.printf("selecting %d,%d mouse %f,%f origin %f,%f\n", tx, ty, t.getX(), t.getY(), getOriginX(), getOriginY());
+
+ selectionModel.setSelected(tx, ty);
+ // hack
+ requestLayout();
+ }
+ }
+ });
+
+ }
+ double oldw, oldh;
+ int vcols, vrows;
+
+ @Override
+ protected void layoutChildren() {
+ super.layoutChildren();
+
+ //System.out.printf("layout children dimensions = %fx%f\n", getWidth(), getHeight());
+
+ overlay.resize(getWidth(), getHeight());
+
+ if (map != null) {
+ //System.out.printf("visible total = %d max = %f visible %f\n",
+ // map.getRows() * tileSize,
+ // map.getRows() * tileSize - getHeight(),
+ // getHeight());
+
+ //vbar.setMin(getHeight());
+ //hbar.setMin(getWidth());
+ vbar.setMax(map.getRows() * tileSize * scale);
+ hbar.setMax(map.getCols() * tileSize * scale);
+ vbar.setVisibleAmount(getHeight());
+ hbar.setVisibleAmount(getWidth());
+
+ //System.out.printf("visible %f total %f\n", vbar.getVisibleAmount(), vbar.getMax());
+
+ // create imageview objects to cover screen
+ if (oldw != getWidth() || oldh != getHeight()) {
+ vcols = (int) (getWidth() / (tileSize * scale)) + 1;
+ vrows = (int) (getHeight() / (tileSize * scale)) + 1;
+ oldw = getWidth();
+ oldh = getHeight();
+ ObservableList<Node> c = graphics.getChildren();
+ c.clear();
+
+ for (int l = 0; l < map.getLayerCount(); l++) {
+ for (int y = 0; y < vrows; y++) {
+ for (int x = 0; x < vcols; x++) {
+ ImageView iv = new ImageView();
+
+ iv.relocate(x * tileSize, y * tileSize);
+ c.add(iv);
+ }
+ }
+ }
+
+ }
+
+ updateMapVisible();
+ //updateThread();
+ }
+ }
+
+ @Override
+ public void changed(ObservableValue<? extends Number> ov, Number t, Number t1) {
+ System.out.println("trnaslate changed");
+ }
+
+ void loadMap(DataManagerFX data, String path) throws IOException {
+ this.data = data;
+ map = TileMap.loadLayered(new File(path));
+ updateMap();
+ requestLayout();
+ }
+
+ @Override
+ protected double computePrefHeight(double d) {
+ //if (map == null)
+ return super.computePrefHeight(d);
+ //return map.getRows() * 32;
+ }
+
+ @Override
+ protected double computePrefWidth(double d) {
+ //if (map == null)
+ return super.computePrefWidth(d);
+ //return map.getCols() * 32;
+ }
+ int oldx0 = -1;
+ int oldy0 = -1;
+ int oldvcols = -1;
+ int oldvrows = -1;
+
+ double getOriginX() {
+ double v = hbar.getValue() * (hbar.getMax() + tileSize * scale - getWidth()) / hbar.getMax();
+
+ v -= Math.IEEEremainder(v, 32);
+ return v;
+ }
+
+ double getOriginY() {
+ double v = vbar.getValue() * (vbar.getMax() + tileSize * scale - getHeight()) / vbar.getMax();
+ v -= Math.IEEEremainder(v, 32);
+ return v;
+ }
+
+ int getTileX() {
+ return (int) (getOriginX() / tileSize / scale);
+ }
+
+ int getTileY() {
+ return (int) (getOriginY() / tileSize / scale);
+ }
+
+ void updateMapVisible() {
+ final ArrayList<Node> children = new ArrayList<>();
+ final ArrayList<Node> upper = new ArrayList<>();
+ int levelCount = map.getLayerCount();
+
+ // Animated tiles hack test
+ // final Rectangle2D[] anims = new Rectangle2D[2];
+ // anims[0] = data.createTile(305, 0, 0, tileSize, tileSize).getViewport();
+ // anims[1] = data.createTile(304, 0, 0, tileSize, tileSize).getViewport();
+ // final List<ImageView> animated = new ArrayList<>();
+
+ int x0 = getTileX();
+ int y0 = getTileY();
+
+ // y0 = Math.min(y0, map.getRows());
+ // y1 = Math.min(y1, map.getRows());
+
+ //graphics.setTranslateX(-((long) getOriginX() & (tileSize - 1)) * scale);
+ //graphics.setTranslateY(-((long) getOriginY() & (tileSize - 1)) * scale);
+
+ // TODO: set position pixel or some shit
+
+ //if (oldx0 == x0 && oldy0 == y0 && oldvcols == vcols && oldvrows == vrows)
+ // return;
+
+ oldx0 = x0;
+ oldy0 = y0;
+ oldvcols = vcols;
+ oldvrows = vrows;
+
+ for (int l = 0; l < map.getLayerCount(); l++) {
+ for (int y = 0; y < vrows; y++) {
+ int ty = y + y0;
+ for (int x = 0; x < vcols; x++) {
+ int tx = x + x0;
+ ImageView iv = (ImageView) graphics.getChildren().get(x + y * vcols + l * vcols * vrows);
+
+ int tileid = map.getTile(l, tx, ty);
+ if (tileid != 0) {
+ data.updateTile(iv, tileid, tileSize, tileSize);
+ iv.setVisible(true);
+ } else {
+ iv.setVisible(false);
+ }
+ }
+ }
+ }
+
+
+ // Check for meta data on map region
+ List<Node> nodes = new ArrayList<Node>();
+
+ boolean overlayOld = true;
+
+ // HACK: check for old map shit
+ if (overlayOld) {
+ for (int y = 0; y < vrows; y++) {
+ int ty = y + y0;
+ for (int x = 0; x < vcols; x++) {
+ int tx = x + x0;
+ File f = new File(String.format("%s/defMoveActions/%d_%d", oldmap, tx, ty));
+
+ if (f.exists()) {
+ Rectangle r = new Rectangle(tileSize - 4, tileSize - 4);
+ r.setFill(null);
+ r.setStroke(Color.BLUE);
+ r.setStrokeWidth(4);
+
+ r.relocate(x * tileSize + 2, y * tileSize + 2);
+ nodes.add(r);
+ }
+ }
+ }
+ }
+
+ // highlight any location with stuff
+ for (int y = 0; y < vrows; y++) {
+ int ty = y + y0;
+ for (int x = 0; x < vcols; x++) {
+ int tx = x + x0;
+ String a = map.aliasForLocation(tx, ty);
+ String j = map.jumpAlias(tx, ty);
+ String able = map.locationAbleScript(tx, ty);
+ String action = map.locationActionScript(tx, ty);
+ String visible = map.locationVisibleScript(tx, ty);
+
+ if (a != null
+ || j != null
+ || able != null
+ || action != null
+ || visible != null) {
+ Rectangle r = new Rectangle(tileSize - 4, tileSize - 4);
+ r.setFill(null);
+ r.setStroke(Color.RED);
+ r.setStrokeWidth(2);
+
+ r.relocate(x * tileSize + 2, y * tileSize + 2);
+ nodes.add(r);
+ }
+ if (a != null) {
+ Text t = new Text(a);
+
+ t.relocate(x * tileSize, y * tileSize);
+ nodes.add(t);
+ }
+ }
+ }
+ MapSelectionModel.Bounds selected = selectionModel.getSelected();
+ if (selected != null) {
+ int left = selected.left - getTileX();
+ int top = selected.top - getTileY();
+ System.out.printf("adding selected %d %d %d %d\n", selected.left, selected.right, selected.top, selected.bottom);
+ Rectangle r = new Rectangle((selected.right - selected.left) * tileSize - 4, (selected.bottom - selected.top) * tileSize - 4);
+ r.setFill(Color.color(1, 1, 0, 0.25));
+ r.setStroke(Color.ORANGE);
+ r.setStrokeWidth(2);
+
+ r.relocate(left * tileSize + 2, top * tileSize + 2);
+ nodes.add(r);
+ }
+
+ alias.getChildren().setAll(nodes);
+
+ }
+ Future f;
+
+ void updateThread() {
+ int y0 = (int) (vbar.getValue() / tileSize / scale);
+ int x0 = (int) (hbar.getValue() / tileSize / scale);
+
+ if (f != null) {
+ if (f.cancel(false)) {
+ System.out.println("pending cancelled");
+ }
+ }
+
+ f = TZ.single.submit(new Update(x0, y0, 1, vcols, vrows));
+ }
+
+ class Update implements Runnable {
+
+ int x0, y0, xstep;
+ int vcols, vrows;
+
+ public Update(int x0, int y0, int xstep, int vcols, int vrows) {
+ this.x0 = x0;
+ this.y0 = y0;
+ this.xstep = xstep;
+ this.vcols = vcols;
+ this.vrows = vrows;
+ }
+
+ @Override
+ public void run() {
+ System.out.println("start update thread");
+ final ArrayList<Node> children = new ArrayList<>();
+ for (int y = 0; y < vrows; y++) {
+ int ty = y + y0;
+ for (int x = 0; x < vcols; x++) {
+ int tx = x + x0;
+
+ int tileid = map.getTile(0, tx, ty);
+ if (tileid != 0) {
+ ImageView iv = data.createTile(tileid, x, y, tileSize, tileSize);
+ children.add(iv);
+ }
+ }
+ }
+
+ Platform.runLater(new Runnable() {
+ @Override
+ public void run() {
+ System.out.println("update ui");
+ graphics.getChildren().setAll(children);
+ }
+ });
+
+ }
+ }
+
+ void updateMap() {
+ final ArrayList<Node> children = new ArrayList<>();
+ final ArrayList<Node> upper = new ArrayList<>();
+ int levelCount = map.getLayerCount();
+
+ // Animated tiles hack test
+ // final Rectangle2D[] anims = new Rectangle2D[2];
+ // anims[0] = data.createTile(305, 0, 0, tileSize, tileSize).getViewport();
+ // anims[1] = data.createTile(304, 0, 0, tileSize, tileSize).getViewport();
+ // final List<ImageView> animated = new ArrayList<>();
+
+ // Build whole map
+ for (int l = 0; l < levelCount; l++) {
+ for (int y = 0; y < map.getRows(); y++) {
+ // Draw tiles first for whole row
+ for (int x = 0; x < map.getCols(); x++) {
+ int tileid = map.getTile(l, x, y);
+ if (tileid != 0) {
+ ImageView iv = data.createTile(tileid, x, y, tileSize, tileSize);
+ children.add(iv);
+
+ // if (tileid == 305)
+ // animated.add(iv);
+ }
+ }
+
+ if (children.size() > 16)
+ break;
+
+ // Now check for entities over this layer row
+ /*
+ if (l == map.getGroundLevel()) {
+ for (int x = 0; x < map.cols; x++) {
+ Collection<Entity> ents = map.getEntities(x + map.offx, y + map.offy);
+ if (ents != null) {
+ for (Entity e : ents) {
+ drawEntity(e, map.offx, map.offy, children, upper);
+ }
+ }
+ }
+ }*/
+ }
+ }
+
+ // Build sprites
+ //for (Entity e : map.getEntities()) {
+ // drawEntity(map.offx, map.offy, children, e);
+ //}
+
+ Platform.runLater(new Runnable() {
+ @Override
+ public void run() {
+ graphics.getChildren().setAll(children);
+ graphics.getChildren().addAll(upper);
+
+ // System.out.println("animated node count = " + animated.size());
+ // if (animator == null) {
+ // animator = new TileAnimator(animated, Duration.seconds(0.25), anims);
+ // animator.setCycleCount(Animation.INDEFINITE);
+ // animator.play();
+ // } else
+ // animator.setNodes(animated);
+ }
+ });
+ }
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import java.util.concurrent.Executors;
+import java.util.concurrent.ThreadPoolExecutor;
+
+/**
+ * Class for global application resources.
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class TZ {
+
+ static ThreadPoolExecutor single = (ThreadPoolExecutor) Executors.newFixedThreadPool(1);
+
+ public static void shutdown() {
+ single.shutdown();
+ }
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import java.io.IOException;
+import java.nio.charset.Charset;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.StandardCopyOption;
+import java.nio.file.StandardOpenOption;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javafx.event.ActionEvent;
+import javafx.event.EventHandler;
+import javafx.scene.Scene;
+import javafx.scene.control.Button;
+import javafx.scene.control.TextArea;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.HBox;
+import javafx.stage.Stage;
+
+/**
+ * Very basic text editor window.
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class TextEditor extends Stage {
+
+ TextArea text;
+ Path path;
+
+ public TextEditor() {
+ HBox buttons = new HBox();
+ BorderPane root = new BorderPane();
+ text = new TextArea();
+ text.setPrefRowCount(30);
+ Button save, cancel;
+ buttons.getChildren().addAll(cancel = new Button("Cancel"),
+ save = new Button("Save"));
+
+ save.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ try {
+ save();
+ } catch (IOException ex) {
+ // TODO: show error somewhere
+ Logger.getLogger(TextEditor.class.getName()).log(Level.SEVERE, null, ex);
+ }
+ }
+ });
+
+ cancel.setOnAction(new EventHandler<ActionEvent>() {
+ @Override
+ public void handle(ActionEvent t) {
+ close();
+ }
+ });
+
+ root.setCenter(text);
+ root.setTop(buttons);
+ Scene scene = new Scene(root);
+
+ setScene(scene);
+ }
+
+ public void setPath(Path path) throws IOException {
+ byte[] bytes = Files.readAllBytes(path);
+ String string = new String(bytes, Charset.defaultCharset());
+
+ this.path = path;
+ text.setText(string);
+ }
+
+ public void save() throws IOException {
+ Path tmp = path.resolveSibling(path.getFileName().toString() + "~");
+ Files.write(tmp, text.getText().getBytes(), StandardOpenOption.CREATE, StandardOpenOption.TRUNCATE_EXISTING);
+ Files.move(tmp, path, StandardCopyOption.ATOMIC_MOVE);
+ }
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import javafx.scene.layout.FlowPane;
+
+/**
+ * Flowpane for tiles, plus some management shit
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class TileView extends FlowPane {
+}
--- /dev/null
+/**
+ * TileZ is a tile editor.
+ * Copyright (C) 2013 Michael Zucchi
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package au.notzed.tilez;
+
+import duskz.client.fx.DataManagerFX;
+import java.io.IOException;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javafx.application.Application;
+import javafx.beans.value.ChangeListener;
+import javafx.beans.value.ObservableValue;
+import javafx.scene.Scene;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.VBox;
+import javafx.stage.Stage;
+
+/**
+ * Tool to view duskz maps, maybe more?
+ *
+ * @author Michael Zucchi <notzed@gmail.com>
+ */
+public class TileZ extends Application {
+
+ MapView mapView;
+ LocationEditor locationEditor;
+ DuskInfoView oldInfo;
+ DataManagerFX data;
+
+ @Override
+ public void start(Stage stage) {
+ BorderPane root = new BorderPane();
+
+ VBox left = new VBox();
+
+ left.getChildren().addAll(
+ locationEditor = new LocationEditor(),
+ oldInfo = new DuskInfoView());
+
+ root.setCenter(mapView = new MapView());
+ root.setLeft(left);
+
+ Scene scene = new Scene(root, 768, 512);
+
+ stage.setTitle("TileZ");
+ stage.setScene(scene);
+ stage.show();
+
+ String datapath = "/home/notzed/house.jar";
+ String mappath = "/home/notzed/dusk/game/defMaps/dusk";
+
+ try {
+ data = new DataManagerFX(datapath);
+ data.open();
+ mapView.loadMap(data, mappath);
+
+ locationEditor.setMap(mapView.map);
+
+ mapView.selectionModel.boundsProperty.addListener(new ChangeListener<MapSelectionModel.Bounds>() {
+ @Override
+ public void changed(ObservableValue<? extends MapSelectionModel.Bounds> ov, MapSelectionModel.Bounds t, MapSelectionModel.Bounds t1) {
+ if (t1 != null) {
+ locationEditor.setTileX(t1.left);
+ locationEditor.setTileY(t1.top);
+ oldInfo.setLocation(t1.left, t1.top);
+ } else {
+ locationEditor.setTileX(-1);
+ locationEditor.setTileY(-1);
+ }
+ }
+ });
+ } catch (IOException ex) {
+ Logger.getLogger(TileZ.class.getName()).log(Level.SEVERE, null, ex);
+ }
+ }
+
+ @Override
+ public void stop() throws Exception {
+ super.stop();
+ TZ.shutdown();
+ }
+
+ /**
+ * The main() method is ignored in correctly deployed JavaFX
+ * application. main() serves only as fallback in case the
+ * application can not be launched through deployment artifacts,
+ * e.g., in IDEs with limited FX support. NetBeans ignores main().
+ *
+ * @param args the command line arguments
+ */
+ public static void main(String[] args) {
+ launch(args);
+ }
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.XmlValue;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "value"
+})
+@XmlRootElement(name = "data")
+public class Data {
+
+ @XmlAttribute(name = "encoding")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String encoding;
+ @XmlAttribute(name = "compression")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String compression;
+ @XmlValue
+ protected String value;
+
+ /**
+ * Gets the value of the encoding property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getEncoding() {
+ return encoding;
+ }
+
+ /**
+ * Sets the value of the encoding property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setEncoding(String value) {
+ this.encoding = value;
+ }
+
+ /**
+ * Gets the value of the compression property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getCompression() {
+ return compression;
+ }
+
+ /**
+ * Sets the value of the compression property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setCompression(String value) {
+ this.compression = value;
+ }
+
+ /**
+ * Gets the value of the value property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getvalue() {
+ return value;
+ }
+
+ /**
+ * Sets the value of the value property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setvalue(String value) {
+ this.value = value;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "data"
+})
+@XmlRootElement(name = "image")
+public class Image {
+
+ @XmlAttribute(name = "format")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String format;
+ @XmlAttribute(name = "id")
+ protected String id;
+ @XmlAttribute(name = "source")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String source;
+ @XmlAttribute(name = "trans")
+ protected String trans;
+ protected Data data;
+
+ /**
+ * Gets the value of the format property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getFormat() {
+ return format;
+ }
+
+ /**
+ * Sets the value of the format property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setFormat(String value) {
+ this.format = value;
+ }
+
+ /**
+ * Gets the value of the id property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getId() {
+ return id;
+ }
+
+ /**
+ * Sets the value of the id property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setId(String value) {
+ this.id = value;
+ }
+
+ /**
+ * Gets the value of the source property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getSource() {
+ return source;
+ }
+
+ /**
+ * Sets the value of the source property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setSource(String value) {
+ this.source = value;
+ }
+
+ /**
+ * Gets the value of the trans property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getTrans() {
+ return trans;
+ }
+
+ /**
+ * Sets the value of the trans property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setTrans(String value) {
+ this.trans = value;
+ }
+
+ /**
+ * Gets the value of the data property.
+ *
+ * @return
+ * possible object is
+ * {@link Data }
+ *
+ */
+ public Data getData() {
+ return data;
+ }
+
+ /**
+ * Sets the value of the data property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Data }
+ *
+ */
+ public void setData(Data value) {
+ this.data = value;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.CollapsedStringAdapter;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "properties",
+ "data"
+})
+@XmlRootElement(name = "layer")
+public class Layer {
+
+ @XmlAttribute(name = "name", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String name;
+ @XmlAttribute(name = "width", required = true)
+ protected int width;
+ @XmlAttribute(name = "height", required = true)
+ protected int height;
+ @XmlAttribute(name = "x")
+ protected int x;
+ @XmlAttribute(name = "y")
+ protected int y;
+ @XmlAttribute(name = "opacity")
+ protected float opacity;
+ @XmlAttribute(name = "visible")
+ protected int visible;
+ protected Properties properties;
+ @XmlElement(required = true)
+ protected Data data;
+
+ /**
+ * Gets the value of the name property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * Sets the value of the name property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setName(String value) {
+ this.name = value;
+ }
+
+ /**
+ * Gets the value of the width property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getWidth() {
+ return width;
+ }
+
+ /**
+ * Sets the value of the width property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setWidth(int value) {
+ this.width = value;
+ }
+
+ /**
+ * Gets the value of the height property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getHeight() {
+ return height;
+ }
+
+ /**
+ * Sets the value of the height property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setHeight(int value) {
+ this.height = value;
+ }
+
+ /**
+ * Gets the value of the x property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getX() {
+ return x;
+ }
+
+ /**
+ * Sets the value of the x property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setX(int value) {
+ this.x = value;
+ }
+
+ /**
+ * Gets the value of the y property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getY() {
+ return y;
+ }
+
+ /**
+ * Sets the value of the y property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setY(int value) {
+ this.y = value;
+ }
+
+ /**
+ * Gets the value of the opacity property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public float getOpacity() {
+ return opacity;
+ }
+
+ /**
+ * Sets the value of the opacity property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setOpacity(float value) {
+ this.opacity = value;
+ }
+
+ /**
+ * Gets the value of the visible property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getVisible() {
+ return visible;
+ }
+
+ /**
+ * Sets the value of the visible property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setVisible(int value) {
+ this.visible = value;
+ }
+
+ /**
+ * Gets the value of the properties property.
+ *
+ * @return
+ * possible object is
+ * {@link Properties }
+ *
+ */
+ public Properties getProperties() {
+ return properties;
+ }
+
+ /**
+ * Sets the value of the properties property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Properties }
+ *
+ */
+ public void setProperties(Properties value) {
+ this.properties = value;
+ }
+
+ /**
+ * Gets the value of the data property.
+ *
+ * @return
+ * possible object is
+ * {@link Data }
+ *
+ */
+ public Data getData() {
+ return data;
+ }
+
+ /**
+ * Sets the value of the data property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Data }
+ *
+ */
+ public void setData(Data value) {
+ this.data = value;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import java.util.ArrayList;
+import java.util.List;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlElement;
+import javax.xml.bind.annotation.XmlElements;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.CollapsedStringAdapter;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "properties",
+ "tileset",
+ "layerOrObjectgroup"
+})
+@XmlRootElement(name = "map")
+public class Map {
+
+ @XmlAttribute(name = "xmlns")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String xmlns;
+ @XmlAttribute(name = "xmlns:xsi")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String xmlnsXsi;
+ @XmlAttribute(name = "xsi:schemaLocation")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String xsiSchemaLocation;
+ @XmlAttribute(name = "version", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String version;
+ @XmlAttribute(name = "orientation", required = true)
+ @XmlJavaTypeAdapter(CollapsedStringAdapter.class)
+ protected String orientation;
+ @XmlAttribute(name = "width", required = true)
+ protected int width;
+ @XmlAttribute(name = "height", required = true)
+ protected int height;
+ @XmlAttribute(name = "tilewidth", required = true)
+ protected int tilewidth;
+ @XmlAttribute(name = "tileheight", required = true)
+ protected int tileheight;
+ protected Properties properties;
+ protected List<Tileset> tileset;
+ @XmlElements({
+ @XmlElement(name = "layer", type = Layer.class),
+ @XmlElement(name = "objectgroup", type = Objectgroup.class)
+ })
+ protected List<java.lang.Object> layerOrObjectgroup;
+
+ /**
+ * Gets the value of the xmlns property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getXmlns() {
+ return xmlns;
+ }
+
+ /**
+ * Sets the value of the xmlns property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setXmlns(String value) {
+ this.xmlns = value;
+ }
+
+ /**
+ * Gets the value of the xmlnsXsi property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getXmlnsXsi() {
+ return xmlnsXsi;
+ }
+
+ /**
+ * Sets the value of the xmlnsXsi property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setXmlnsXsi(String value) {
+ this.xmlnsXsi = value;
+ }
+
+ /**
+ * Gets the value of the xsiSchemaLocation property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getXsiSchemaLocation() {
+ return xsiSchemaLocation;
+ }
+
+ /**
+ * Sets the value of the xsiSchemaLocation property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setXsiSchemaLocation(String value) {
+ this.xsiSchemaLocation = value;
+ }
+
+ /**
+ * Gets the value of the version property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getVersion() {
+ return version;
+ }
+
+ /**
+ * Sets the value of the version property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setVersion(String value) {
+ this.version = value;
+ }
+
+ /**
+ * Gets the value of the orientation property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getOrientation() {
+ return orientation;
+ }
+
+ /**
+ * Sets the value of the orientation property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setOrientation(String value) {
+ this.orientation = value;
+ }
+
+ /**
+ * Gets the value of the width property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getWidth() {
+ return width;
+ }
+
+ /**
+ * Sets the value of the width property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setWidth(int value) {
+ this.width = value;
+ }
+
+ /**
+ * Gets the value of the height property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getHeight() {
+ return height;
+ }
+
+ /**
+ * Sets the value of the height property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setHeight(int value) {
+ this.height = value;
+ }
+
+ /**
+ * Gets the value of the tilewidth property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getTilewidth() {
+ return tilewidth;
+ }
+
+ /**
+ * Sets the value of the tilewidth property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setTilewidth(int value) {
+ this.tilewidth = value;
+ }
+
+ /**
+ * Gets the value of the tileheight property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getTileheight() {
+ return tileheight;
+ }
+
+ /**
+ * Sets the value of the tileheight property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setTileheight(int value) {
+ this.tileheight = value;
+ }
+
+ /**
+ * Gets the value of the properties property.
+ *
+ * @return
+ * possible object is
+ * {@link Properties }
+ *
+ */
+ public Properties getProperties() {
+ return properties;
+ }
+
+ /**
+ * Sets the value of the properties property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Properties }
+ *
+ */
+ public void setProperties(Properties value) {
+ this.properties = value;
+ }
+
+ /**
+ * Gets the value of the tileset property.
+ *
+ * <p>
+ * This accessor method returns a reference to the live list,
+ * not a snapshot. Therefore any modification you make to the
+ * returned list will be present inside the JAXB object.
+ * This is why there is not a <CODE>set</CODE> method for the tileset property.
+ *
+ * <p>
+ * For example, to add a new item, do as follows:
+ * <pre>
+ * getTileset().add(newItem);
+ * </pre>
+ *
+ *
+ * <p>
+ * Objects of the following type(s) are allowed in the list
+ * {@link Tileset }
+ *
+ *
+ */
+ public List<Tileset> getTileset() {
+ if (tileset == null) {
+ tileset = new ArrayList<Tileset>();
+ }
+ return this.tileset;
+ }
+
+ /**
+ * Gets the value of the layerOrObjectgroup property.
+ *
+ * <p>
+ * This accessor method returns a reference to the live list,
+ * not a snapshot. Therefore any modification you make to the
+ * returned list will be present inside the JAXB object.
+ * This is why there is not a <CODE>set</CODE> method for the layerOrObjectgroup property.
+ *
+ * <p>
+ * For example, to add a new item, do as follows:
+ * <pre>
+ * getLayerOrObjectgroup().add(newItem);
+ * </pre>
+ *
+ *
+ * <p>
+ * Objects of the following type(s) are allowed in the list
+ * {@link Layer }
+ * {@link Objectgroup }
+ *
+ *
+ */
+ public List<java.lang.Object> getLayerOrObjectgroup() {
+ if (layerOrObjectgroup == null) {
+ layerOrObjectgroup = new ArrayList<java.lang.Object>();
+ }
+ return this.layerOrObjectgroup;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "properties",
+ "image"
+})
+@XmlRootElement(name = "object")
+public class Object {
+
+ @XmlAttribute(name = "name", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String name;
+ @XmlAttribute(name = "type", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String type;
+ @XmlAttribute(name = "x", required = true)
+ protected int x;
+ @XmlAttribute(name = "y", required = true)
+ protected int y;
+ @XmlAttribute(name = "width")
+ protected int width;
+ @XmlAttribute(name = "height")
+ protected int height;
+ protected Properties properties;
+ protected Image image;
+
+ /**
+ * Gets the value of the name property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * Sets the value of the name property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setName(String value) {
+ this.name = value;
+ }
+
+ /**
+ * Gets the value of the type property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getType() {
+ return type;
+ }
+
+ /**
+ * Sets the value of the type property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setType(String value) {
+ this.type = value;
+ }
+
+ /**
+ * Gets the value of the x property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getX() {
+ return x;
+ }
+
+ /**
+ * Sets the value of the x property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setX(int value) {
+ this.x = value;
+ }
+
+ /**
+ * Gets the value of the y property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getY() {
+ return y;
+ }
+
+ /**
+ * Sets the value of the y property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setY(int value) {
+ this.y = value;
+ }
+
+ /**
+ * Gets the value of the width property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getWidth() {
+ return width;
+ }
+
+ /**
+ * Sets the value of the width property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setWidth(int value) {
+ this.width = value;
+ }
+
+ /**
+ * Gets the value of the height property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getHeight() {
+ return height;
+ }
+
+ /**
+ * Sets the value of the height property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setHeight(int value) {
+ this.height = value;
+ }
+
+ /**
+ * Gets the value of the properties property.
+ *
+ * @return
+ * possible object is
+ * {@link Properties }
+ *
+ */
+ public Properties getProperties() {
+ return properties;
+ }
+
+ /**
+ * Sets the value of the properties property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Properties }
+ *
+ */
+ public void setProperties(Properties value) {
+ this.properties = value;
+ }
+
+ /**
+ * Gets the value of the image property.
+ *
+ * @return
+ * possible object is
+ * {@link Image }
+ *
+ */
+ public Image getImage() {
+ return image;
+ }
+
+ /**
+ * Sets the value of the image property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Image }
+ *
+ */
+ public void setImage(Image value) {
+ this.image = value;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlRegistry;
+
+
+/**
+ * This object contains factory methods for each
+ * Java content interface and Java element interface
+ * generated in the generated package.
+ * <p>An ObjectFactory allows you to programatically
+ * construct new instances of the Java representation
+ * for XML content. The Java representation of XML
+ * content can consist of schema derived interfaces
+ * and classes representing the binding of schema
+ * type definitions, element declarations and model
+ * groups. Factory methods for each of these are
+ * provided in this class.
+ *
+ */
+@XmlRegistry
+public class ObjectFactory {
+
+
+ /**
+ * Create a new ObjectFactory that can be used to create new instances of schema derived classes for package: generated
+ *
+ */
+ public ObjectFactory() {
+ }
+
+ /**
+ * Create an instance of {@link Tileset }
+ *
+ */
+ public Tileset createTileset() {
+ return new Tileset();
+ }
+
+ /**
+ * Create an instance of {@link Image }
+ *
+ */
+ public Image createImage() {
+ return new Image();
+ }
+
+ /**
+ * Create an instance of {@link Tile }
+ *
+ */
+ public Tile createTile() {
+ return new Tile();
+ }
+
+ /**
+ * Create an instance of {@link Properties }
+ *
+ */
+ public Properties createProperties() {
+ return new Properties();
+ }
+
+ /**
+ * Create an instance of {@link Objectgroup }
+ *
+ */
+ public Objectgroup createObjectgroup() {
+ return new Objectgroup();
+ }
+
+ /**
+ * Create an instance of {@link Object }
+ *
+ */
+ public Object createObject() {
+ return new Object();
+ }
+
+ /**
+ * Create an instance of {@link Data }
+ *
+ */
+ public Data createData() {
+ return new Data();
+ }
+
+ /**
+ * Create an instance of {@link Map }
+ *
+ */
+ public Map createMap() {
+ return new Map();
+ }
+
+ /**
+ * Create an instance of {@link Layer }
+ *
+ */
+ public Layer createLayer() {
+ return new Layer();
+ }
+
+ /**
+ * Create an instance of {@link Property }
+ *
+ */
+ public Property createProperty() {
+ return new Property();
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import java.util.ArrayList;
+import java.util.List;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "object"
+})
+@XmlRootElement(name = "objectgroup")
+public class Objectgroup {
+
+ @XmlAttribute(name = "name", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String name;
+ @XmlAttribute(name = "width")
+ protected int width;
+ @XmlAttribute(name = "height")
+ protected int height;
+ @XmlAttribute(name = "x")
+ protected int x;
+ @XmlAttribute(name = "y")
+ protected int y;
+ protected List<Object> object;
+
+ /**
+ * Gets the value of the name property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * Sets the value of the name property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setName(String value) {
+ this.name = value;
+ }
+
+ /**
+ * Gets the value of the width property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getWidth() {
+ return width;
+ }
+
+ /**
+ * Sets the value of the width property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setWidth(int value) {
+ this.width = value;
+ }
+
+ /**
+ * Gets the value of the height property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getHeight() {
+ return height;
+ }
+
+ /**
+ * Sets the value of the height property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setHeight(int value) {
+ this.height = value;
+ }
+
+ /**
+ * Gets the value of the x property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getX() {
+ return x;
+ }
+
+ /**
+ * Sets the value of the x property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setX(int value) {
+ this.x = value;
+ }
+
+ /**
+ * Gets the value of the y property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getY() {
+ return y;
+ }
+
+ /**
+ * Sets the value of the y property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setY(int value) {
+ this.y = value;
+ }
+
+ /**
+ * Gets the value of the object property.
+ *
+ * <p>
+ * This accessor method returns a reference to the live list,
+ * not a snapshot. Therefore any modification you make to the
+ * returned list will be present inside the JAXB object.
+ * This is why there is not a <CODE>set</CODE> method for the object property.
+ *
+ * <p>
+ * For example, to add a new item, do as follows:
+ * <pre>
+ * getObject().add(newItem);
+ * </pre>
+ *
+ *
+ * <p>
+ * Objects of the following type(s) are allowed in the list
+ * {@link Object }
+ *
+ *
+ */
+ public List<Object> getObject() {
+ if (object == null) {
+ object = new ArrayList<Object>();
+ }
+ return this.object;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import java.util.ArrayList;
+import java.util.List;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "property"
+})
+@XmlRootElement(name = "properties")
+public class Properties {
+
+ protected List<Property> property;
+
+ /**
+ * Gets the value of the property property.
+ *
+ * <p>
+ * This accessor method returns a reference to the live list,
+ * not a snapshot. Therefore any modification you make to the
+ * returned list will be present inside the JAXB object.
+ * This is why there is not a <CODE>set</CODE> method for the property property.
+ *
+ * <p>
+ * For example, to add a new item, do as follows:
+ * <pre>
+ * getProperty().add(newItem);
+ * </pre>
+ *
+ *
+ * <p>
+ * Objects of the following type(s) are allowed in the list
+ * {@link Property }
+ *
+ *
+ */
+ public List<Property> getProperty() {
+ if (property == null) {
+ property = new ArrayList<Property>();
+ }
+ return this.property;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "")
+@XmlRootElement(name = "property")
+public class Property {
+
+ @XmlAttribute(name = "name", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String name;
+ @XmlAttribute(name = "value", required = true)
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String value;
+
+ /**
+ * Gets the value of the name property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * Sets the value of the name property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setName(String value) {
+ this.name = value;
+ }
+
+ /**
+ * Gets the value of the value property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getValue() {
+ return value;
+ }
+
+ /**
+ * Sets the value of the value property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setValue(String value) {
+ this.value = value;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "properties",
+ "image"
+})
+@XmlRootElement(name = "tile")
+public class Tile {
+
+ @XmlAttribute(name = "id")
+ protected int id;
+ @XmlAttribute(name = "gid")
+ protected String gid;
+ protected Properties properties;
+ protected Image image;
+
+ /**
+ * Gets the value of the id property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getId() {
+ return id;
+ }
+
+ /**
+ * Sets the value of the id property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setId(int value) {
+ this.id = value;
+ }
+
+ /**
+ * Gets the value of the gid property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getGid() {
+ return gid;
+ }
+
+ /**
+ * Sets the value of the gid property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setGid(String value) {
+ this.gid = value;
+ }
+
+ /**
+ * Gets the value of the properties property.
+ *
+ * @return
+ * possible object is
+ * {@link Properties }
+ *
+ */
+ public Properties getProperties() {
+ return properties;
+ }
+
+ /**
+ * Sets the value of the properties property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Properties }
+ *
+ */
+ public void setProperties(Properties value) {
+ this.properties = value;
+ }
+
+ /**
+ * Gets the value of the image property.
+ *
+ * @return
+ * possible object is
+ * {@link Image }
+ *
+ */
+ public Image getImage() {
+ return image;
+ }
+
+ /**
+ * Sets the value of the image property.
+ *
+ * @param value
+ * allowed object is
+ * {@link Image }
+ *
+ */
+ public void setImage(Image value) {
+ this.image = value;
+ }
+
+}
--- /dev/null
+//
+// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.4-2
+// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
+// Any modifications to this file will be lost upon recompilation of the source schema.
+// Generated on: 2013.02.27 at 01:07:39 PM CST
+//
+
+
+package au.notzed.tilez.io;
+
+import java.util.ArrayList;
+import java.util.List;
+import javax.xml.bind.annotation.XmlAccessType;
+import javax.xml.bind.annotation.XmlAccessorType;
+import javax.xml.bind.annotation.XmlAttribute;
+import javax.xml.bind.annotation.XmlRootElement;
+import javax.xml.bind.annotation.XmlType;
+import javax.xml.bind.annotation.adapters.NormalizedStringAdapter;
+import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
+
+
+/**
+ *
+ */
+@XmlAccessorType(XmlAccessType.FIELD)
+@XmlType(name = "", propOrder = {
+ "image",
+ "tile"
+})
+@XmlRootElement(name = "tileset")
+public class Tileset {
+
+ @XmlAttribute(name = "name")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String name;
+ @XmlAttribute(name = "firstgid", required = true)
+ protected int firstgid;
+ @XmlAttribute(name = "source")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String source;
+ @XmlAttribute(name = "tilewidth")
+ protected int tilewidth;
+ @XmlAttribute(name = "tileheight")
+ protected int tileheight;
+ @XmlAttribute(name = "spacing")
+ protected int spacing;
+ @XmlAttribute(name = "margin")
+ @XmlJavaTypeAdapter(NormalizedStringAdapter.class)
+ protected String margin;
+ protected List<Image> image;
+ protected List<Tile> tile;
+
+ /**
+ * Gets the value of the name property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getName() {
+ return name;
+ }
+
+ /**
+ * Sets the value of the name property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setName(String value) {
+ this.name = value;
+ }
+
+ /**
+ * Gets the value of the firstgid property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getFirstgid() {
+ return firstgid;
+ }
+
+ /**
+ * Sets the value of the firstgid property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setFirstgid(int value) {
+ this.firstgid = value;
+ }
+
+ /**
+ * Gets the value of the source property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getSource() {
+ return source;
+ }
+
+ /**
+ * Sets the value of the source property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setSource(String value) {
+ this.source = value;
+ }
+
+ /**
+ * Gets the value of the tilewidth property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getTilewidth() {
+ return tilewidth;
+ }
+
+ /**
+ * Sets the value of the tilewidth property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setTilewidth(int value) {
+ this.tilewidth = value;
+ }
+
+ /**
+ * Gets the value of the tileheight property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getTileheight() {
+ return tileheight;
+ }
+
+ /**
+ * Sets the value of the tileheight property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setTileheight(int value) {
+ this.tileheight = value;
+ }
+
+ /**
+ * Gets the value of the spacing property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public int getSpacing() {
+ return spacing;
+ }
+
+ /**
+ * Sets the value of the spacing property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setSpacing(int value) {
+ this.spacing = value;
+ }
+
+ /**
+ * Gets the value of the margin property.
+ *
+ * @return
+ * possible object is
+ * {@link String }
+ *
+ */
+ public String getMargin() {
+ return margin;
+ }
+
+ /**
+ * Sets the value of the margin property.
+ *
+ * @param value
+ * allowed object is
+ * {@link String }
+ *
+ */
+ public void setMargin(String value) {
+ this.margin = value;
+ }
+
+ /**
+ * Gets the value of the image property.
+ *
+ * <p>
+ * This accessor method returns a reference to the live list,
+ * not a snapshot. Therefore any modification you make to the
+ * returned list will be present inside the JAXB object.
+ * This is why there is not a <CODE>set</CODE> method for the image property.
+ *
+ * <p>
+ * For example, to add a new item, do as follows:
+ * <pre>
+ * getImage().add(newItem);
+ * </pre>
+ *
+ *
+ * <p>
+ * Objects of the following type(s) are allowed in the list
+ * {@link Image }
+ *
+ *
+ */
+ public List<Image> getImage() {
+ if (image == null) {
+ image = new ArrayList<Image>();
+ }
+ return this.image;
+ }
+
+ /**
+ * Gets the value of the tile property.
+ *
+ * <p>
+ * This accessor method returns a reference to the live list,
+ * not a snapshot. Therefore any modification you make to the
+ * returned list will be present inside the JAXB object.
+ * This is why there is not a <CODE>set</CODE> method for the tile property.
+ *
+ * <p>
+ * For example, to add a new item, do as follows:
+ * <pre>
+ * getTile().add(newItem);
+ * </pre>
+ *
+ *
+ * <p>
+ * Objects of the following type(s) are allowed in the list
+ * {@link Tile }
+ *
+ *
+ */
+ public List<Tile> getTile() {
+ if (tile == null) {
+ tile = new ArrayList<Tile>();
+ }
+ return this.tile;
+ }
+
+}