diff --git a/.classpath b/.classpath index a3daea2df6045e33002f39cad1c25b21c71bb070..7e2824efa48ea1b6119c482f96893b1b986bad65 100644 --- a/.classpath +++ b/.classpath @@ -6,5 +6,7 @@ <classpathentry kind="con" path="org.eclipse.fx.ide.jdt.core.JAVAFX_CONTAINER"/> <classpathentry kind="con" path="org.eclipse.jdt.junit.JUNIT_CONTAINER/4"/> <classpathentry kind="lib" path="lib/GMapsFX-1.1.1.jar"/> + <classpathentry kind="lib" path="lib/geotools/gt-epsg-hsql-11.0.jar"/> + <classpathentry kind="lib" path="lib/geotools/gt-main-11.0.jar"/> <classpathentry kind="output" path="bin"/> </classpath> diff --git a/lib/geotools/COLORBREWER b/lib/geotools/COLORBREWER new file mode 100644 index 0000000000000000000000000000000000000000..c1dfe2c71402c2227e7c200fcc8de415f14dd473 --- /dev/null +++ b/lib/geotools/COLORBREWER @@ -0,0 +1,35 @@ + (used in the Brewer module) + +Apache-Style Software License for ColorBrewer Color Schemes + +Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The Pennsylvania State University. + +Licensed under the Apache License, Version 2.0 (the "License"); you may not use +this file except in compliance with the License. + +You may obtain a copy of the License at: +http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software distributed +under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR +CONDITIONS OF ANY KIND, either express or implied. See the License for the +specific language governing permissions and limitations under the License. + +For guidance on attribution and permissions: + +Redistribution and use in source and binary forms, with or without modification, +are permitted provided that the following conditions are met: +1. Redistributions as source code must retain the above copyright notice, this +list of conditions and the following disclaimer. +2. The end-user documentation included with the redistribution, if any, must +include the following acknowledgment: +"This product includes color specifications and designs developed by Cynthia +Brewer (http://colorbrewer.org/)." +Alternately, this acknowledgment may appear in the software itself, if and +wherever such third-party acknowledgments normally appear. +4. The name "ColorBrewer" must not be used to endorse or promote products derived +from this software without prior written permission. For written permission, +please contact Cynthia Brewer at cbrewer@psu.edu. +5. Products derived from this software may not be called "ColorBrewer", nor may +"ColorBrewer" appear in their name, without prior written permission of Cynthia +Brewer. diff --git a/lib/geotools/EPSG.html b/lib/geotools/EPSG.html new file mode 100644 index 0000000000000000000000000000000000000000..acc7f134f66a0f55f7d9906d092f20c2d4c6040f --- /dev/null +++ b/lib/geotools/EPSG.html @@ -0,0 +1,38 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> + +<html> + <head> + <title>EPSG license</title> + </head> + <body> + <p><b>Copyright (c) 1993-2006, OGP Surveying & Positioning Committee</b></p> + + <blockquote> + <p>The EPSG geodetic parameter dataset is owned jointly and severally by the + members of the Surveying and Positioning Committee of the International Association + of Oil and Gas Producers (OGP), formerly the European Petroleum Survey Group (EPSG). + It is compiled by the Geodetic Subcommittee of the OGP from publicly available and + member-supplied information and distributed at no charge through the internet. The + data may be copied and distributed subject to the following conditions:</p> + <ol> + <li><p>The user assumes the entire risk as to the accuracy and the use of this data. + INFORMATION PROVIDED IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER + EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF + MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.</p></li> + + <li><p>All data pertinent to a specific coordinate reference system must be copied + without modification and all related pages/records must be included;</li></p> + + <li><p>The data may not be distributed for profit by any third party; and</li></p> + + <li><p>The original source [OGP / EPSG] must be acknowledged.</li></p> + </ol> + + <p>With regard to (3) above, the data may be included within propriatory applications + distributed on a commercial basis when the commerciality is based on application + functionality and not on a value ascribed to the freely-distributed OGP data.</p> + + <p align="right"><cite>Source: <a href="http://www.epsg.org/guides/G7-1.html">www.epsg.org</a></cite></p> + </blockquote> + </body> +</html> diff --git a/lib/geotools/GPL+CP b/lib/geotools/GPL+CP new file mode 100644 index 0000000000000000000000000000000000000000..eb0652a5321b74f0af0661165198d866418f674d --- /dev/null +++ b/lib/geotools/GPL+CP @@ -0,0 +1,351 @@ + + The GNU General Public License with CLASSPATH Exception (GPL+CE) + + +The GNU General Public License (GPL) + +Version 2, June 1991 + +Copyright (C) 1989, 1991 Free Software Foundation, Inc. +59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + +Everyone is permitted to copy and distribute verbatim copies of this license +document, but changing it is not allowed. + +Preamble + +The licenses for most software are designed to take away your freedom to share +and change it. By contrast, the GNU General Public License is intended to +guarantee your freedom to share and change free software--to make sure the +software is free for all its users. This General Public License applies to +most of the Free Software Foundation's software and to any other program whose +authors commit to using it. (Some other Free Software Foundation software is +covered by the GNU Library General Public License instead.) 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 this service 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 make restrictions that forbid anyone to deny +you these rights or to ask you to surrender the rights. These restrictions +translate to certain responsibilities for you if you distribute copies of the +software, or if you modify it. + +For example, if you distribute copies of such a program, whether gratis or for +a fee, you must give the recipients all the rights that you have. 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. + +We protect your rights with two steps: (1) copyright the software, and (2) +offer you this license which gives you legal permission to copy, distribute +and/or modify the software. + +Also, for each author's protection and ours, we want to make certain that +everyone understands that there is no warranty for this free software. If the +software is modified by someone else and passed on, we want its recipients to +know that what they have is not the original, so that any problems introduced +by others will not reflect on the original authors' reputations. + +Finally, any free program is threatened constantly by software patents. We +wish to avoid the danger that redistributors of a free program will +individually obtain patent licenses, in effect making the program proprietary. +To prevent this, we have made it clear that any patent must be licensed for +everyone's free use or not licensed at all. + +The precise terms and conditions for copying, distribution and modification +follow. + +TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + +0. This License applies to any program or other work which contains a notice +placed by the copyright holder saying it may be distributed under the terms of +this General Public License. The "Program", below, refers to any such program +or work, and a "work based on the Program" means either the Program or any +derivative work under copyright law: that is to say, a work containing the +Program or a portion of it, either verbatim or with modifications and/or +translated into another language. (Hereinafter, translation is included +without limitation in the term "modification".) Each licensee is addressed as +"you". + +Activities other than copying, distribution and modification are not covered by +this License; they are outside its scope. The act of running the Program is +not restricted, and the output from the Program is covered only if its contents +constitute a work based on the Program (independent of having been made by +running the Program). Whether that is true depends on what the Program does. + +1. You may copy and distribute 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 and +disclaimer of warranty; keep intact all the notices that refer to this License +and to the absence of any warranty; and give any other recipients of the +Program a copy of this License along with the Program. + +You may charge a fee for the physical act of transferring a copy, and you may +at your option offer warranty protection in exchange for a fee. + +2. You may modify your copy or copies of the Program or any portion of it, thus +forming a work based on the Program, and copy and distribute such modifications +or work under the terms of Section 1 above, provided that you also meet all of +these conditions: + + a) You must cause the modified files to carry prominent notices stating + that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in whole or + in part contains or is derived from the Program or any part thereof, to be + licensed as a whole at no charge to all third parties under the terms of + this License. + + c) If the modified program normally reads commands interactively when run, + you must cause it, when started running for such interactive use in the + most ordinary way, to print or display an announcement including an + appropriate copyright notice and a notice that there is no warranty (or + else, saying that you provide a warranty) and that users may redistribute + the program under these conditions, and telling the user how to view a copy + of this License. (Exception: if the Program itself is interactive but does + not normally print such an announcement, your work based on the Program is + not required to print an announcement.) + +These requirements apply to the modified work as a whole. If identifiable +sections of that work are not derived from the Program, and can be reasonably +considered independent and separate works in themselves, then this License, and +its terms, do not apply to those sections when you distribute them as separate +works. But when you distribute the same sections as part of a whole which is a +work based on the Program, the distribution of the whole must be on the terms +of this License, whose permissions for other licensees extend to the entire +whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest your +rights to work written entirely by you; rather, the intent is to exercise the +right to control the distribution of derivative or collective works based on +the Program. + +In addition, mere aggregation of another work not based on the Program with the +Program (or with a work based on the Program) on a volume of a storage or +distribution medium does not bring the other work under the scope of this +License. + +3. You may copy and distribute the Program (or a work based on it, under +Section 2) in object code or executable form under the terms of Sections 1 and +2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable source + code, which must be distributed under the terms of Sections 1 and 2 above + on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three years, to + give any third party, for a charge no more than your cost of physically + performing source distribution, a complete machine-readable copy of the + corresponding source code, to be distributed under the terms of Sections 1 + and 2 above on a medium customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer to + distribute corresponding source code. (This alternative is allowed only + for noncommercial distribution and only if you received the program in + object code or executable form with such an offer, in accord with + Subsection b above.) + +The source code for a work means the preferred form of the work for making +modifications to it. For an executable work, complete source code means all +the source code for all modules it contains, plus any associated interface +definition files, plus the scripts used to control compilation and installation +of the executable. However, as a special exception, the source code +distributed need not include anything that is normally distributed (in either +source or binary form) with the major components (compiler, kernel, and so on) +of the operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering access to copy +from a designated place, then offering equivalent access to copy the source +code from the same place counts as distribution of the source code, even though +third parties are not compelled to copy the source along with the object code. + +4. You may not copy, modify, sublicense, or distribute the Program except as +expressly provided under this License. Any attempt otherwise to copy, modify, +sublicense or distribute the Program is void, and will automatically terminate +your rights under this License. However, parties who have received copies, or +rights, from you under this License will not have their licenses terminated so +long as such parties remain in full compliance. + +5. You are not required to accept this License, since you have not signed it. +However, nothing else grants you permission to modify or distribute the Program +or its derivative works. These actions are prohibited by law if you do not +accept this License. Therefore, by modifying or distributing the Program (or +any work based on the Program), you indicate your acceptance of this License to +do so, and all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + +6. Each time you redistribute the Program (or any work based on the Program), +the recipient automatically receives a license from the original licensor to +copy, distribute or modify the Program subject to these terms and conditions. +You may not impose any further restrictions on the recipients' exercise of the +rights granted herein. You are not responsible for enforcing compliance by +third parties to this License. + +7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), 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 distribute so as to satisfy +simultaneously your obligations under this License and any other pertinent +obligations, then as a consequence you may not distribute the Program at all. +For example, if a patent license would not permit royalty-free redistribution +of the Program by all those who receive copies directly or indirectly through +you, then the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under any +particular circumstance, the balance of the section is intended to apply and +the section as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any patents or +other property right claims or to contest validity of any such claims; this +section has the sole purpose of protecting the integrity of the free software +distribution system, which is implemented by public license practices. Many +people have made generous contributions to the wide range of software +distributed through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing to +distribute software through any other system and a licensee cannot impose that +choice. + +This section is intended to make thoroughly clear what is believed to be a +consequence of the rest of this License. + +8. If the distribution and/or use of the Program is restricted in certain +countries either by patents or by copyrighted interfaces, the original +copyright holder who places the Program under this License may add an explicit +geographical distribution limitation excluding those countries, so that +distribution is permitted only in or among countries not thus excluded. In +such case, this License incorporates the limitation as if written in the body +of this License. + +9. The Free Software Foundation may publish revised and/or new versions of the +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 a version number of this License which applies to it and "any later +version", you have the option of following the terms and conditions either of +that version or of any later version published by the Free Software Foundation. +If the Program does not specify a version number of this License, you may +choose any version ever published by the Free Software Foundation. + +10. If you wish to incorporate parts of the Program into other free programs +whose distribution conditions are different, write to the author to ask for +permission. For software which is copyrighted by the Free Software Foundation, +write to the Free Software Foundation; we sometimes make exceptions for this. +Our decision will be guided by the two goals of preserving the free status of +all derivatives of our free software and of promoting the sharing and reuse of +software generally. + +NO WARRANTY + +11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, 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. + +12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL +ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE 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. + +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 convey 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 2 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, write to the Free Software Foundation, Inc., 59 + Temple Place, Suite 330, Boston, MA 02111-1307 USA + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this when it +starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author Gnomovision 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, the commands you use may be +called something other than 'show w' and 'show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your school, +if any, to sign a "copyright disclaimer" for the program, if necessary. Here +is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + 'Gnomovision' (which makes passes at compilers) written by James Hacker. + + signature of Ty Coon, 1 April 1989 + + Ty Coon, President of Vice + +This 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 Library General Public +License instead of this License. + + +"CLASSPATH" EXCEPTION TO THE GPL + +Certain source files distributed by Sun Microsystems, Inc. are subject to +the following clarification and special exception to the GPL, but only where +Sun has expressly included in the particular source file's header the words +"Sun designates this particular file as subject to the "Classpath" exception +as provided by Sun in the LICENSE file that accompanied this code." + + Linking this library statically or dynamically with other modules is making + a combined work based on this library. Thus, the terms and conditions of + the GNU General Public License cover the whole combination. + + As a special exception, the copyright holders of this library give you + permission to link this library with independent modules to produce an + executable, regardless of the license terms of these independent modules, + and to copy and distribute the resulting executable under terms of your + choice, provided that you also meet, for each linked independent module, + the terms and conditions of the license of that module. An independent + module is a module which is not derived from or based on this library. If + you modify this library, you may extend this exception to your version of + the library, but you are not obligated to do so. If you do not wish to do + so, delete this exception statement from your version. diff --git a/lib/geotools/GeoTools.html b/lib/geotools/GeoTools.html new file mode 100644 index 0000000000000000000000000000000000000000..2a2e4875fd0a1036c533aa55e6c7eb9b76d4bdc7 --- /dev/null +++ b/lib/geotools/GeoTools.html @@ -0,0 +1,53 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> + +<html> + <head> + <title>License for the GeoTools geospatial Library</title> + </head> + <body> + <p><strong>GeoTools - The Open Source Java GIS Toolkit</strong><br> + <a href="http://www.geotools.org">http://geotools.org</a></p> + <p>(C) 2008, Open Source Geospatial Foundation (OSGeo)</p> + + <p> + The files in this library are part of Geotools, an open source Java GIS + toolkit. See http://geotools.org/ for details on the project. + </p> + + <p> + Files written entirely by the project are mostly covered by a copyright + of the Open Source Geospatial Foundation (OSGeo) as documented in the + file headers. See http://osgeo.org/ for details on the Foundation. Such + files are licensed to all under the terms of the GNU Lesser General Public + License (LGPL), version 2 or later. The directory containing this file + should also contain a copy of the LGPL, as a file named LGPL. + </p> + + <p> + Some files or portions of files are licensed under a different license as + documented in the headers of individual files. A copy of any license which + is not designed to be included in the file header itself should be included + along side this file: look for files with names such as GPL+CP. + </p> + + <p> + The standard header for the project is as follows: + </p> + <blockquote> + <p> + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; + version 2.1 of the License. + </p> + + <p> + This library 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 + <a href="http://www.gnu.org/licenses/lgpl.txt">GNU Lesser General + Public License</a> for more details.</p> + </blockquote> + </body> +</html> + diff --git a/lib/geotools/HSQL.html b/lib/geotools/HSQL.html new file mode 100644 index 0000000000000000000000000000000000000000..a9efcca648e8507d46b61e932b4fc73a7a25fdd3 --- /dev/null +++ b/lib/geotools/HSQL.html @@ -0,0 +1,42 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> + +<html> + <head> + <title>HSQL license</title> + </head> + <body> + <p><b>Copyright (c) 2001-2004, The HSQL Development Group</b><br> + All rights reserved.</p> + + <blockquote> + <p>Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met:</p> + <ol> + <li><p>Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer.</p></li> + + <li><p>Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution.</p></li> + + <li><p>Neither the name of the HSQL Development Group nor the names of its + contributors may be used to endorse or promote products derived from this + software without specific prior written permission.</p></li> + </ol> + + <p>THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG, + OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.</p> + + <p align="right"><cite>Source: <a href="http://www.hsqldb.org/web/hsqlLicense.html">www.hsqldb.org</a></cite></p> + </blockquote> + </body> +</html> diff --git a/lib/geotools/LGPL b/lib/geotools/LGPL new file mode 100644 index 0000000000000000000000000000000000000000..9ef3d701d14158244a5391964fa19e4bdee7c76a --- /dev/null +++ b/lib/geotools/LGPL @@ -0,0 +1,503 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 2.1, February 1999 + + Copyright (C) 1991, 1999 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + +[This is the first released version of the Lesser GPL. It also counts + as the successor of the GNU Library Public License, version 2, hence + the version number 2.1.] + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +Licenses are intended to guarantee your freedom to share and change +free software--to make sure the software is free for all its users. + + This license, the Lesser General Public License, applies to some +specially designated software packages--typically libraries--of the +Free Software Foundation and other authors who decide to use it. You +can use it too, but we suggest you first think carefully about whether +this license or the ordinary General Public License is the better +strategy to use in any particular case, based on the explanations below. + + When we speak of free software, we are referring to freedom of use, +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 this service if you wish); that you receive source code or can get +it if you want it; that you can change the software and use pieces of +it in new free programs; and that you are informed that you can do +these things. + + To protect your rights, we need to make restrictions that forbid +distributors to deny you these rights or to ask you to surrender these +rights. These restrictions translate to certain responsibilities for +you if you distribute copies of the library or if you modify it. + + For example, if you distribute copies of the library, whether gratis +or for a fee, you must give the recipients all the rights that we gave +you. You must make sure that they, too, receive or can get the source +code. If you link other code with the library, you must provide +complete object files to the recipients, so that they can relink them +with the library after making changes to the library and recompiling +it. And you must show them these terms so they know their rights. + + We protect your rights with a two-step method: (1) we copyright the +library, and (2) we offer you this license, which gives you legal +permission to copy, distribute and/or modify the library. + + To protect each distributor, we want to make it very clear that +there is no warranty for the free library. Also, if the library is +modified by someone else and passed on, the recipients should know +that what they have is not the original version, so that the original +author's reputation will not be affected by problems that might be +introduced by others. + + Finally, software patents pose a constant threat to the existence of +any free program. We wish to make sure that a company cannot +effectively restrict the users of a free program by obtaining a +restrictive license from a patent holder. Therefore, we insist that +any patent license obtained for a version of the library must be +consistent with the full freedom of use specified in this license. + + Most GNU software, including some libraries, is covered by the +ordinary GNU General Public License. This license, the GNU Lesser +General Public License, applies to certain designated libraries, and +is quite different from the ordinary General Public License. We use +this license for certain libraries in order to permit linking those +libraries into non-free programs. + + When a program is linked with a library, whether statically or using +a shared library, the combination of the two is legally speaking a +combined work, a derivative of the original library. The ordinary +General Public License therefore permits such linking only if the +entire combination fits its criteria of freedom. The Lesser General +Public License permits more lax criteria for linking other code with +the library. + + We call this license the "Lesser" General Public License because it +does Less to protect the user's freedom than the ordinary General +Public License. It also provides other free software developers Less +of an advantage over competing non-free programs. These disadvantages +are the reason we use the ordinary General Public License for many +libraries. However, the Lesser license provides advantages in certain +special circumstances. + + For example, on rare occasions, there may be a special need to +encourage the widest possible use of a certain library, so that it becomes +a de-facto standard. To achieve this, non-free programs must be +allowed to use the library. A more frequent case is that a free +library does the same job as widely used non-free libraries. In this +case, there is little to gain by limiting the free library to free +software only, so we use the Lesser General Public License. + + In other cases, permission to use a particular library in non-free +programs enables a greater number of people to use a large body of +free software. For example, permission to use the GNU C Library in +non-free programs enables many more people to use the whole GNU +operating system, as well as its variant, the GNU/Linux operating +system. + + Although the Lesser General Public License is Less protective of the +users' freedom, it does ensure that the user of a program that is +linked with the Library has the freedom and the wherewithal to run +that program using a modified version of the Library. + + The precise terms and conditions for copying, distribution and +modification follow. Pay close attention to the difference between a +"work based on the library" and a "work that uses the library". The +former contains code derived from the library, whereas the latter must +be combined with the library in order to run. + + GNU LESSER GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License Agreement applies to any software library or other +program which contains a notice placed by the copyright holder or +other authorized party saying it may be distributed under the terms of +this Lesser General Public License (also called "this License"). +Each licensee is addressed as "you". + + A "library" means a collection of software functions and/or data +prepared so as to be conveniently linked with application programs +(which use some of those functions and data) to form executables. + + The "Library", below, refers to any such software library or work +which has been distributed under these terms. A "work based on the +Library" means either the Library or any derivative work under +copyright law: that is to say, a work containing the Library or a +portion of it, either verbatim or with modifications and/or translated +straightforwardly into another language. (Hereinafter, translation is +included without limitation in the term "modification".) + + "Source code" for a work means the preferred form of the work for +making modifications to it. For a library, complete source code means +all the source code for all modules it contains, plus any associated +interface definition files, plus the scripts used to control compilation +and installation of the library. + + Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running a program using the Library is not restricted, and output from +such a program is covered only if its contents constitute a work based +on the Library (independent of the use of the Library in a tool for +writing it). Whether that is true depends on what the Library does +and what the program that uses the Library does. + + 1. You may copy and distribute verbatim copies of the Library's +complete source code as you receive it, in any medium, provided that +you conspicuously and appropriately publish on each copy an +appropriate copyright notice and disclaimer of warranty; keep intact +all the notices that refer to this License and to the absence of any +warranty; and distribute a copy of this License along with the +Library. + + You may charge a fee for the physical act of transferring a copy, +and you may at your option offer warranty protection in exchange for a +fee. + + 2. You may modify your copy or copies of the Library or any portion +of it, thus forming a work based on the Library, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) The modified work must itself be a software library. + + b) You must cause the files modified to carry prominent notices + stating that you changed the files and the date of any change. + + c) You must cause the whole of the work to be licensed at no + charge to all third parties under the terms of this License. + + d) If a facility in the modified Library refers to a function or a + table of data to be supplied by an application program that uses + the facility, other than as an argument passed when the facility + is invoked, then you must make a good faith effort to ensure that, + in the event an application does not supply such function or + table, the facility still operates, and performs whatever part of + its purpose remains meaningful. + + (For example, a function in a library to compute square roots has + a purpose that is entirely well-defined independent of the + application. Therefore, Subsection 2d requires that any + application-supplied function or table used by this function must + be optional: if the application does not supply it, the square + root function must still compute square roots.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Library, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Library, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote +it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Library. + +In addition, mere aggregation of another work not based on the Library +with the Library (or with a work based on the Library) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may opt to apply the terms of the ordinary GNU General Public +License instead of this License to a given copy of the Library. To do +this, you must alter all the notices that refer to this License, so +that they refer to the ordinary GNU General Public License, version 2, +instead of to this License. (If a newer version than version 2 of the +ordinary GNU General Public License has appeared, then you can specify +that version instead if you wish.) Do not make any other change in +these notices. + + Once this change is made in a given copy, it is irreversible for +that copy, so the ordinary GNU General Public License applies to all +subsequent copies and derivative works made from that copy. + + This option is useful when you wish to copy part of the code of +the Library into a program that is not a library. + + 4. You may copy and distribute the Library (or a portion or +derivative of it, under Section 2) in object code or executable form +under the terms of Sections 1 and 2 above provided that you accompany +it with the complete corresponding machine-readable source code, which +must be distributed under the terms of Sections 1 and 2 above on a +medium customarily used for software interchange. + + If distribution of object code is made by offering access to copy +from a designated place, then offering equivalent access to copy the +source code from the same place satisfies the requirement to +distribute the source code, even though third parties are not +compelled to copy the source along with the object code. + + 5. A program that contains no derivative of any portion of the +Library, but is designed to work with the Library by being compiled or +linked with it, is called a "work that uses the Library". Such a +work, in isolation, is not a derivative work of the Library, and +therefore falls outside the scope of this License. + + However, linking a "work that uses the Library" with the Library +creates an executable that is a derivative of the Library (because it +contains portions of the Library), rather than a "work that uses the +library". The executable is therefore covered by this License. +Section 6 states terms for distribution of such executables. + + When a "work that uses the Library" uses material from a header file +that is part of the Library, the object code for the work may be a +derivative work of the Library even though the source code is not. +Whether this is true is especially significant if the work can be +linked without the Library, or if the work is itself a library. The +threshold for this to be true is not precisely defined by law. + + If such an object file uses only numerical parameters, data +structure layouts and accessors, and small macros and small inline +functions (ten lines or less in length), then the use of the object +file is unrestricted, regardless of whether it is legally a derivative +work. (Executables containing this object code plus portions of the +Library will still fall under Section 6.) + + Otherwise, if the work is a derivative of the Library, you may +distribute the object code for the work under the terms of Section 6. +Any executables containing that work also fall under Section 6, +whether or not they are linked directly with the Library itself. + + 6. As an exception to the Sections above, you may also combine or +link a "work that uses the Library" with the Library to produce a +work containing portions of the Library, and distribute that work +under terms of your choice, provided that the terms permit +modification of the work for the customer's own use and reverse +engineering for debugging such modifications. + + You must give prominent notice with each copy of the work that the +Library is used in it and that the Library and its use are covered by +this License. You must supply a copy of this License. If the work +during execution displays copyright notices, you must include the +copyright notice for the Library among them, as well as a reference +directing the user to the copy of this License. Also, you must do one +of these things: + + a) Accompany the work with the complete corresponding + machine-readable source code for the Library including whatever + changes were used in the work (which must be distributed under + Sections 1 and 2 above); and, if the work is an executable linked + with the Library, with the complete machine-readable "work that + uses the Library", as object code and/or source code, so that the + user can modify the Library and then relink to produce a modified + executable containing the modified Library. (It is understood + that the user who changes the contents of definitions files in the + Library will not necessarily be able to recompile the application + to use the modified definitions.) + + b) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (1) uses at run time a + copy of the library already present on the user's computer system, + rather than copying library functions into the executable, and (2) + will operate properly with a modified version of the library, if + the user installs one, as long as the modified version is + interface-compatible with the version that the work was made with. + + c) Accompany the work with a written offer, valid for at + least three years, to give the same user the materials + specified in Subsection 6a, above, for a charge no more + than the cost of performing this distribution. + + d) If distribution of the work is made by offering access to copy + from a designated place, offer equivalent access to copy the above + specified materials from the same place. + + e) Verify that the user has already received a copy of these + materials or that you have already sent this user a copy. + + For an executable, the required form of the "work that uses the +Library" must include any data and utility programs needed for +reproducing the executable from it. However, as a special exception, +the materials to be distributed need not include anything that is +normally distributed (in either source or binary form) with the major +components (compiler, kernel, and so on) of the operating system on +which the executable runs, unless that component itself accompanies +the executable. + + It may happen that this requirement contradicts the license +restrictions of other proprietary libraries that do not normally +accompany the operating system. Such a contradiction means you cannot +use both them and the Library together in an executable that you +distribute. + + 7. You may place library facilities that are a work based on the +Library side-by-side in a single library together with other library +facilities not covered by this License, and distribute such a combined +library, provided that the separate distribution of the work based on +the Library and of the other library facilities is otherwise +permitted, and provided that you do these two things: + + a) Accompany the combined library with a copy of the same work + based on the Library, uncombined with any other library + facilities. This must be distributed under the terms of the + Sections above. + + b) Give prominent notice with the combined library of the fact + that part of it is a work based on the Library, and explaining + where to find the accompanying uncombined form of the same work. + + 8. You may not copy, modify, sublicense, link with, or distribute +the Library except as expressly provided under this License. Any +attempt otherwise to copy, modify, sublicense, link with, or +distribute the Library is void, and will automatically terminate your +rights under this License. However, parties who have received copies, +or rights, from you under this License will not have their licenses +terminated so long as such parties remain in full compliance. + + 9. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Library or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Library (or any work based on the +Library), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Library or works based on it. + + 10. Each time you redistribute the Library (or any work based on the +Library), the recipient automatically receives a license from the +original licensor to copy, distribute, link with or modify the Library +subject to these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties with +this License. + + 11. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +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 +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Library at all. For example, if a patent +license would not permit royalty-free redistribution of the Library by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Library. + +If any portion of this section is held invalid or unenforceable under any +particular circumstance, the balance of the section is intended to apply, +and the section as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 12. If the distribution and/or use of the Library is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Library under this License may add +an explicit geographical distribution limitation excluding those countries, +so that distribution is permitted only in or among countries not thus +excluded. In such case, this License incorporates the limitation as if +written in the body of this License. + + 13. The Free Software Foundation may publish revised and/or new +versions of the Lesser 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 Library +specifies a version number of this License which applies to it and +"any later version", you have the option of following the terms and +conditions either of that version or of any later version published by +the Free Software Foundation. If the Library does not specify a +license version number, you may choose any version ever published by +the Free Software Foundation. + + 14. If you wish to incorporate parts of the Library into other free +programs whose distribution conditions are incompatible with these, +write to the author to ask for permission. For software which is +copyrighted by the Free Software Foundation, write to the Free +Software Foundation; we sometimes make exceptions for this. Our +decision will be guided by the two goals of preserving the free status +of all derivatives of our free software and of promoting the sharing +and reuse of software generally. + + NO WARRANTY + + 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO +WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. +EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR +OTHER PARTIES PROVIDE THE LIBRARY "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 +LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME +THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN +WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY +AND/OR REDISTRIBUTE THE LIBRARY 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 +LIBRARY (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 LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF +SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH +DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Libraries + + If you develop a new library, and you want it to be of the greatest +possible use to the public, we recommend making it free software that +everyone can redistribute and change. You can do so by permitting +redistribution under these terms (or, alternatively, under the terms of the +ordinary General Public License). + + To apply these terms, attach the following notices to the library. It is +safest to attach them to the start of each source file to most effectively +convey 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 library's name and a brief idea of what it does.> + Copyright (C) <year> <name of author> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library 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 + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + +Also add information on how to contact you by electronic and paper mail. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the library, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the + library `Frob' (a library for tweaking knobs) written by James Random Hacker. + + <signature of Ty Coon>, 1 April 1990 + Ty Coon, President of Vice + +That's all there is to it! + diff --git a/lib/geotools/LICENSE b/lib/geotools/LICENSE new file mode 100644 index 0000000000000000000000000000000000000000..30468459cc525c3632294457ab453e45e94cc56a --- /dev/null +++ b/lib/geotools/LICENSE @@ -0,0 +1,21 @@ + + The files in this library are part of Geotools, an open source Java GIS + toolkit. See http://geotools.org/ for details on the project. + + Files written entirely by the project are mostly covered by a copyright + of the Open Source Geospatial Foundation (OSGeo) as documented in the + file headers. See http://osgeo.org/ for details on the Foundation. Such + files are licensed to all under the terms of the GNU Lesser General Public + License (LGPL), version 2 or later. The directory containing this file + should also contain a copy of the LGPL, as a file named LGPL. + + Some files or portions of files are licensed under a different license as + documented in the headers of individual files. A copy of any license which + is not designed to be included in the file header itself should be included + along side this file: look for files with names such as GPL+CP. + + + This library 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 + Lesser General Public License for more details. diff --git a/lib/geotools/OGC b/lib/geotools/OGC new file mode 100644 index 0000000000000000000000000000000000000000..10549e0dba2e7d392185da3f66d7c3f8bcf2f614 --- /dev/null +++ b/lib/geotools/OGC @@ -0,0 +1,38 @@ +This OGC work (including software, documents, or other related items) is being +provided by the copyright holders under the following license. By obtaining, +using and/or copying this work, you (the licensee) agree that you have read, +understood, and will comply with the following terms and conditions: + +Permission to use, copy, and modify this software and its documentation, with +or without modification, for any purpose and without fee or royalty is hereby +granted, provided that you include the following on ALL copies of the software +and documentation or portions thereof, including modifications, that you make: + + 1. The full text of this NOTICE in a location viewable to users of the + redistributed or derivative work. + + 2. Any pre-existing intellectual property disclaimers, notices, or terms and + conditions. If none exist, a short notice of the following form (hypertext + is preferred, text is permitted) should be used within the body of any + redistributed or derivative code: "Copyright © [$date-of-document] Open + Geospatial Consortium, Inc. All Rights Reserved. + http://www.opengeospatial.org/Legal/ + (Hypertext is preferred, but a textual representation is permitted.) + + 3. Notice of any changes or modifications to the OGC files, including the + date changes were made. (We recommend you provide URIs to the location + from which the code is derived.) + +THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE +NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED +TO, WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT +THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY +PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS. + +COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR +CONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION. + +The name and trademarks of copyright holders may NOT be used in advertising or +publicity pertaining to the software without specific, written prior permission. +Title to copyright in this software and any associated documentation will at all +times remain with copyright holders. diff --git a/lib/geotools/PostgreSQL.html b/lib/geotools/PostgreSQL.html new file mode 100644 index 0000000000000000000000000000000000000000..3f2d8fc796dd772c5a7180485e93926fe3dac090 --- /dev/null +++ b/lib/geotools/PostgreSQL.html @@ -0,0 +1,42 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> + +<html> + <head> + <title>PostgreSQL JDBC driver license</title> + </head> + <body> + <p><b>Copyright (c) 1997-2005, PostgreSQL Global Development Group</b><br> + All rights reserved.</p> + + <blockquote> + <p>Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met:</p> + <ol> + <li><p>Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer.</p></li> + + <li><p>Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution.</p></li> + + <li><p>Neither the name of the PostgreSQL Global Development Group nor the names + of its contributors may be used to endorse or promote products derived + from this software without specific prior written permission.</p></li> + </ol> + + <p>THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE.</p> + + <p align="right"><cite>Source: <a href="http://jdbc.postgresql.org/license.html">jdbc.postgresql.org</a></cite></p> + </blockquote> + </body> +</html> diff --git a/lib/geotools/README.html b/lib/geotools/README.html new file mode 100644 index 0000000000000000000000000000000000000000..eb30001e6ecbcf07d2f89ace04913d108f986332 --- /dev/null +++ b/lib/geotools/README.html @@ -0,0 +1,106 @@ +<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> +<HTML> +<HEAD> + <META HTTP-EQUIV="CONTENT-TYPE" CONTENT="text/html; charset=utf-8"> + <TITLE>GeoTools 11.0 README</TITLE> + <META NAME="GENERATOR" CONTENT="LibreOffice 3.3 (Linux)"> + <META NAME="CREATED" CONTENT="0;0"> + <META NAME="CHANGEDBY" CONTENT="Jody Garnett"> + <META NAME="CHANGED" CONTENT="20110428;21541200"> + <META NAME="CocoaVersion" CONTENT="1038.11"> + <META NAME="CHANGEDBY" CONTENT="Jody Garnett"> + <META HTTP-EQUIV="Content-Style-Type" CONTENT="text/css"> + <STYLE TYPE="text/css"> + <!-- + H1.western { font-family: "Liberation Sans", sans-serif } + H2.cjk { font-family: "WenQuanYi Micro Hei" } + H2.ctl { font-family: "Lohit Hindi" } + H3.western { font-family: "Liberation Sans", sans-serif } + H3.cjk { font-family: "WenQuanYi Micro Hei" } + H3.ctl { font-family: "Lohit Hindi" } + --> + </STYLE> +</HEAD> +<BODY LANG="en-AU" DIR="LTR"> +<a href="http://geotools.org"><img src="geotools-logo.png"></a> +<H1 CLASS="western">GeoTools 11.0</H1> +<P>Thank you for downloading GeoTools 11.0. This release was +created on Mar 18, 2014.</P> + +<P>This release contains only a subset of the current GeoTools code +base. The full GeoTools code base contains additional unsupported +modules covering experiments with a range of additional data formats. +Only the modules which are considered to be stable have been included +in this release.</P> + +<P>For more information, and documentation on the GeoTools library +please see the <A HREF="http://docs.geotools.org/stable/userguide/">GeoTools +User Guide</A>.</P> +<P>The user guide includes the following tutorials to introduce you +to GeoTools development:</P> +<UL> + <LI><P><A HREF="http://docs.geotools.org/stable/userguide/tutorial/quickstart/index.html">Quickstart</a> (<A HREF="http://docs.geotools.org/stable/userguide/tutorial/quickstart/eclipse.html">Eclipse + </A>, <A HREF="http://docs.geotools.org/stable/userguide/tutorial/quickstart/netbeans.html">Netbeans + </A> or <A HREF="http://docs.geotools.org/stable/userguide/tutorial/quickstart/maven.html">Maven</a>)</P> + <LI><P><A HREF="http://docs.geotools.org/stable/userguide/tutorial/feature/csv2shp.html">Feature + Tutorial</A></P> + <LI><P><A HREF="http://docs.geotools.org/stable/userguide/tutorial/geometry/geometrycrs.html">Geometry + CRS Tutorial</A></P> + <LI><P><A HREF="http://docs.geotools.org/stable/userguide/tutorial/filter/query.html">Query + Tutorial</A></P> + <LI><P><A HREF="http://docs.geotools.org/stable/userguide/tutorial/raster/image.html">Image + Tutorial</A></P> + <LI><P><A HREF="http://docs.geotools.org/stable/userguide/tutorial/map/style.html">Map + Style Tutorial</A></P> + <LI>Additional <A HREF="http://docs.geotools.org/stable/userguide/tutorial/advanced/index.html">advanced tutorials</A> cover topics such as making your own function, process or datastore.</LI> +</UL> + +<P>Welcome to GeoTools development!</P> +<H2 CLASS="western">Reference</H2> +<P>For full details on requirements and build process please see the +<A HREF="http://docs.geotools.org/latest/developer/">Developers' +Guide</A> (the following is provided as a quick reference only).</P> +<H3 CLASS="western">Requirements</H3> +<P>To use the GeoTools libraries you will need:</P> +<UL> + <LI><P>Java 6 or higher</P> +</UL> +<P>GeoTools will benefit from the inclusion of Java Advanced Imaging +(JAI) and the Java Image IO (JIO) extensions in your JRE. In addition +some formats require the ImageIO-Ext additions which explicitly +support raster formats such as MRSID and ECW. Detailed instructions +on configuring your JDK with these optional extensions can be found +in our developers guide <A HREF="http://docs.geotools.org/stable/userguide/advanced/build/install/jdk.html">here</A>.</P> +<H3 CLASS="western">Oracle (Optional)</H3> +<P>In order to use the gt-oracle or gt-jdbc-oracle modules, you need +the Oracle JDBC driver from Oracle. Unlike most external libraries +used in GeoTools, we cannot redistribute this jar.</P> +<P>However, you can obtain them from the Oracle website, free of +charge, after registering:</P> +<UL> + <LI><P><A HREF="http://www.oracle.com/technetwork/database/features/jdbc/index.html">http://www.oracle.com/technetwork/database/features/jdbc/</A></P> +</UL> +<P>Please see the developers guide for detailed instructions.</P> +<H3 CLASS="western">Building (Optional)</H3> +<P>In order to build GeoTools you will need a copy of <A HREF="http://maven.apache.org/download.html">Maven</A>. Maven is a project management tool from the Apache group.</P> +<P>Once you have maven installed, you can perform a full build by +moving to the GeoTools folder and typing:</P> +<P STYLE="margin-left: 2cm">mvn install</P> +<P>Please read the <A HREF="http://docs.geotools.org/stable/userguide/build/maven/index.html">User +Guide</A> for more information about maven.</P> +<H3 CLASS="western">Getting Involved (Recommended)</H3> +<P>The <A HREF="mailto:geotools-gt2-users@lists.sourceforge.net">gt2-users +mailing list</A> is provided for general inquiries, with additional +<A HREF="http://docs.geotools.org/stable/userguide/welcome/support.html">support +options</A> are available in the user guide.</P> +<P>If you are interested in the future development of GeoTools then +feel free to join the <A HREF="http://docs.geotools.org/latest/developer/communication.html">geotools-devel</A> +mailing list. We welcome contributions of new modules as well as keen +developers who want to work on the project as a whole.</P> +<P>You can find out more about the mailing lists and recent news by +going to the <A HREF="http://geotools.org/">GeoTools Homepage</A>.</P> +<P>Good luck and many thanks for your interest in GeoTools,</P> +<P><I>The GeoTools Project Management Committee, Open Source +Geospatial Foundation</I></P> +</BODY> +</HTML> diff --git a/lib/geotools/README.md b/lib/geotools/README.md new file mode 100644 index 0000000000000000000000000000000000000000..32dbb8454c154041ab832c826eef940c5b134452 --- /dev/null +++ b/lib/geotools/README.md @@ -0,0 +1,42 @@ +# GeoTools + +[GeoTools](http://geotools.org) is an open source Java library that provides + tools for geospatial data. Our Users guide provides an [overview](http://docs.geotools.org/latest/userguide/geotools.html) of the core features, supported formats and standards support. + +## License + +GeoTools licensed under the [LGPL](http://www.gnu.org/licenses/lgpl.html). The user guide [license](http://docs.geotools.org/latest/userguide/welcome/license.html) page describes the less restrictive license for documentation and source code examples. + +## Contributing + +The developers guide outlines ways to [contribute ](http://docs.geotools.org/latest/developer/procedures/contribute.html) to GeoTools using patches, pull requests and setting up new modules. + +If you are already experienced with GitHub please check our [pull request](http://docs.geotools.org/latest/developer/procedures/pull_requests.html) page before you start! + +## Building + +GeoTools uses [Apache Maven](http://maven.apache.org/) for a build system. To +build the library run maven from the root of the repository. + + % mvn clean install + +See the [user guide](http://docs.geotools.org/latest/userguide/build/index.html) +for more details. + +## Bugs + +GeoTools uses [JIRA](http://www.codehaus.org/), hosted by +[CodeHaus](http://www.codehaus.org/), for issue tracking. + +## Mailing Lists + +The [user list](mailto:geotools-gt2-users@lists.sourceforge.net) is for all questions +related to GeoTools usage. + +The [dev list](mailto:geotools-devel@lists.sourceforge.net) is for questions relateded +to hacking on the GeoTools library itself. + +## More Information + +Visit the [website](http://geotools.org/) or read the [docs](http://docs.geotools.org/). + diff --git a/lib/geotools/W3C b/lib/geotools/W3C new file mode 100644 index 0000000000000000000000000000000000000000..fed7fd37d82d5f0024271b01887e2b8346599a62 --- /dev/null +++ b/lib/geotools/W3C @@ -0,0 +1,44 @@ +W3C SOFTWARE NOTICE AND LICENSE +------------------------------------------------------------------------------------------- +This work (and included software, documentation such as READMEs, or other related items) is +being provided by the copyright holders under the following license. + +License +------------------------------------------------------------------------------------------- +By obtaining, using and/or copying this work, you (the licensee) agree that you have read, +understood, and will comply with the following terms and conditions. +Permission to copy, modify, and distribute this software and its documentation, with or +without modification, for any purpose and without fee or royalty is hereby granted, provided +that you include the following on ALL copies of the software and documentation or portions +thereof, including modifications: +The full text of this NOTICE in a location viewable to users of the redistributed or +derivative work. +Any pre-existing intellectual property disclaimers, notices, or terms and conditions. If none +exist, the W3C Software Short Notice should be included (hypertext is preferred, text is +permitted) within the body of any redistributed or derivative code. +Notice of any changes or modifications to the files, including the date changes were made. +(We recommend you provide URIs to the location from which the code is derived.) + +Disclaimers +------------------------------------------------------------------------------------------- +THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE NO +REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO, WARRANTIES +OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THE SOFTWARE OR +DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER +RIGHTS. +COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR CONSEQUENTIAL +DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION. +The name and trademarks of copyright holders may NOT be used in advertising or publicity +pertaining to the software without specific, written prior permission. Title to copyright in +this software and any associated documentation will at all times remain with copyright holders. + +Notes +------------------------------------------------------------------------------------------- +This version: http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231 +This formulation of W3C's notice and license became active on December 31 2002. This version +removes the copyright ownership notice such that this license can be used with materials +other than those owned by the W3C, reflects that ERCIM is now a host of the W3C, includes +references to this specific dated version of the license, and removes the ambiguous grant of +"use". Otherwise, this version is the same as the previous version and is written so as to +preserve the Free Software Foundation's assessment of GPL compatibility and OSI's +certification under the Open Source Definition. \ No newline at end of file diff --git a/lib/geotools/batik-transcoder-1.7.jar b/lib/geotools/batik-transcoder-1.7.jar new file mode 100644 index 0000000000000000000000000000000000000000..3934ed0a99ee941969d46142df06a0cf72232e9c Binary files /dev/null and b/lib/geotools/batik-transcoder-1.7.jar differ diff --git a/lib/geotools/bridj-0.6-c-only.jar b/lib/geotools/bridj-0.6-c-only.jar new file mode 100644 index 0000000000000000000000000000000000000000..d7a1a4c03f70d4c04f184f7163dd0e23ff13806f Binary files /dev/null and b/lib/geotools/bridj-0.6-c-only.jar differ diff --git a/lib/geotools/bufr-4.3.16.jar b/lib/geotools/bufr-4.3.16.jar new file mode 100644 index 0000000000000000000000000000000000000000..fb0c31481eceda955e515dbfd49a38eceb313e22 Binary files /dev/null and b/lib/geotools/bufr-4.3.16.jar differ diff --git a/lib/geotools/common-2.6.0.jar b/lib/geotools/common-2.6.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e3317d5fea35553f9353ef17b1af365105c947a4 Binary files /dev/null and b/lib/geotools/common-2.6.0.jar differ diff --git a/lib/geotools/commons-beanutils-1.7.0.jar b/lib/geotools/commons-beanutils-1.7.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..b1b89c9c921f16af22a88db3ff28975a8e40d886 Binary files /dev/null and b/lib/geotools/commons-beanutils-1.7.0.jar differ diff --git a/lib/geotools/commons-cli-2.0-gt2-pre1.jar b/lib/geotools/commons-cli-2.0-gt2-pre1.jar new file mode 100644 index 0000000000000000000000000000000000000000..a1041bce1fcd5e4e6eae2f1ec2346b51969bb94d Binary files /dev/null and b/lib/geotools/commons-cli-2.0-gt2-pre1.jar differ diff --git a/lib/geotools/commons-codec-1.2.jar b/lib/geotools/commons-codec-1.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..67cb720f5ed3f5c81a41accd02a09f4108d8b9ef Binary files /dev/null and b/lib/geotools/commons-codec-1.2.jar differ diff --git a/lib/geotools/commons-collections-3.1.jar b/lib/geotools/commons-collections-3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..41e230feeaa53618b6ac5f8d11792c2eecf4d4fd Binary files /dev/null and b/lib/geotools/commons-collections-3.1.jar differ diff --git a/lib/geotools/commons-dbcp-1.4.jar b/lib/geotools/commons-dbcp-1.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..c4c1c4f286a464227a55bcd3577d01d107e7b192 Binary files /dev/null and b/lib/geotools/commons-dbcp-1.4.jar differ diff --git a/lib/geotools/commons-digester-1.7.jar b/lib/geotools/commons-digester-1.7.jar new file mode 100644 index 0000000000000000000000000000000000000000..1783dbea232ced6db122268f8faa5ce773c7ea42 Binary files /dev/null and b/lib/geotools/commons-digester-1.7.jar differ diff --git a/lib/geotools/commons-httpclient-3.1.jar b/lib/geotools/commons-httpclient-3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..7c59774aed4f5dd08778489aaad565690ff7c132 Binary files /dev/null and b/lib/geotools/commons-httpclient-3.1.jar differ diff --git a/lib/geotools/commons-io-2.1.jar b/lib/geotools/commons-io-2.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..b5c7d692fe5616af4332c1a1db6efd23e3ff881b Binary files /dev/null and b/lib/geotools/commons-io-2.1.jar differ diff --git a/lib/geotools/commons-jxpath-1.3.jar b/lib/geotools/commons-jxpath-1.3.jar new file mode 100644 index 0000000000000000000000000000000000000000..e344a1e66d83ce608928a1e5e01dacfbc6270ab0 Binary files /dev/null and b/lib/geotools/commons-jxpath-1.3.jar differ diff --git a/lib/geotools/commons-lang-2.3.jar b/lib/geotools/commons-lang-2.3.jar new file mode 100644 index 0000000000000000000000000000000000000000..c33b3537b2be3a4df20b7c8f823a18403e79d809 Binary files /dev/null and b/lib/geotools/commons-lang-2.3.jar differ diff --git a/lib/geotools/commons-logging-1.1.1.jar b/lib/geotools/commons-logging-1.1.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..1deef144cb17ed2c11c6cdcdcb2d9530fa8d0b47 Binary files /dev/null and b/lib/geotools/commons-logging-1.1.1.jar differ diff --git a/lib/geotools/commons-pool-1.5.4.jar b/lib/geotools/commons-pool-1.5.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..43edf996359706eccd90cc01311ce852c87cb6fb Binary files /dev/null and b/lib/geotools/commons-pool-1.5.4.jar differ diff --git a/lib/geotools/core.commands-3.6.0.I20100512-1500.jar b/lib/geotools/core.commands-3.6.0.I20100512-1500.jar new file mode 100644 index 0000000000000000000000000000000000000000..6c95c0f88d52b72417bd639b836768ae7eb78837 Binary files /dev/null and b/lib/geotools/core.commands-3.6.0.I20100512-1500.jar differ diff --git a/lib/geotools/core.runtime-3.6.0.v20100505.jar b/lib/geotools/core.runtime-3.6.0.v20100505.jar new file mode 100644 index 0000000000000000000000000000000000000000..02aaf0779c5f6db7806b1c2eaabc59bb1def9d64 Binary files /dev/null and b/lib/geotools/core.runtime-3.6.0.v20100505.jar differ diff --git a/lib/geotools/eastwood-1.1.1-20090908.jar b/lib/geotools/eastwood-1.1.1-20090908.jar new file mode 100644 index 0000000000000000000000000000000000000000..90208365acafcad9b1fcf9abf69cf732dbd46ea9 Binary files /dev/null and b/lib/geotools/eastwood-1.1.1-20090908.jar differ diff --git a/lib/geotools/ecore-2.6.1.jar b/lib/geotools/ecore-2.6.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..ddf761b766358368bef701ca3ee177220a829cc3 Binary files /dev/null and b/lib/geotools/ecore-2.6.1.jar differ diff --git a/lib/geotools/ehcache-1.6.2.jar b/lib/geotools/ehcache-1.6.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..85a0ab428be7c8913c120aa932a3d78f705fa73a Binary files /dev/null and b/lib/geotools/ehcache-1.6.2.jar differ diff --git a/lib/geotools/equinox.common-3.6.0.v20100503.jar b/lib/geotools/equinox.common-3.6.0.v20100503.jar new file mode 100644 index 0000000000000000000000000000000000000000..a5d37aa152c5eefdfd3a58f490a54d466fd493c6 Binary files /dev/null and b/lib/geotools/equinox.common-3.6.0.v20100503.jar differ diff --git a/lib/geotools/gdal-1.8.1.jar b/lib/geotools/gdal-1.8.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..896f37eb077ccda6aae225813134dcd7dab80f8d Binary files /dev/null and b/lib/geotools/gdal-1.8.1.jar differ diff --git a/lib/geotools/geodb-0.7-RC2.jar b/lib/geotools/geodb-0.7-RC2.jar new file mode 100644 index 0000000000000000000000000000000000000000..87b6ba6e382315486d1b1f2ec6b5113d30f8673b Binary files /dev/null and b/lib/geotools/geodb-0.7-RC2.jar differ diff --git a/lib/geotools/grib-4.3.16.jar b/lib/geotools/grib-4.3.16.jar new file mode 100644 index 0000000000000000000000000000000000000000..27237826a298df0ccdb80d42fe14fbf7154b75ca Binary files /dev/null and b/lib/geotools/grib-4.3.16.jar differ diff --git a/lib/geotools/gt-api-11.0.jar b/lib/geotools/gt-api-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..d7bc54638698c30fd487e99e6dbaaddf5ff99d41 Binary files /dev/null and b/lib/geotools/gt-api-11.0.jar differ diff --git a/lib/geotools/gt-app-schema-11.0.jar b/lib/geotools/gt-app-schema-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..fe954ab5903d819237501ab8cfbed7ab630933cf Binary files /dev/null and b/lib/geotools/gt-app-schema-11.0.jar differ diff --git a/lib/geotools/gt-app-schema-resolver-11.0.jar b/lib/geotools/gt-app-schema-resolver-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..433ef19408ea6c20f3ef00725b277844d607e6df Binary files /dev/null and b/lib/geotools/gt-app-schema-resolver-11.0.jar differ diff --git a/lib/geotools/gt-arcgrid-11.0.jar b/lib/geotools/gt-arcgrid-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..6aff3eb8ae105e82b6e9e7337d2fbf73f737404d Binary files /dev/null and b/lib/geotools/gt-arcgrid-11.0.jar differ diff --git a/lib/geotools/gt-arcsde-11.0.jar b/lib/geotools/gt-arcsde-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a765fa82029f526185037bf23817004a1f54b0ce Binary files /dev/null and b/lib/geotools/gt-arcsde-11.0.jar differ diff --git a/lib/geotools/gt-arcsde-common-11.0.jar b/lib/geotools/gt-arcsde-common-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..7c0cf936fc91a1f14c30aca2b81b1fbd3a5717d2 Binary files /dev/null and b/lib/geotools/gt-arcsde-common-11.0.jar differ diff --git a/lib/geotools/gt-brewer-11.0.jar b/lib/geotools/gt-brewer-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..8355fc51c82e0d3512c2449634d2c37f04c82855 Binary files /dev/null and b/lib/geotools/gt-brewer-11.0.jar differ diff --git a/lib/geotools/gt-charts-11.0.jar b/lib/geotools/gt-charts-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..c536905fe1941e93bf149ac76e8efc7d498ca766 Binary files /dev/null and b/lib/geotools/gt-charts-11.0.jar differ diff --git a/lib/geotools/gt-complex-11.0-tests.jar b/lib/geotools/gt-complex-11.0-tests.jar new file mode 100644 index 0000000000000000000000000000000000000000..f847b2ba5b05dc46c79a8ef344a933e1fd7c837a Binary files /dev/null and b/lib/geotools/gt-complex-11.0-tests.jar differ diff --git a/lib/geotools/gt-complex-11.0.jar b/lib/geotools/gt-complex-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..6d5f2f7e9798524568b1c22b8d52ae4123104401 Binary files /dev/null and b/lib/geotools/gt-complex-11.0.jar differ diff --git a/lib/geotools/gt-coverage-11.0.jar b/lib/geotools/gt-coverage-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..497dc2074d7d7f474f434e7bcd9591bfde78f22c Binary files /dev/null and b/lib/geotools/gt-coverage-11.0.jar differ diff --git a/lib/geotools/gt-coverage-api-11.0.jar b/lib/geotools/gt-coverage-api-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..ac30e6b40fa970d1999f506102b454b39fce8215 Binary files /dev/null and b/lib/geotools/gt-coverage-api-11.0.jar differ diff --git a/lib/geotools/gt-coveragetools-11.0.jar b/lib/geotools/gt-coveragetools-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..075b90897c48fabf114a0a6ba2c5efa02b1fb32c Binary files /dev/null and b/lib/geotools/gt-coveragetools-11.0.jar differ diff --git a/lib/geotools/gt-cql-11.0.jar b/lib/geotools/gt-cql-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..da48c8e78670bdf8cb201f3dfb64d7aad80eb7f0 Binary files /dev/null and b/lib/geotools/gt-cql-11.0.jar differ diff --git a/lib/geotools/gt-csv-11.0.jar b/lib/geotools/gt-csv-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a4de4873a7928bd0cebccaa86c625e646c5890db Binary files /dev/null and b/lib/geotools/gt-csv-11.0.jar differ diff --git a/lib/geotools/gt-data-11.0.jar b/lib/geotools/gt-data-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..0a04eb110a1efca003bf07db45db5df354d859ed Binary files /dev/null and b/lib/geotools/gt-data-11.0.jar differ diff --git a/lib/geotools/gt-epsg-extension-11.0.jar b/lib/geotools/gt-epsg-extension-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a9785c1681cdefb5f53b663a79d135404f4531f7 Binary files /dev/null and b/lib/geotools/gt-epsg-extension-11.0.jar differ diff --git a/lib/geotools/gt-epsg-hsql-11.0.jar b/lib/geotools/gt-epsg-hsql-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..0cfcd8cb013df71620fcc72dd0ad2876ff17909f Binary files /dev/null and b/lib/geotools/gt-epsg-hsql-11.0.jar differ diff --git a/lib/geotools/gt-epsg-oracle-11.0.jar b/lib/geotools/gt-epsg-oracle-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..86f44366e8cf4f3d3b4e26ce9c2a6f90e043abd1 Binary files /dev/null and b/lib/geotools/gt-epsg-oracle-11.0.jar differ diff --git a/lib/geotools/gt-epsg-postgresql-11.0.jar b/lib/geotools/gt-epsg-postgresql-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a6de5be4038ecdf958d5e1f79a2b6dfc65bc3e90 Binary files /dev/null and b/lib/geotools/gt-epsg-postgresql-11.0.jar differ diff --git a/lib/geotools/gt-epsg-wkt-11.0.jar b/lib/geotools/gt-epsg-wkt-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e32b13a493da8dd707e10628df91189e71765ed3 Binary files /dev/null and b/lib/geotools/gt-epsg-wkt-11.0.jar differ diff --git a/lib/geotools/gt-feature-aggregate-11.0.jar b/lib/geotools/gt-feature-aggregate-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..894dd0f6f1422f15dc3fd565049c45e2bbfe6268 Binary files /dev/null and b/lib/geotools/gt-feature-aggregate-11.0.jar differ diff --git a/lib/geotools/gt-feature-pregeneralized-11.0.jar b/lib/geotools/gt-feature-pregeneralized-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e854f2255f01a998d01ccea66b78bbfedc8a1d70 Binary files /dev/null and b/lib/geotools/gt-feature-pregeneralized-11.0.jar differ diff --git a/lib/geotools/gt-geojson-11.0.jar b/lib/geotools/gt-geojson-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..513ed1e2720934ea8c335be74774c1aad9317c53 Binary files /dev/null and b/lib/geotools/gt-geojson-11.0.jar differ diff --git a/lib/geotools/gt-geometry-11.0.jar b/lib/geotools/gt-geometry-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..ba106ff727f01d42d2c72e08f300c61b3fbf484a Binary files /dev/null and b/lib/geotools/gt-geometry-11.0.jar differ diff --git a/lib/geotools/gt-geopkg-11.0.jar b/lib/geotools/gt-geopkg-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a34c8aa201a1b972fb90941bc034b1f111f7384e Binary files /dev/null and b/lib/geotools/gt-geopkg-11.0.jar differ diff --git a/lib/geotools/gt-geotiff-11.0.jar b/lib/geotools/gt-geotiff-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..ab4509aec7d88741620fd4620501f2266c6a2006 Binary files /dev/null and b/lib/geotools/gt-geotiff-11.0.jar differ diff --git a/lib/geotools/gt-graph-11.0.jar b/lib/geotools/gt-graph-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..91b644fc73976ea4ad24c2539e0b411252911dab Binary files /dev/null and b/lib/geotools/gt-graph-11.0.jar differ diff --git a/lib/geotools/gt-grassraster-11.0.jar b/lib/geotools/gt-grassraster-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..940cfd03e8bb8571221d27f81f150f845805ae5d Binary files /dev/null and b/lib/geotools/gt-grassraster-11.0.jar differ diff --git a/lib/geotools/gt-grid-11.0.jar b/lib/geotools/gt-grid-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..90df7baf2f787d0060d62cc120d662fe780064b9 Binary files /dev/null and b/lib/geotools/gt-grid-11.0.jar differ diff --git a/lib/geotools/gt-gtopo30-11.0.jar b/lib/geotools/gt-gtopo30-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..26f01b528bdf2a915503d69d7e8ec6abfa41fbfe Binary files /dev/null and b/lib/geotools/gt-gtopo30-11.0.jar differ diff --git a/lib/geotools/gt-image-11.0.jar b/lib/geotools/gt-image-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..19efe80856b47826b8e7e7902119bf074f81a7f6 Binary files /dev/null and b/lib/geotools/gt-image-11.0.jar differ diff --git a/lib/geotools/gt-imageio-ext-gdal-11.0.jar b/lib/geotools/gt-imageio-ext-gdal-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..065adb3a1a90e7cb3ce33292da8785c13800cca3 Binary files /dev/null and b/lib/geotools/gt-imageio-ext-gdal-11.0.jar differ diff --git a/lib/geotools/gt-imagemosaic-11.0.jar b/lib/geotools/gt-imagemosaic-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..d2d53223f8830710737ac86468c0faf386797ef2 Binary files /dev/null and b/lib/geotools/gt-imagemosaic-11.0.jar differ diff --git a/lib/geotools/gt-imagemosaic-jdbc-11.0.jar b/lib/geotools/gt-imagemosaic-jdbc-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..cf1b0008987f1063f25a0a5b427cd44cbea10d7d Binary files /dev/null and b/lib/geotools/gt-imagemosaic-jdbc-11.0.jar differ diff --git a/lib/geotools/gt-imagepyramid-11.0.jar b/lib/geotools/gt-imagepyramid-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..f144d83c9f7c995b2d2c57f71732c02b805aae5a Binary files /dev/null and b/lib/geotools/gt-imagepyramid-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-11.0.jar b/lib/geotools/gt-jdbc-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..bafe28c72718278d58581bdc9e0187245d357205 Binary files /dev/null and b/lib/geotools/gt-jdbc-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-db2-11.0.jar b/lib/geotools/gt-jdbc-db2-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..f6e3bf7e888a81b713a21a1b25e8b8471b688003 Binary files /dev/null and b/lib/geotools/gt-jdbc-db2-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-h2-11.0.jar b/lib/geotools/gt-jdbc-h2-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..223b6a67572fcfa05b10d4a618ae598aff0a6ec8 Binary files /dev/null and b/lib/geotools/gt-jdbc-h2-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-mysql-11.0.jar b/lib/geotools/gt-jdbc-mysql-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a305211dbfcbc81e2c8f92fe199f876cccba0537 Binary files /dev/null and b/lib/geotools/gt-jdbc-mysql-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-oracle-11.0.jar b/lib/geotools/gt-jdbc-oracle-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..1f2123c499135c2c1070f5d914fac877a45cac50 Binary files /dev/null and b/lib/geotools/gt-jdbc-oracle-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-postgis-11.0.jar b/lib/geotools/gt-jdbc-postgis-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..7ba4cabb957dde68f9558033d60d9caa964da600 Binary files /dev/null and b/lib/geotools/gt-jdbc-postgis-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-spatialite-11.0.jar b/lib/geotools/gt-jdbc-spatialite-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..1939a4ebda6bcf6d5340d9ced51661fa8550dd9c Binary files /dev/null and b/lib/geotools/gt-jdbc-spatialite-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-sqlserver-11.0.jar b/lib/geotools/gt-jdbc-sqlserver-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..abb9d658dfc50841101b6e91be6292d8d94135b3 Binary files /dev/null and b/lib/geotools/gt-jdbc-sqlserver-11.0.jar differ diff --git a/lib/geotools/gt-jdbc-teradata-11.0.jar b/lib/geotools/gt-jdbc-teradata-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..c746ceae347bf384be50d1d7a3b94e5c87c5d847 Binary files /dev/null and b/lib/geotools/gt-jdbc-teradata-11.0.jar differ diff --git a/lib/geotools/gt-jp2k-11.0.jar b/lib/geotools/gt-jp2k-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e61607fe71f1ef0910c82d1d55bc953576e8ec68 Binary files /dev/null and b/lib/geotools/gt-jp2k-11.0.jar differ diff --git a/lib/geotools/gt-jts-wrapper-11.0.jar b/lib/geotools/gt-jts-wrapper-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..2f51d837c32f81ce4452be2b88effe19b7cd37e0 Binary files /dev/null and b/lib/geotools/gt-jts-wrapper-11.0.jar differ diff --git a/lib/geotools/gt-main-11.0.jar b/lib/geotools/gt-main-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e70cd821b43647f177c2407e60b95ea83e48a87f Binary files /dev/null and b/lib/geotools/gt-main-11.0.jar differ diff --git a/lib/geotools/gt-mark-wkt-11.0.jar b/lib/geotools/gt-mark-wkt-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e45dca332f92e41bf2e081dde3360ba7615207bf Binary files /dev/null and b/lib/geotools/gt-mark-wkt-11.0.jar differ diff --git a/lib/geotools/gt-matfile5-11.0.jar b/lib/geotools/gt-matfile5-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..dd8b2491d06fe5e76d21b36d0d31a401dc265b7a Binary files /dev/null and b/lib/geotools/gt-matfile5-11.0.jar differ diff --git a/lib/geotools/gt-metadata-11.0.jar b/lib/geotools/gt-metadata-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..8d7b3e8efab7e07aeb05e8a9ae735f7384697699 Binary files /dev/null and b/lib/geotools/gt-metadata-11.0.jar differ diff --git a/lib/geotools/gt-mongodb-11.0.jar b/lib/geotools/gt-mongodb-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..1d076aa45fca326686974bde019a48e1025d7149 Binary files /dev/null and b/lib/geotools/gt-mongodb-11.0.jar differ diff --git a/lib/geotools/gt-netcdf-11.0.jar b/lib/geotools/gt-netcdf-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..c8cddff8edd536701652ecf9444de66e307682c4 Binary files /dev/null and b/lib/geotools/gt-netcdf-11.0.jar differ diff --git a/lib/geotools/gt-ogr-bridj-11.0.jar b/lib/geotools/gt-ogr-bridj-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..b8090fbbafa60dd18507a8efe6bfe2876ae1a249 Binary files /dev/null and b/lib/geotools/gt-ogr-bridj-11.0.jar differ diff --git a/lib/geotools/gt-ogr-core-11.0.jar b/lib/geotools/gt-ogr-core-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..4e1bd0bfe126daa57dc6a83f76bace9bca9464c8 Binary files /dev/null and b/lib/geotools/gt-ogr-core-11.0.jar differ diff --git a/lib/geotools/gt-ogr-jni-11.0.jar b/lib/geotools/gt-ogr-jni-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..724b65240bd46e9f572bb8e6f202c2a00f2fba82 Binary files /dev/null and b/lib/geotools/gt-ogr-jni-11.0.jar differ diff --git a/lib/geotools/gt-opengis-11.0.jar b/lib/geotools/gt-opengis-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..2705aabd6144d5662a4333af63a34595625b0618 Binary files /dev/null and b/lib/geotools/gt-opengis-11.0.jar differ diff --git a/lib/geotools/gt-process-11.0.jar b/lib/geotools/gt-process-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..d53e73bd9531f6a9d6b1044666629030cceccf61 Binary files /dev/null and b/lib/geotools/gt-process-11.0.jar differ diff --git a/lib/geotools/gt-process-feature-11.0.jar b/lib/geotools/gt-process-feature-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..9980c98007c0ceafb4f8bb58ee77b544e1f3faeb Binary files /dev/null and b/lib/geotools/gt-process-feature-11.0.jar differ diff --git a/lib/geotools/gt-process-geometry-11.0.jar b/lib/geotools/gt-process-geometry-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..b9af92c8303591932046ba9f11334d2f5e34e377 Binary files /dev/null and b/lib/geotools/gt-process-geometry-11.0.jar differ diff --git a/lib/geotools/gt-process-raster-11.0.jar b/lib/geotools/gt-process-raster-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..5d6db84125cfa4191f9a478d4a9e32568d4f4ef9 Binary files /dev/null and b/lib/geotools/gt-process-raster-11.0.jar differ diff --git a/lib/geotools/gt-property-11.0.jar b/lib/geotools/gt-property-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..4441522fc98fd52f1eea83bd5ec9458d86e92f5d Binary files /dev/null and b/lib/geotools/gt-property-11.0.jar differ diff --git a/lib/geotools/gt-property-ng-11.0.jar b/lib/geotools/gt-property-ng-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..5ff51c50728affae2acde840f77668b7f9068836 Binary files /dev/null and b/lib/geotools/gt-property-ng-11.0.jar differ diff --git a/lib/geotools/gt-referencing-11.0.jar b/lib/geotools/gt-referencing-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..15bf55d0c8dad76cb03099ea3d6529e2af439e8e Binary files /dev/null and b/lib/geotools/gt-referencing-11.0.jar differ diff --git a/lib/geotools/gt-referencing3D-11.0.jar b/lib/geotools/gt-referencing3D-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a594b256f0b2bbcd9ac5a569bba84c41c71344bc Binary files /dev/null and b/lib/geotools/gt-referencing3D-11.0.jar differ diff --git a/lib/geotools/gt-render-11.0.jar b/lib/geotools/gt-render-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..489c0b1bbda48bd3727b41ba7e8d7dbf3876a552 Binary files /dev/null and b/lib/geotools/gt-render-11.0.jar differ diff --git a/lib/geotools/gt-sample-data-11.0.jar b/lib/geotools/gt-sample-data-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..c673e47f7104b8b45149c0df28f17dbebb0c601a Binary files /dev/null and b/lib/geotools/gt-sample-data-11.0.jar differ diff --git a/lib/geotools/gt-sample-data-access-11.0.jar b/lib/geotools/gt-sample-data-access-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..672e6f5059a6bfa45e033148f2f3e5086d12a4dc Binary files /dev/null and b/lib/geotools/gt-sample-data-access-11.0.jar differ diff --git a/lib/geotools/gt-sfs-11.0.jar b/lib/geotools/gt-sfs-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..07c6c005f146c8029dd3bc1dfff26fa42083d149 Binary files /dev/null and b/lib/geotools/gt-sfs-11.0.jar differ diff --git a/lib/geotools/gt-shapefile-11.0.jar b/lib/geotools/gt-shapefile-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..93ca211874225c50a3eb6c30734890f6ba158cd2 Binary files /dev/null and b/lib/geotools/gt-shapefile-11.0.jar differ diff --git a/lib/geotools/gt-shapefile-old-11.0.jar b/lib/geotools/gt-shapefile-old-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..081b86d1ede7c6151cfb97d465e2d01ca95092a9 Binary files /dev/null and b/lib/geotools/gt-shapefile-old-11.0.jar differ diff --git a/lib/geotools/gt-svg-11.0.jar b/lib/geotools/gt-svg-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..3a44d9157332016a7084f8a367868a69fea24c9c Binary files /dev/null and b/lib/geotools/gt-svg-11.0.jar differ diff --git a/lib/geotools/gt-swing-11.0.jar b/lib/geotools/gt-swing-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..85c5b39d93f0391b4e0709aa53bd08009e602eef Binary files /dev/null and b/lib/geotools/gt-swing-11.0.jar differ diff --git a/lib/geotools/gt-swt-11.0.jar b/lib/geotools/gt-swt-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..3955717e3209154e33f8137987071f05759e9728 Binary files /dev/null and b/lib/geotools/gt-swt-11.0.jar differ diff --git a/lib/geotools/gt-transform-11.0.jar b/lib/geotools/gt-transform-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..9625ce8e81db34d6f619f9532e585d9e3261d47b Binary files /dev/null and b/lib/geotools/gt-transform-11.0.jar differ diff --git a/lib/geotools/gt-unidata-11.0.jar b/lib/geotools/gt-unidata-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..ba78836f5f49a4e34ccca0bffd7a815959cf5836 Binary files /dev/null and b/lib/geotools/gt-unidata-11.0.jar differ diff --git a/lib/geotools/gt-validation-11.0.jar b/lib/geotools/gt-validation-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..cd1534fe3879badaecf3d6b392cc9342d83e2ae8 Binary files /dev/null and b/lib/geotools/gt-validation-11.0.jar differ diff --git a/lib/geotools/gt-vpf-11.0.jar b/lib/geotools/gt-vpf-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a0f3aa4b1ecef0c2773534311d0695941ec85f9c Binary files /dev/null and b/lib/geotools/gt-vpf-11.0.jar differ diff --git a/lib/geotools/gt-wfs-11.0.jar b/lib/geotools/gt-wfs-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..a9c6ec3868ca2998b65bd8c6466564ceb08de0b3 Binary files /dev/null and b/lib/geotools/gt-wfs-11.0.jar differ diff --git a/lib/geotools/gt-wms-11.0.jar b/lib/geotools/gt-wms-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..556cd4e5e6b5d94c57c6059048d1b23a010a85dc Binary files /dev/null and b/lib/geotools/gt-wms-11.0.jar differ diff --git a/lib/geotools/gt-wps-11.0.jar b/lib/geotools/gt-wps-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..cb7c9e44954f6bd521cfeac7b2a09c7b5ba9e66b Binary files /dev/null and b/lib/geotools/gt-wps-11.0.jar differ diff --git a/lib/geotools/gt-xml-11.0.jar b/lib/geotools/gt-xml-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..271a32e4a257d954161d50f757114e855277bfed Binary files /dev/null and b/lib/geotools/gt-xml-11.0.jar differ diff --git a/lib/geotools/gt-xsd-core-11.0.jar b/lib/geotools/gt-xsd-core-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..faddcf732825941bc48e927151940a8ee045b78a Binary files /dev/null and b/lib/geotools/gt-xsd-core-11.0.jar differ diff --git a/lib/geotools/gt-xsd-csw-11.0.jar b/lib/geotools/gt-xsd-csw-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..53bbdfd113067098c0ec0de399fb1bb763b37d91 Binary files /dev/null and b/lib/geotools/gt-xsd-csw-11.0.jar differ diff --git a/lib/geotools/gt-xsd-fes-11.0.jar b/lib/geotools/gt-xsd-fes-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..f3fb5c033ecdf2329761d915fec3d4fe5c5e98ab Binary files /dev/null and b/lib/geotools/gt-xsd-fes-11.0.jar differ diff --git a/lib/geotools/gt-xsd-filter-11.0.jar b/lib/geotools/gt-xsd-filter-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..7730672e32beeb9caf6ed51b812c37b2d0d32e06 Binary files /dev/null and b/lib/geotools/gt-xsd-filter-11.0.jar differ diff --git a/lib/geotools/gt-xsd-gml2-11.0.jar b/lib/geotools/gt-xsd-gml2-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..d32bf3f7db0fc46fdf8e3ddedd11ae9cf12b9291 Binary files /dev/null and b/lib/geotools/gt-xsd-gml2-11.0.jar differ diff --git a/lib/geotools/gt-xsd-gml3-11.0.jar b/lib/geotools/gt-xsd-gml3-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..b9317962a2ad102c0fe1a6d6e375dcf34b990213 Binary files /dev/null and b/lib/geotools/gt-xsd-gml3-11.0.jar differ diff --git a/lib/geotools/gt-xsd-kml-11.0.jar b/lib/geotools/gt-xsd-kml-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..cc968d8dc5904fd4829a82cf9e96296ed6ac70bd Binary files /dev/null and b/lib/geotools/gt-xsd-kml-11.0.jar differ diff --git a/lib/geotools/gt-xsd-ows-11.0.jar b/lib/geotools/gt-xsd-ows-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..5306789f91ecdb05c955cb5c2a0a9c6af356148a Binary files /dev/null and b/lib/geotools/gt-xsd-ows-11.0.jar differ diff --git a/lib/geotools/gt-xsd-sld-11.0.jar b/lib/geotools/gt-xsd-sld-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..0405d4228cc31274f69e394aa3434463f8e3bd06 Binary files /dev/null and b/lib/geotools/gt-xsd-sld-11.0.jar differ diff --git a/lib/geotools/gt-xsd-wcs-11.0.jar b/lib/geotools/gt-xsd-wcs-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..c539531d7b3c35ecc6fd61044daaf703bf52b762 Binary files /dev/null and b/lib/geotools/gt-xsd-wcs-11.0.jar differ diff --git a/lib/geotools/gt-xsd-wfs-11.0.jar b/lib/geotools/gt-xsd-wfs-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..3149de549a287aa0ac5e8232828477acc2e88da9 Binary files /dev/null and b/lib/geotools/gt-xsd-wfs-11.0.jar differ diff --git a/lib/geotools/gt-xsd-wms-11.0.jar b/lib/geotools/gt-xsd-wms-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..da315c4ed8313cd324978dd682b12ac4692711e6 Binary files /dev/null and b/lib/geotools/gt-xsd-wms-11.0.jar differ diff --git a/lib/geotools/gt-xsd-wps-11.0.jar b/lib/geotools/gt-xsd-wps-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..8aa2e371c48646a1a8b0c24891d8c5f78335f21d Binary files /dev/null and b/lib/geotools/gt-xsd-wps-11.0.jar differ diff --git a/lib/geotools/h2-1.1.119.jar b/lib/geotools/h2-1.1.119.jar new file mode 100644 index 0000000000000000000000000000000000000000..4c004e33efdc6dcf35c12473afbfe5867b5f3c25 Binary files /dev/null and b/lib/geotools/h2-1.1.119.jar differ diff --git a/lib/geotools/header_osgeo.text b/lib/geotools/header_osgeo.text new file mode 100644 index 0000000000000000000000000000000000000000..1a93a218df01bd8b64958467f44d97c64e1079a7 --- /dev/null +++ b/lib/geotools/header_osgeo.text @@ -0,0 +1,17 @@ +/* + * GeoTools - The Open Source Java GIS Toolkit + * http://geotools.org + * + * (C) 2008, Open Source Geospatial Foundation (OSGeo) + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; + * version 2.1 of the License. + * + * This library 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 + * Lesser General Public License for more details. + */ + diff --git a/lib/geotools/header_publicDomain.text b/lib/geotools/header_publicDomain.text new file mode 100644 index 0000000000000000000000000000000000000000..8d85e4dc764e199c1cf356eb87ac84c4ea215f77 --- /dev/null +++ b/lib/geotools/header_publicDomain.text @@ -0,0 +1,10 @@ +/* + * GeoTools - The Open Source Java GIS Tookit + * http://geotools.org + * + * (C) 2008, Open Source Geospatial Foundation (OSGeo) + * + * This file is hereby placed into the Public Domain. This means anyone is + * free to do whatever they wish with this file. Use it well and enjoy! + */ + diff --git a/lib/geotools/hsqldb-2.2.8.jar b/lib/geotools/hsqldb-2.2.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..aee69efd5fc66759cd278007bf830b4095000abe Binary files /dev/null and b/lib/geotools/hsqldb-2.2.8.jar differ diff --git a/lib/geotools/icu4j-3.4.4.jar b/lib/geotools/icu4j-3.4.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..f5e8c167e7f7f3d078407859cb50b8abf23c697e Binary files /dev/null and b/lib/geotools/icu4j-3.4.4.jar differ diff --git a/lib/geotools/imageio-ext-arcgrid-1.1.8.jar b/lib/geotools/imageio-ext-arcgrid-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..0d2c253a404404f6853b63416a98e120ed4bc359 Binary files /dev/null and b/lib/geotools/imageio-ext-arcgrid-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalarcbinarygrid-1.1.8.jar b/lib/geotools/imageio-ext-gdalarcbinarygrid-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..c702cbed0fbabcf5849339594722e18926d4c94c Binary files /dev/null and b/lib/geotools/imageio-ext-gdalarcbinarygrid-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdaldted-1.1.8.jar b/lib/geotools/imageio-ext-gdaldted-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..ac753a44c8785b9fbfbdb8573b57fef58fae945d Binary files /dev/null and b/lib/geotools/imageio-ext-gdaldted-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalecw-1.1.8.jar b/lib/geotools/imageio-ext-gdalecw-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..68eeab07f5d0da3db904c813b338e14bb2f5055c Binary files /dev/null and b/lib/geotools/imageio-ext-gdalecw-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalecwjp2-1.1.8.jar b/lib/geotools/imageio-ext-gdalecwjp2-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..f8c6a7aa652e7fe9fa366b8878d697a0664869cb Binary files /dev/null and b/lib/geotools/imageio-ext-gdalecwjp2-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalehdr-1.1.8.jar b/lib/geotools/imageio-ext-gdalehdr-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..1f47dadb4183bed5a93ddaa1f37edcb9f840f1c4 Binary files /dev/null and b/lib/geotools/imageio-ext-gdalehdr-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalenvihdr-1.1.8.jar b/lib/geotools/imageio-ext-gdalenvihdr-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..bc58fe2c78ef7864ddb5f25bbc4d7ff8b546fe0b Binary files /dev/null and b/lib/geotools/imageio-ext-gdalenvihdr-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalerdasimg-1.1.8.jar b/lib/geotools/imageio-ext-gdalerdasimg-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..138d2cb63c33e74edaf036d54036c80b83d68ba0 Binary files /dev/null and b/lib/geotools/imageio-ext-gdalerdasimg-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalidrisi-1.1.8.jar b/lib/geotools/imageio-ext-gdalidrisi-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..e4e40eac45953e249a6d09ac622f0f0fba843ba6 Binary files /dev/null and b/lib/geotools/imageio-ext-gdalidrisi-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalkakadujp2-1.1.8.jar b/lib/geotools/imageio-ext-gdalkakadujp2-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..d18af85b110316a8289c62512f3135a21fbfc161 Binary files /dev/null and b/lib/geotools/imageio-ext-gdalkakadujp2-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalmrsid-1.1.8.jar b/lib/geotools/imageio-ext-gdalmrsid-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..4644c951441e7315fd825252f327441719e308fe Binary files /dev/null and b/lib/geotools/imageio-ext-gdalmrsid-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalmrsidjp2-1.1.8.jar b/lib/geotools/imageio-ext-gdalmrsidjp2-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..a07c40426bfe2166e691460d92ab79787ddab1db Binary files /dev/null and b/lib/geotools/imageio-ext-gdalmrsidjp2-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalnitf-1.1.8.jar b/lib/geotools/imageio-ext-gdalnitf-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..271f1bd6021036b3a51c93da8e4779609e277b10 Binary files /dev/null and b/lib/geotools/imageio-ext-gdalnitf-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-gdalrpftoc-1.1.8.jar b/lib/geotools/imageio-ext-gdalrpftoc-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..4e975c584fb4536c3b5fae63abde786d7bbf8af0 Binary files /dev/null and b/lib/geotools/imageio-ext-gdalrpftoc-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-geocore-1.1.8.jar b/lib/geotools/imageio-ext-geocore-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..2b3d1bbd666286584a226681404f4e70e478808d Binary files /dev/null and b/lib/geotools/imageio-ext-geocore-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-imagereadmt-1.1.8.jar b/lib/geotools/imageio-ext-imagereadmt-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..5f39c9063a6cb191c9f3a07c8051e9505ae8f4e8 Binary files /dev/null and b/lib/geotools/imageio-ext-imagereadmt-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-imagereadmt-1.1M012010.jar b/lib/geotools/imageio-ext-imagereadmt-1.1M012010.jar new file mode 100644 index 0000000000000000000000000000000000000000..58eefb1cb688cf70976c0005a03dad376346d8d6 Binary files /dev/null and b/lib/geotools/imageio-ext-imagereadmt-1.1M012010.jar differ diff --git a/lib/geotools/imageio-ext-kakadu-1.1.8.jar b/lib/geotools/imageio-ext-kakadu-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..674bc389f945eb69d4305971eaaefaa03e951215 Binary files /dev/null and b/lib/geotools/imageio-ext-kakadu-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-mat-sas-1.1M012010.jar b/lib/geotools/imageio-ext-mat-sas-1.1M012010.jar new file mode 100644 index 0000000000000000000000000000000000000000..369a528bf847a795d1cee6a9b1fc525de366b68b Binary files /dev/null and b/lib/geotools/imageio-ext-mat-sas-1.1M012010.jar differ diff --git a/lib/geotools/imageio-ext-streams-1.1.8.jar b/lib/geotools/imageio-ext-streams-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..cad7b71e3a9a846b946d9c31c95b4b0aee7241ec Binary files /dev/null and b/lib/geotools/imageio-ext-streams-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-tiff-1.1.8.jar b/lib/geotools/imageio-ext-tiff-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..7ccdee7423dbfb2023cb79e76b01ddd7b5fbbfec Binary files /dev/null and b/lib/geotools/imageio-ext-tiff-1.1.8.jar differ diff --git a/lib/geotools/imageio-ext-utilities-1.1.8.jar b/lib/geotools/imageio-ext-utilities-1.1.8.jar new file mode 100644 index 0000000000000000000000000000000000000000..bd4e7fb0683ebe665416b64b16d1d9589324045b Binary files /dev/null and b/lib/geotools/imageio-ext-utilities-1.1.8.jar differ diff --git a/lib/geotools/jai_codec-1.1.3.jar b/lib/geotools/jai_codec-1.1.3.jar new file mode 100644 index 0000000000000000000000000000000000000000..056ecd3a741e0e8e9e68054110c63f72d35d8095 Binary files /dev/null and b/lib/geotools/jai_codec-1.1.3.jar differ diff --git a/lib/geotools/jai_core-1.1.3.jar b/lib/geotools/jai_core-1.1.3.jar new file mode 100644 index 0000000000000000000000000000000000000000..b29b8eed5bb38c8f49215efdbf07a6038674c56a Binary files /dev/null and b/lib/geotools/jai_core-1.1.3.jar differ diff --git a/lib/geotools/jai_imageio-1.1.jar b/lib/geotools/jai_imageio-1.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..571aa199fae498bb66a45df18f5f1c028794a4e7 Binary files /dev/null and b/lib/geotools/jai_imageio-1.1.jar differ diff --git a/lib/geotools/javacsv-2.0.jar b/lib/geotools/javacsv-2.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..125c4d0270b3fe50bd49abd5f9275bccc47e2fcd Binary files /dev/null and b/lib/geotools/javacsv-2.0.jar differ diff --git a/lib/geotools/jdom-1.1.3.jar b/lib/geotools/jdom-1.1.3.jar new file mode 100644 index 0000000000000000000000000000000000000000..a287727868572178c408ef6ffad0a5f27baed34b Binary files /dev/null and b/lib/geotools/jdom-1.1.3.jar differ diff --git a/lib/geotools/jface-3.6.1.M20100825-0800.jar b/lib/geotools/jface-3.6.1.M20100825-0800.jar new file mode 100644 index 0000000000000000000000000000000000000000..a1bb7a958349d0d9fe2bd2a1acd53d8ee1a648a9 Binary files /dev/null and b/lib/geotools/jface-3.6.1.M20100825-0800.jar differ diff --git a/lib/geotools/jgridshift-1.0.jar b/lib/geotools/jgridshift-1.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..d9b8d3283d7cfa126e5d0b73ee43b8aa9a5596e1 Binary files /dev/null and b/lib/geotools/jgridshift-1.0.jar differ diff --git a/lib/geotools/json-simple-1.1.jar b/lib/geotools/json-simple-1.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..f395f41471a796876278a6c5667ded4632546893 Binary files /dev/null and b/lib/geotools/json-simple-1.1.jar differ diff --git a/lib/geotools/jsqlparser-0.3.14.jar b/lib/geotools/jsqlparser-0.3.14.jar new file mode 100644 index 0000000000000000000000000000000000000000..f5adba8e590c92fcc67d237cf271f27d97a8b49b Binary files /dev/null and b/lib/geotools/jsqlparser-0.3.14.jar differ diff --git a/lib/geotools/jsr-275-1.0-beta-2.jar b/lib/geotools/jsr-275-1.0-beta-2.jar new file mode 100644 index 0000000000000000000000000000000000000000..68e19aa4d16331034d2ddd5117040401587fa288 Binary files /dev/null and b/lib/geotools/jsr-275-1.0-beta-2.jar differ diff --git a/lib/geotools/jt-contour-1.3.1.jar b/lib/geotools/jt-contour-1.3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..e592c5701d4123b89d334d7c184c67384a95d3d0 Binary files /dev/null and b/lib/geotools/jt-contour-1.3.1.jar differ diff --git a/lib/geotools/jt-rangelookup-1.3.1.jar b/lib/geotools/jt-rangelookup-1.3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..768316a8da081d5c77bc11ddfe53c89b37ceb60b Binary files /dev/null and b/lib/geotools/jt-rangelookup-1.3.1.jar differ diff --git a/lib/geotools/jt-utils-1.3.1.jar b/lib/geotools/jt-utils-1.3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..2c869f094038b4f159fc978b16a06008af801a0b Binary files /dev/null and b/lib/geotools/jt-utils-1.3.1.jar differ diff --git a/lib/geotools/jt-vectorbinarize-1.3.1.jar b/lib/geotools/jt-vectorbinarize-1.3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..7ff9d8a67920852d44a71f8cf0cea479b714686b Binary files /dev/null and b/lib/geotools/jt-vectorbinarize-1.3.1.jar differ diff --git a/lib/geotools/jt-vectorize-1.3.1.jar b/lib/geotools/jt-vectorize-1.3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..2f778e47ca4052f829a6a8954204e1f7d67b9411 Binary files /dev/null and b/lib/geotools/jt-vectorize-1.3.1.jar differ diff --git a/lib/geotools/jt-zonalstats-1.3.1.jar b/lib/geotools/jt-zonalstats-1.3.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..b45c885e9a9fb19b18be6f25f6973e4ba6037f96 Binary files /dev/null and b/lib/geotools/jt-zonalstats-1.3.1.jar differ diff --git a/lib/geotools/jts-1.13.jar b/lib/geotools/jts-1.13.jar new file mode 100644 index 0000000000000000000000000000000000000000..bbaa20bfacd9652b611dea390e9e798c0be4430a Binary files /dev/null and b/lib/geotools/jts-1.13.jar differ diff --git a/lib/geotools/log4j-over-slf4j-1.6.4.jar b/lib/geotools/log4j-over-slf4j-1.6.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..ac397ff7457aa6a120c496e56e0d19f1158d89c1 Binary files /dev/null and b/lib/geotools/log4j-over-slf4j-1.6.4.jar differ diff --git a/lib/geotools/miglayout-3.7-swing.jar b/lib/geotools/miglayout-3.7-swing.jar new file mode 100644 index 0000000000000000000000000000000000000000..3261fb628d1cfc21352ad80ba91485c963b2f823 Binary files /dev/null and b/lib/geotools/miglayout-3.7-swing.jar differ diff --git a/lib/geotools/mongo-java-driver-2.5.jar b/lib/geotools/mongo-java-driver-2.5.jar new file mode 100644 index 0000000000000000000000000000000000000000..897baae7649fe4b0fa07d2383236342c6cc5a487 Binary files /dev/null and b/lib/geotools/mongo-java-driver-2.5.jar differ diff --git a/lib/geotools/mysql-connector-java-5.1.17.jar b/lib/geotools/mysql-connector-java-5.1.17.jar new file mode 100644 index 0000000000000000000000000000000000000000..026dc397cb22aee3e943d189539b2f1cf47a2895 Binary files /dev/null and b/lib/geotools/mysql-connector-java-5.1.17.jar differ diff --git a/lib/geotools/net.opengis.csw-11.0.jar b/lib/geotools/net.opengis.csw-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..6cfdd6aec5651df7ec76f37a0be4f1097378e573 Binary files /dev/null and b/lib/geotools/net.opengis.csw-11.0.jar differ diff --git a/lib/geotools/net.opengis.fes-11.0.jar b/lib/geotools/net.opengis.fes-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..6a7aae830c70fe3a7d349c21f8f4c2304fbea9c1 Binary files /dev/null and b/lib/geotools/net.opengis.fes-11.0.jar differ diff --git a/lib/geotools/net.opengis.ows-11.0.jar b/lib/geotools/net.opengis.ows-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..ddceb0f4da95f0aeec587c14677f2ac7bb9dadb9 Binary files /dev/null and b/lib/geotools/net.opengis.ows-11.0.jar differ diff --git a/lib/geotools/net.opengis.wcs-11.0.jar b/lib/geotools/net.opengis.wcs-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..6be7657910eca65ac134d819debaf1bd10ff143c Binary files /dev/null and b/lib/geotools/net.opengis.wcs-11.0.jar differ diff --git a/lib/geotools/net.opengis.wfs-11.0.jar b/lib/geotools/net.opengis.wfs-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..2540f1126ddb78bc5e3adc685cd86e2e939da027 Binary files /dev/null and b/lib/geotools/net.opengis.wfs-11.0.jar differ diff --git a/lib/geotools/net.opengis.wps-11.0.jar b/lib/geotools/net.opengis.wps-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..24148fd03773612262f8f950b3e32e1e1009762b Binary files /dev/null and b/lib/geotools/net.opengis.wps-11.0.jar differ diff --git a/lib/geotools/netcdf-4.3.16.jar b/lib/geotools/netcdf-4.3.16.jar new file mode 100644 index 0000000000000000000000000000000000000000..946a82d8bafa455d4d286888a940aad82a4862f0 Binary files /dev/null and b/lib/geotools/netcdf-4.3.16.jar differ diff --git a/lib/geotools/opendap-2.1.jar b/lib/geotools/opendap-2.1.jar new file mode 100644 index 0000000000000000000000000000000000000000..0ec294983a5b484d7bd6c9a9b6aa8c71190e7e82 Binary files /dev/null and b/lib/geotools/opendap-2.1.jar differ diff --git a/lib/geotools/org.w3.xlink-11.0.jar b/lib/geotools/org.w3.xlink-11.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..e8b41e3506aaaf6bd80ecaf081632391f77685bf Binary files /dev/null and b/lib/geotools/org.w3.xlink-11.0.jar differ diff --git a/lib/geotools/picocontainer-1.2.jar b/lib/geotools/picocontainer-1.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..fbb1c925b8c9dd184dde9b14bfd53d40ab5decb2 Binary files /dev/null and b/lib/geotools/picocontainer-1.2.jar differ diff --git a/lib/geotools/postgresql-8.4-701.jdbc3.jar b/lib/geotools/postgresql-8.4-701.jdbc3.jar new file mode 100644 index 0000000000000000000000000000000000000000..c64b709e1874abb059418253d00a1cfdc6616a30 Binary files /dev/null and b/lib/geotools/postgresql-8.4-701.jdbc3.jar differ diff --git a/lib/geotools/slf4j-log4j12-1.5.6.jar b/lib/geotools/slf4j-log4j12-1.5.6.jar new file mode 100644 index 0000000000000000000000000000000000000000..97241bb140b80b5ed63724040694d63131cba3ee Binary files /dev/null and b/lib/geotools/slf4j-log4j12-1.5.6.jar differ diff --git a/lib/geotools/slf4j-log4j12-1.6.4.jar b/lib/geotools/slf4j-log4j12-1.6.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..1517fbd140eac1e14c944dfb875954895787ae35 Binary files /dev/null and b/lib/geotools/slf4j-log4j12-1.6.4.jar differ diff --git a/lib/geotools/spatialite-jdbc-3.7.2-2.4.jar b/lib/geotools/spatialite-jdbc-3.7.2-2.4.jar new file mode 100644 index 0000000000000000000000000000000000000000..45382009205314d2e3a97f8708a998912782107a Binary files /dev/null and b/lib/geotools/spatialite-jdbc-3.7.2-2.4.jar differ diff --git a/lib/geotools/sqlite-jdbc-3.7.2.jar b/lib/geotools/sqlite-jdbc-3.7.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..2030ea0f116f6aaf85f2a4f87dc064e12c466e81 Binary files /dev/null and b/lib/geotools/sqlite-jdbc-3.7.2.jar differ diff --git a/lib/geotools/swt.gtk.linux.x86-3.6.1.v3655c.jar b/lib/geotools/swt.gtk.linux.x86-3.6.1.v3655c.jar new file mode 100644 index 0000000000000000000000000000000000000000..5b2a6d17bd5373ad1fdc01907eb049aa9cf20010 Binary files /dev/null and b/lib/geotools/swt.gtk.linux.x86-3.6.1.v3655c.jar differ diff --git a/lib/geotools/swt.win32.win32.x86_64-3.6.1.v3655c.jar b/lib/geotools/swt.win32.win32.x86_64-3.6.1.v3655c.jar new file mode 100644 index 0000000000000000000000000000000000000000..eebd5da67e3ab67464bfa4a5b9ba1df1189cf906 Binary files /dev/null and b/lib/geotools/swt.win32.win32.x86_64-3.6.1.v3655c.jar differ diff --git a/lib/geotools/target/VERSION.txt b/lib/geotools/target/VERSION.txt new file mode 100644 index 0000000000000000000000000000000000000000..c1624d88240e204ef70282bc5d953e7c90686598 --- /dev/null +++ b/lib/geotools/target/VERSION.txt @@ -0,0 +1,3 @@ +version: 11.0 +git revision: 5980067537bb0903b1e9016c9aeb57371a860ca4 +build date: 18-Mar-2014 17:16 diff --git a/lib/geotools/ui.workbench-3.6.1.M20100826-1330.jar b/lib/geotools/ui.workbench-3.6.1.M20100826-1330.jar new file mode 100644 index 0000000000000000000000000000000000000000..5b035327b83db0f93e0880490c5a2d72ff814022 Binary files /dev/null and b/lib/geotools/ui.workbench-3.6.1.M20100826-1330.jar differ diff --git a/lib/geotools/vecmath-1.3.2.jar b/lib/geotools/vecmath-1.3.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..9b00b8c52ec7d78c673a24017975961817583f6d Binary files /dev/null and b/lib/geotools/vecmath-1.3.2.jar differ diff --git a/lib/geotools/xml-commons-resolver-1.2.jar b/lib/geotools/xml-commons-resolver-1.2.jar new file mode 100644 index 0000000000000000000000000000000000000000..e535bdc073355b300614041be473988c3a6c8624 Binary files /dev/null and b/lib/geotools/xml-commons-resolver-1.2.jar differ diff --git a/lib/geotools/xpp3_min-1.1.4c.jar b/lib/geotools/xpp3_min-1.1.4c.jar new file mode 100644 index 0000000000000000000000000000000000000000..813a9a830bd0c09bfb45084633ccbe88ba64498f Binary files /dev/null and b/lib/geotools/xpp3_min-1.1.4c.jar differ diff --git a/lib/geotools/xsd-2.6.0.jar b/lib/geotools/xsd-2.6.0.jar new file mode 100644 index 0000000000000000000000000000000000000000..28ff987cef80b6217ca035a7ce5c3980a667a189 Binary files /dev/null and b/lib/geotools/xsd-2.6.0.jar differ diff --git a/src/eu/simstadt/nf/Coord.java b/src/eu/simstadt/nf/Coord.java new file mode 100644 index 0000000000000000000000000000000000000000..e17ed35dcc44ed3fe0da332466584e8538db4a57 --- /dev/null +++ b/src/eu/simstadt/nf/Coord.java @@ -0,0 +1,26 @@ +package eu.simstadt.nf; + +/** + * This is an intermediate representation for WGS 84 coordinates. + * + * @author Marcel Bruse + */ +public class Coord { + + /** The latitude of the geographic position. */ + public double latitude; + + /** The longitude of the geographic position. */ + public double longitude; + + /** Standard constructor. + * + * @param latitude The latitude of the WGS 84 coordinate. + * @param longitude The longitude of the WGS 84 coordinate. + */ + public Coord(double latitude, double longitude) { + this.latitude = latitude; + this.longitude = longitude; + } + +} diff --git a/src/eu/simstadt/nf/JobStatus.java b/src/eu/simstadt/nf/JobStatus.java new file mode 100644 index 0000000000000000000000000000000000000000..e9771cdf813e9d758a72ceb88f40f892806927c6 --- /dev/null +++ b/src/eu/simstadt/nf/JobStatus.java @@ -0,0 +1,74 @@ +package eu.simstadt.nf; + +/** + * Enumeration of possible states of nF import and export jobs. + * + * @author Marcel Bruse + */ +public enum JobStatus { + UNKOWN(-1), PENDING(0), RUNNING(10), FAILED(20), FINISHED(30); + + public static final String UNKNOWN_STATUS_MESSAGE = "The state of the job is unknown."; + public static final String PENDING_MESSAGE = "Job is pending."; + public static final String RUNNING_MESSAGE = "Job is running."; + public static final String FAILED_MESSAGE = "Job failed."; + public static final String FINISHED_MESSAGE = "Job is finished."; + + private int jobId; + private int value; + private String message; + + private JobStatus(int value) { + this.value = value; + if (value == 0) { + message = PENDING_MESSAGE; + } else if (value == 10) { + message = RUNNING_MESSAGE; + } else if (value == 20) { + message = FAILED_MESSAGE; + } else if (value == 30) { + message = FINISHED_MESSAGE; + } else { + message = UNKNOWN_STATUS_MESSAGE; + } + } + + public static JobStatus getInstanceForStatus(int status) { + if (status == 0) { + return PENDING; + } else if (status == 10) { + return RUNNING; + } else if (status == 20) { + return FAILED; + } else if (status == 30) { + return FINISHED; + } else { + return UNKOWN; + } + } + + public int getValue() { + return value; + } + + public int getJobId() { + return jobId; + } + + public void setJobId(int jobId) { + this.jobId = jobId; + } + + public void setMessage(String message) { + this.message = message; + } + + public String getMessage() { + return message; + } + + public boolean isFinished() { + return this == FINISHED; + } + +} diff --git a/src/eu/simstadt/nf/Main.java b/src/eu/simstadt/nf/Main.java new file mode 100644 index 0000000000000000000000000000000000000000..74a87c6b8a3399a217a8b55556fa092aa809d4ae --- /dev/null +++ b/src/eu/simstadt/nf/Main.java @@ -0,0 +1,37 @@ +package eu.simstadt.nf; + +import java.io.File; +import java.io.FileNotFoundException; +import java.io.PrintWriter; +import java.util.Arrays; +import java.util.List; + +public class Main { + + public static void main(String[] args) { +// List<Coord> regionPolygon = Arrays.asList( +// new Coord(48.879696, 9.215463), +// new Coord(48.878230, 9.215714), +// new Coord(48.878323, 9.216613), +// new Coord(48.879402, 9.216532) +// ); +// String exportJobDescription = NFJobBuilder.buildExportJob(regionPolygon); +// +// String filename = "tmp.xml"; +// +// try { +// PrintWriter writer = new PrintWriter(filename); +// writer.print(exportJobDescription); +// writer.close(); +// +// File exportJobFile = new File(filename); +// NFConnector connector = new NFConnectorImpl("193.196.136.164"); +// JobStatus status = connector.sendExportJob(exportJobFile); +// System.out.println(status + " - " + status.getMessage()); +// } catch (FileNotFoundException ex) { +// // TODO Auto-generated catch block +// ex.printStackTrace(); +// } + } + +} \ No newline at end of file diff --git a/src/eu/simstadt/nf/NFConnector.java b/src/eu/simstadt/nf/NFConnector.java new file mode 100644 index 0000000000000000000000000000000000000000..bd6e4947267775df0ac0578b74c99e46c7d5572c --- /dev/null +++ b/src/eu/simstadt/nf/NFConnector.java @@ -0,0 +1,49 @@ +package eu.simstadt.nf; + +import java.io.File; + +/** + * NFConnector lets you communicate with your novaFACTORY (nF) server instance. + * + * @author Marcel Bruse + */ +public interface NFConnector { + + /** + * Callers of this NFConnector want to know the actual version of the novaFACTORY and the versions of its + * HTTP/FTP/WPS/etc. interfaces against which this interface has been implemented. + * + * The various NovaFACTORY interfaces may change over time. Such changes force the SimStadt programmers to + * implement different versions of this NFConnector interface while keeping old implementations due to + * backward comparability. + * + * @return The supported version of the novaFACTORY. + */ + public String supportsNFVersion(); + + /** + * Sends an export job to nF. The job has to be passed and to be described in an appropriate XML format. + * The DTD of the XML format can be obtained from the nF installation or documentation. + * + * @param file The nF export job as a prepared XML file. + * @return The status of the job. Could be pending or failed. + */ + public JobStatus sendExportJob(File file); + + /** + * Returns the status of any existing nF job. + * + * @param jobId The id of the job for which you want to request the status. + * @return The status of any existing nF job. + */ + public JobStatus requestJobStatus(int jobId); + + /** + * Downloads the result for a given nF export job and hands over the corresponding file handle. + * + * @param jobId The id of the export job for which the result should be loaded. + * @return A file handle to the result of the nF export job. + */ + public File requestJobResult(int jobId); + +} diff --git a/src/eu/simstadt/nf/NFConnectorImpl.java b/src/eu/simstadt/nf/NFConnectorImpl.java new file mode 100644 index 0000000000000000000000000000000000000000..9460fde9d6854012ba7f7f4eb79020f602e522a8 --- /dev/null +++ b/src/eu/simstadt/nf/NFConnectorImpl.java @@ -0,0 +1,376 @@ +package eu.simstadt.nf; + +import java.io.BufferedReader; +import java.io.File; +import java.io.FileOutputStream; +import java.io.IOException; +import java.io.InputStream; +import java.io.InputStreamReader; +import java.io.OutputStream; +import java.io.OutputStreamWriter; +import java.io.PrintWriter; +import java.io.StringReader; +import java.io.UnsupportedEncodingException; +import java.net.HttpURLConnection; +import java.net.MalformedURLException; +import java.net.URL; +import java.nio.file.Files; +import java.util.Arrays; +import java.util.List; +import java.util.Objects; + +import javax.xml.parsers.ParserConfigurationException; +import javax.xml.parsers.SAXParser; +import javax.xml.parsers.SAXParserFactory; + +import org.xml.sax.InputSource; +import org.xml.sax.SAXException; + +/** + * NFConnector lets you communicate with your novaFACTORY (nF) server instance. It supports nF version 6.3.1.1. + * For more technical details about the NFConnector interface @see NFConnector. + * + * @author Marcel Bruse + */ +public class NFConnectorImpl implements NFConnector { + + /** Supported version of the novaFACTORY. */ + public static final String NOVA_FACTORY_VERSION = "6.3.1.1"; + + /** The default context of the nF web application. It is part of any request URL directed at the nF server. */ + public static final String DEFAULT_CONTEXT = "novaFACTORY"; + + /** The default port number of the nF web application. */ + public static final int DEFAULT_PORT = 80; + + /** The default protocol for requests. */ + public static final String DEFAULT_PROTOCOL = "http"; + + /** The standard char set for requests. */ + public static final String DEFAULT_CHARSET = "UTF-8"; + + /** The standard line separator required for file transmission via multipart/form-data. */ + public static final String CRLF = "\r\n"; + + /** The name of nF's remote order servlet. */ + public static final String REMOTE_ORDER_SERVLET = "RemoteOrder"; + + /** The name of nF's remote status servlet. */ + public static final String REMOTE_STATUS_SERVLET = "RemoteStatus"; + + /** The name of nF's remote import servlet. */ + public static final String REMOTE_IMPORT_SERVLET = "RemoteImport"; + + /** Default parser error message. */ + public static final String XML_PARSER_ERROR = "Request failed due to an unknown XML parser error."; + + /** Default IO exception occurred message. */ + public static final String IO_EXCEPTION_OCCURRED = + "Request failed due to an IO exception. Check the host and port."; + + /** Default malformed URL message. */ + public static final String MALFORMED_URL = "Request failed due to a malformed URL."; + + /** Default unknown error message. */ + public static final String UNKNOWN_ERROR_OCCURRED = "An unknown error occurred."; + + /** The server or host name of the nF server. */ + private String server; + + /** The port of the nF server. */ + private int port; + + /** The protocol of the data connection. */ + private String protocol; + + /** The context of the nF web application. It is part of any request URL directed at the nF server. */ + private String context; + + /** + * Constructs your NFConnector instance. + * + * @param server The host name of the nF server with which you want to establish a data connection. + */ + public NFConnectorImpl(String server) { + this(server, DEFAULT_PORT, DEFAULT_CONTEXT, DEFAULT_PROTOCOL); + } + + /** + * Constructs your NFConnector instance. + * + * @param server The host name of the nF server with which you want to establish a data connection. + * @param port The port of the nF web application. + * @param context The context of the nF web application. It is part of any request URL directed at the nF server. + */ + public NFConnectorImpl(String server, int port, String context, String protocol) { + this.server = server; + this.port = port; + this.context = context; + this.protocol = protocol; + } + + /** + * Callers of this NFConnector want to know the actual version of the novaFACTORY and the versions of its + * HTTP/FTP/WPS/etc. interfaces against which this interface has been implemented. + * + * The NovaFACTORY interfaces may change over time. Such changes force the SimStadt programmers to + * implement different versions of this NFConnector interface while keeping old implementations in order to + * ensure backward compatibility. + * + * @return The supported version of the novaFACTORY. + */ + @Override + public String supportsNFVersion() { + return NOVA_FACTORY_VERSION; + } + + /** + * Returns the status of any existing nF job. + * + * @param jobId The id of the job for which you want to request the status. + * @return The status of any existing nF job. + * @throws IOException An error occurred during the request. This could be a malformed URL or a network failure. + */ + @Override + public JobStatus requestJobStatus(int jobId) { + JobStatus result = JobStatus.UNKOWN; + try { + List<String> parameters = Arrays.asList(buildParameter("jobid", jobId)); + result = getJobStatusFromResponse(getResponse(buildURL(REMOTE_STATUS_SERVLET, parameters))); + } catch (MalformedURLException ex) { + result.setMessage(MALFORMED_URL); + } catch (IOException ex) { + result.setMessage(IO_EXCEPTION_OCCURRED); + } catch (ParserConfigurationException | SAXException ex) { + result.setMessage(XML_PARSER_ERROR); + } + return result; + } + + /** + * Downloads the result for a given nF export job and hands over the corresponding file handle. + * + * @param jobId The id of the export job for which the result should be loaded. + * @return A file handle to the result of the nF export job. + */ + @Override + public File requestJobResult(int jobId) { + File result = null; + try { + List<String> parameters = Arrays.asList( + buildParameter("request", "downloadJob"), + buildParameter("mode", 0), + buildParameter("jobId", jobId)); + result = downloadFile(buildURL(REMOTE_ORDER_SERVLET, parameters)); + } catch (MalformedURLException ex) { + ex.printStackTrace(); + } catch (IOException ex) { + ex.printStackTrace(); + } + return result; + } + + /** + * Builds a simple parameter string for a HTTP GET request string. + * + * @param key The parameter name. + * @param value The value of the parameter. + * @return The HTTP GET request parameter as concatenated key and value. + */ + private String buildParameter(String key, Object value) { + return key + "=" + value; + } + + /** + * Builds a HTTP GET request URL out of the used protocol, nF server, port, context, servlet and existing + * parameters. + * + * @param servlet One of the supported nF servlets RemoteOrder, RemoteStatus or RemoteImport. + * @param parameters List of parameters to be send to the servlet. + * @return The built URL instance. + * @throws MalformedURLException You will get some of this, if you mess up any part of the URL. + */ + private URL buildURL(String servlet, List<String> parameters) throws MalformedURLException { + String url = String.format("%s://%s:%s/%s/%s", protocol, server, port, context, servlet); + if (Objects.nonNull(parameters) && !parameters.isEmpty()) { + url += "?" + String.join("&", parameters); + } + return new URL(url); + } + + /** + * Requests a response from the given URL. The response is expected to be returned as nF XML report. + * + * @param url The URL of the nF servlet with all its necessary parameters. Read the nF handbook for more + * details about the usage of nF servlets. + * @return The response is expected to be a XML report, which will then be returned as a String. + * @throws IOException You will get some of this, if anything goes wrong with your data connection to your + * nF instance. + */ + private String getResponse(URL url) throws UnsupportedEncodingException, IOException { + HttpURLConnection httpConnection = (HttpURLConnection) url.openConnection(); + httpConnection.setRequestProperty("Accept-Charset", DEFAULT_CHARSET); + return getResponse(httpConnection); + } + + /** + * Requests a response from the given HTTP connection. The response is expected to be a XML document. + * + * @param httpConnection The HTTP Connection to the nF servlet. Read the nF handbook for more details + * about the usage of the nF servlets. + * @return The response is expected to be a XML report, which will then be returned as a String. + * @throws UnsupportedEncodingException You will get some of this, if your connection uses wrong encodings. + * @throws IOException You will get some of this, if anything goes wrong with your data connection to your + * nF instance. + */ + private String getResponse(HttpURLConnection httpConnection) throws UnsupportedEncodingException, IOException { + String xml = ""; + if (httpConnection.getResponseCode() == HttpURLConnection.HTTP_OK) { + String contentType = httpConnection.getHeaderField("Content-Type"); + String charset = null; + for (String param : contentType.replace(" ", "").split(";")) { + if (param.startsWith("charset=")) { + charset = param.split("=", 2)[1]; + break; + } + } + InputStream response = httpConnection.getInputStream(); + if (Objects.nonNull(charset)) { + BufferedReader reader = new BufferedReader(new InputStreamReader(response, charset)); + String line; + while ((line = reader.readLine()) != null) { + xml += line; + } + } + response.close(); + } else { + throw new IOException(); + } + return xml; + } + + /** + * If everything works as expected, then nF's servlets will respond with XML reports to your requests. The job + * status will be extracted from the response string. The XML reports have a certain structure. Read the nF + * manual for more information about the XML reports and have a look at the DTD of the XML reports. + * + * @param xml A XML string that is supposed to be a XML document. + * @return The status of the job which was encoded in the given XML string. + * @throws ParserConfigurationException Something went wrong. + * @throws SAXException Some parse error. + * @throws IOException Some parse error. + */ + private JobStatus getJobStatusFromResponse(String xml) + throws ParserConfigurationException, SAXException, IOException { + JobStatus result = JobStatus.UNKOWN; + SAXParserFactory saxFactory = SAXParserFactory.newInstance(); + SAXParser parser = saxFactory.newSAXParser(); + StringReader reader = new StringReader(xml); + ReportHandler handler = new ReportHandler(); + parser.parse(new InputSource(reader), handler); + if (Objects.nonNull(handler.serviceException)) { + result.setMessage(handler.serviceException); + } else if (Objects.nonNull(handler.statusId)) { + result = JobStatus.getInstanceForStatus(handler.statusId); + } + if (Objects.nonNull(handler.jobId)) { + result.setJobId(handler.jobId); + } + return result; + } + + /** + * Downloads a (zipped) CityGML file from the nF server. The file will be the result of an export job. + * + * @param url The URL of the remote order servlet that points at the CityGML file on the nF server. + * @return Returns a handle to the downloaded (zipped) CityGML file. + * @throws IOException Something went wrong with your data connection. Check your server and the port. + */ + private File downloadFile(URL url) throws IOException { + File handle = null; + HttpURLConnection httpConnection = (HttpURLConnection) url.openConnection(); + httpConnection.setRequestProperty("Accept-Charset", DEFAULT_CHARSET); + if (httpConnection.getResponseCode() == HttpURLConnection.HTTP_OK) { + String filename = "result.gml"; + String disposition = httpConnection.getHeaderField("Content-Disposition"); + if (disposition != null) { + int index = disposition.indexOf("filename="); + if (index > -1) { + filename = disposition. + substring(index + 9, disposition.length()). + replaceAll("\"", ""). + replaceAll(";", ""); + } + } + InputStream inputStream = httpConnection.getInputStream(); + FileOutputStream outputStream = new FileOutputStream(filename); + int bytesRead = -1; + byte[] buffer = new byte[4096]; + while ((bytesRead = inputStream.read(buffer)) != -1) { + outputStream.write(buffer, 0, bytesRead); + } + outputStream.close(); + inputStream.close(); + handle = new File(filename); + } else { + throw new IOException(); + } + return handle; + } + + /** + * Sends an export job to the nF. This job will be enqueued in the queue of export jobs. + * + * @param file The XML file which describes the nF export job. + * @return Returns the status of the export job you just sent. + */ + @Override + public JobStatus sendExportJob(File file) { + JobStatus result = JobStatus.UNKOWN; + try { + URL url = buildURL(REMOTE_ORDER_SERVLET, null); + JobStatus status = sendFile(url, file); + if (Objects.nonNull(status.getJobId())) { + status = requestJobStatus(status.getJobId()); + } else { + status.setMessage(UNKNOWN_ERROR_OCCURRED); + } + result = status; + } catch (MalformedURLException ex) { + result.setMessage(MALFORMED_URL); + } catch (IOException ex) { + result.setMessage(IO_EXCEPTION_OCCURRED); + } catch (ParserConfigurationException | SAXException ex) { + result.setMessage(XML_PARSER_ERROR); + } + return result; + } + + /** + * Does the actual job for the sendExportJob() method. sendExportJob() builds the URL for the remote servlet + * and calls this method. + * + * @param url The URL of the remote order servlet to which the file should be send to. + * @param file The file to be sent to nF. + * @return Returns the status of the export job you just sent. + * @throws IOException There was a problem with your data connection. + * @throws ParserConfigurationException There was a problem while parsing the response. + * @throws SAXException Some parse error while parsing the response. + */ + private JobStatus sendFile(URL url, File file) throws IOException, ParserConfigurationException, SAXException { + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.setRequestMethod("POST"); + connection.setRequestProperty("Connection", "Keep-Alive"); + connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); + connection.setDoOutput(true); // Sends export job file + connection.setDoInput(true); // Expects XML response + connection.connect(); + OutputStream os = connection.getOutputStream(); + PrintWriter writer = new PrintWriter(new OutputStreamWriter(os, DEFAULT_CHARSET), true); + Files.copy(file.toPath(), os); + os.flush(); + writer.append(CRLF).flush(); + return getJobStatusFromResponse(getResponse(connection)); + } + +} \ No newline at end of file diff --git a/src/eu/simstadt/nf/NFJobBuilder.java b/src/eu/simstadt/nf/NFJobBuilder.java new file mode 100644 index 0000000000000000000000000000000000000000..21af3fa21a317cd53e9dbf144eec52a3a3297e5d --- /dev/null +++ b/src/eu/simstadt/nf/NFJobBuilder.java @@ -0,0 +1,256 @@ +package eu.simstadt.nf; + +import java.io.StringWriter; +import java.util.List; + +import javax.xml.parsers.DocumentBuilder; +import javax.xml.parsers.DocumentBuilderFactory; +import javax.xml.parsers.ParserConfigurationException; +import javax.xml.transform.Transformer; +import javax.xml.transform.TransformerConfigurationException; +import javax.xml.transform.TransformerException; +import javax.xml.transform.TransformerFactory; +import javax.xml.transform.dom.DOMSource; +import javax.xml.transform.stream.StreamResult; + +import org.geotools.geometry.GeneralDirectPosition; +import org.geotools.referencing.CRS; +import org.opengis.geometry.DirectPosition; +import org.opengis.geometry.MismatchedDimensionException; +import org.opengis.referencing.FactoryException; +import org.opengis.referencing.NoSuchAuthorityCodeException; +import org.opengis.referencing.crs.CoordinateReferenceSystem; +import org.opengis.referencing.operation.MathTransform; +import org.opengis.referencing.operation.TransformException; +import org.w3c.dom.Document; +import org.w3c.dom.Element; + +/** + * Builds nF import and export jobs using nF's XML job format. + * + * @author Marcel Bruse + */ +public class NFJobBuilder { + + /** + * This is an intermediate prototype. + * + * @param regionPolygon A polygon of geo coordinates which encloses the buildings to be downloaded. + * @return Returns a string representation of the nF export job. + */ + public static String buildExportJob(List<Coord> regionPolygon) { + String result = null; + + try { + DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); + DocumentBuilder builder = factory.newDocumentBuilder(); + + Document doc = builder.newDocument(); + Element root = doc.createElement("EXPORT_JOB"); + root.setAttribute("version", "1.0.0"); + doc.appendChild(root); + + Element job = doc.createElement("job"); + root.appendChild(job); + + Element initiator = doc.createElement("initiator"); + initiator.appendChild(doc.createTextNode("2758")); + job.appendChild(initiator); + + Element jobnumber = doc.createElement("jobnumber"); + jobnumber.appendChild(doc.createTextNode("GR_EXPORT_CITYGML_LOD1")); + job.appendChild(jobnumber); + + Element account = doc.createElement("account"); + account.appendChild(doc.createTextNode("Habib")); + job.appendChild(account); + + Element product = doc.createElement("product"); + product.appendChild(doc.createTextNode("LBTEST")); + root.appendChild(product); + + Element layers = doc.createElement("layers"); + layers.setAttribute("color", "0"); + layers.setAttribute("mono", "0"); + layers.setAttribute("plotLabelSrs", "-1"); + layers.setAttribute("plotframe", "0"); + layers.setAttribute("single", "1"); + root.appendChild(layers); + + Element layer = doc.createElement("layer"); + layer.setAttribute("name", "GML"); + layer.setAttribute("product", "LBTEST"); + layer.setAttribute("style", "#000000"); + layers.appendChild(layer); + + Element srs = doc.createElement("srs"); + srs.appendChild(doc.createTextNode("31467")); + root.appendChild(srs); + + Element extent = doc.createElement("extent"); + extent.setAttribute("merge_mapsheets", "off"); + extent.setAttribute("tile1asgn", "false"); + root.appendChild(extent); + + Element polygon = appendRegionPolygon(doc, regionPolygon); + extent.appendChild(polygon); + + Element resolution = doc.createElement("resolution"); + resolution.appendChild(doc.createTextNode("100.0")); + root.appendChild(resolution); + + Element scale = doc.createElement("scale"); + scale.appendChild(doc.createTextNode("10000.0")); + root.appendChild(scale); + + Element format = doc.createElement("format"); + format.setAttribute("alphalinscale", "0.0"); + format.setAttribute("alphascale", "1.0"); + format.setAttribute("citygml_actfunc", "tolod1"); + format.setAttribute("citygml_apptheme", ""); + format.setAttribute("citygml_elemclasses", "true"); + format.setAttribute("citygml_lodmode", "all"); + format.setAttribute("citygml_lods", "1"); + format.setAttribute("citygml_metadata", "true"); + format.setAttribute("citygml_outmode", "normal"); + format.setAttribute("dtm", "false"); + format.setAttribute("foredit", "false"); + format.setAttribute("materialcopymode", "none"); + format.setAttribute("polyopts_reverse", "false"); + format.setAttribute("relcoords", "false"); + format.setAttribute("rooftxr", "false"); + format.setAttribute("roundcoords", "3"); + format.setAttribute("schemetxr", "false"); + format.setAttribute("solar", "false"); + format.setAttribute("solargeoplex", "false"); + format.setAttribute("tex", "false"); + format.setAttribute("tolod1", "true"); + format.setAttribute("tolod1_add", "false"); + format.setAttribute("tolod1_delrest", "false"); + format.setAttribute("tolod1_dstattrabsgrnd", ""); + format.setAttribute("tolod1_dstattrabsheight", ""); + format.setAttribute("tolod1_dstattrrelheight", ""); + format.setAttribute("tolod1_dstattrzmode", ""); + format.setAttribute("tolod1_geommode", "lod1solid"); + format.setAttribute("tolod1_lodsrcmode", "all"); + format.setAttribute("tolod1_triangulate", "false"); + format.setAttribute("tolod1_zroofmode", "mid"); + format.setAttribute("tolod1_zusegenattrs", ""); + format.setAttribute("tolod1_zusemeasuredheight", "false"); + format.setAttribute("xyz", "false"); + format.appendChild(doc.createTextNode("CityGML")); + root.appendChild(format); + + Element exportmetadata = doc.createElement("exportmetadata"); + exportmetadata.setAttribute("calibration", "0"); + exportmetadata.setAttribute("xmetadata", "0"); + exportmetadata.appendChild(doc.createTextNode("1")); + root.appendChild(exportmetadata); + + Element addfile = doc.createElement("addfile"); + addfile.setAttribute("col", "0"); + addfile.setAttribute("eck", ""); + root.appendChild(addfile); + + Element usenodatamask = doc.createElement("usenodatamask"); + usenodatamask.appendChild(doc.createTextNode("0")); + root.appendChild(usenodatamask); + + Element usepdctborderpoly = doc.createElement("usepdctborderpoly"); + usepdctborderpoly.appendChild(doc.createTextNode("0")); + root.appendChild(usepdctborderpoly); + + Element dhkresolvereferences = doc.createElement("dhkresolvereferences"); + dhkresolvereferences.appendChild(doc.createTextNode("1")); + root.appendChild(dhkresolvereferences); + + Element zipresult = doc.createElement("zipresult"); + zipresult.appendChild(doc.createTextNode("0")); + root.appendChild(zipresult); + + Element userdescription = doc.createElement("userdescription"); + root.appendChild(userdescription); + + Element namingpattern = doc.createElement("namingpattern"); + root.appendChild(namingpattern); + + TransformerFactory transformerFactory = TransformerFactory.newInstance(); + Transformer transformer = transformerFactory.newTransformer(); + StringWriter writer = new StringWriter(); + StreamResult streamResult = new StreamResult(writer); + transformer.transform(new DOMSource(doc), streamResult); + + result = writer.toString(); + } catch (ParserConfigurationException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } catch (TransformerConfigurationException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } catch (TransformerException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } + return result; + } + + /** + * Transforms a global WGS 84 position into a coordinate of the given target SRS. + * + * @param wgs84Position The WGS 84 position to be transformed to a position within the target SRS. + * @param targetCRS The target SRS for the transformation. + * @return The transformed target position within the target SRS. + */ + public static DirectPosition transformCoordinate(DirectPosition wgs84Position, + CoordinateReferenceSystem targetCRS) { + DirectPosition result = null; + try { + CoordinateReferenceSystem sourceCRS = CRS.decode("EPSG:4326"); // WGS 84 (used by Google Maps) + MathTransform transform = CRS.findMathTransform(sourceCRS, targetCRS, true); + result = transform.transform(wgs84Position, null); + } catch (NoSuchAuthorityCodeException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } catch (FactoryException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } catch (MismatchedDimensionException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } catch (TransformException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } + return result; + } + + /** + * Appends the region polygon to the XML export job document. In order to do this, the given WGS 84 region + * polygon will be transformed into a DHDN Gauss-Kruger zone 3 polygon. + * + * @param doc The XML export job document. + * @param regionPolygon The polygon of the region which has been selected to be exported. + * @return The w3c.dom.Element of the XML export job which describes the region polygon. + */ + private static Element appendRegionPolygon(Document doc, List<Coord> regionPolygon) { + Element polygon = doc.createElement("polygon"); + polygon.setAttribute("srs", "31467"); + try { + CoordinateReferenceSystem targetCRS = CRS.decode("EPSG:31467"); // DHDN Gauss-Kruger zone 3 + for (Coord coord : regionPolygon) { + DirectPosition sourcePosition = new GeneralDirectPosition(coord.latitude, coord.longitude); + DirectPosition targetPosition = transformCoordinate(sourcePosition, targetCRS); + + Element vertex = doc.createElement("vertex"); + vertex.setAttribute("x", String.valueOf(targetPosition.getCoordinate()[1])); + vertex.setAttribute("y", String.valueOf(targetPosition.getCoordinate()[0])); + polygon.appendChild(vertex); + } + } catch (FactoryException ex) { + // TODO Auto-generated catch block + ex.printStackTrace(); + } + return polygon; + } + +} diff --git a/src/eu/simstadt/nf/ReportHandler.java b/src/eu/simstadt/nf/ReportHandler.java new file mode 100644 index 0000000000000000000000000000000000000000..d37d52e5789dce9dc4664a56416b44c19f72f57f --- /dev/null +++ b/src/eu/simstadt/nf/ReportHandler.java @@ -0,0 +1,60 @@ +package eu.simstadt.nf; + +import org.xml.sax.SAXException; +import org.xml.sax.helpers.DefaultHandler; + +/** + * This SAX handler scans a nF XML status report instance and searches for the nF job id and the status of a + * nF job. + * + * @author Marcel Bruse + */ +public class ReportHandler extends DefaultHandler { + + /** The XML tag which tells you the status of a nF job. */ + public static final String STATUS_TAG = "status"; + + /** The XML tag which holds the id of the nF job. */ + public static final String JOB_ID = "jobId"; + + /** If there was a problem on the nF server, then this XML tag gives you some hints. */ + public static final String SERVICE_EXCEPTION_TAG = "ServiceException"; + + /** The id of the status of the nF job. */ + public Integer statusId = null; + + /** The id of the nF job. */ + public Integer jobId = null; + + /** If there was any problem, then you will find an exception message here. */ + public String serviceException = null; + + /** Scanned string will be stored here temporarily. */ + private String currentString; + + /** + * If a tag has been read, its contents will be tested here. If it contains either a status id, job id or + * service exception messege, then the contents will be stored in the appropriate member variable. + */ + @Override + public void endElement(String uri, String localName, String qName) throws SAXException { + if (qName.equalsIgnoreCase(STATUS_TAG)) { + statusId = Integer.valueOf(currentString); + } else if (qName.equalsIgnoreCase(SERVICE_EXCEPTION_TAG)) { + serviceException = currentString; + } else if (qName.equalsIgnoreCase(JOB_ID)) { + jobId = Integer.valueOf(currentString); + } + } + + /** + * The scanner of the XML document. + * + * @see DefaultHandler + */ + @Override + public void characters(char[] ch, int start, int length) { + currentString = new String(ch, start, length); + } + +} diff --git a/src/eu/simstadt/regionchooser/RegionChooserController.java b/src/eu/simstadt/regionchooser/RegionChooserController.java index 25092d9b6277fcefb1dc8b97538c74f2175aaaa3..3cf8c2b96e1f2f6583a3fe981cb11edbb0b47305 100644 --- a/src/eu/simstadt/regionchooser/RegionChooserController.java +++ b/src/eu/simstadt/regionchooser/RegionChooserController.java @@ -1,7 +1,11 @@ package eu.simstadt.regionchooser; +import java.util.Arrays; +import java.util.List; + import javafx.fxml.FXML; import javafx.scene.control.Button; + import com.lynden.gmapsfx.GoogleMapView; import com.lynden.gmapsfx.MapComponentInitializedListener; import com.lynden.gmapsfx.javascript.object.GoogleMap; @@ -13,9 +17,11 @@ import com.lynden.gmapsfx.javascript.object.Marker; import com.lynden.gmapsfx.javascript.object.MarkerOptions; +import eu.simstadt.nf.Coord; +import eu.simstadt.nf.NFJobBuilder; -public class RegionChooserController implements MapComponentInitializedListener -{ +public class RegionChooserController implements MapComponentInitializedListener { + @FXML private Button button; @@ -31,10 +37,10 @@ public void initialize() { @Override public void mapInitialized() { - LatLong bochumLoc = new LatLong(51.482, 7.225); - LatLong hamburgLoc = new LatLong(53.551, 9.994); - LatLong stuttgartLoc = new LatLong(48.778, 9.176); - LatLong dresdenLoc = new LatLong(51.049, 13.741); + LatLong bochumLoc = new LatLong(48.879696, 9.215463); + LatLong hamburgLoc = new LatLong(48.878230, 9.215714); + LatLong stuttgartLoc = new LatLong(48.878323, 9.216613); + LatLong dresdenLoc = new LatLong(48.879402, 9.216532); //Set the initial properties of the map. @@ -80,5 +86,15 @@ public void mapInitialized() { InfoWindow bochumInfoWindow = new InfoWindow(infoWindowOptions); bochumInfoWindow.open(map, bochumMarker); + + // Build the nF export job description from a region polygon + List<Coord> regionPolygon = Arrays.asList( + new Coord(bochumLoc.getLatitude(), bochumLoc.getLongitude()), + new Coord(hamburgLoc.getLatitude(), bochumLoc.getLongitude()), + new Coord(stuttgartLoc.getLatitude(), bochumLoc.getLongitude()), + new Coord(dresdenLoc.getLatitude(), bochumLoc.getLongitude()) + ); + String exportJobDescription = NFJobBuilder.buildExportJob(regionPolygon); + System.out.println(exportJobDescription); } } \ No newline at end of file