Apache License: |

   Apache License
   Version 2.0, January 2004
   http://www.apache.org/licenses/

   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION

   1. Definitions.

      "License" shall mean the terms and conditions for use, reproduction,
      and distribution as defined by Sections 1 through 9 of this document.

      "Licensor" shall mean the copyright owner or entity authorized by
      the copyright owner that is granting the License.

      "Legal Entity" shall mean the union of the acting entity and all
      other entities that control, are controlled by, or are under common
      control with that entity. For the purposes of this definition,
      "control" means (i) the power, direct or indirect, to cause the
      direction or management of such entity, whether by contract or
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
      outstanding shares, or (iii) beneficial ownership of such entity.

      "You" (or "Your") shall mean an individual or Legal Entity
      exercising permissions granted by this License.

      "Source" form shall mean the preferred form for making modifications,
      including but not limited to software source code, documentation
      source, and configuration files.

      "Object" form shall mean any form resulting from mechanical
      transformation or translation of a Source form, including but
      not limited to compiled object code, generated documentation,
      and conversions to other media types.

      "Work" shall mean the work of authorship, whether in Source or
      Object form, made available under the License, as indicated by a
      copyright notice that is included in or attached to the work
      (an example is provided in the Appendix below).

      "Derivative Works" shall mean any work, whether in Source or Object
      form, that is based on (or derived from) the Work and for which the
      editorial revisions, annotations, elaborations, or other modifications
      represent, as a whole, an original work of authorship. For the purposes
      of this License, Derivative Works shall not include works that remain
      separable from, or merely link (or bind by name) to the interfaces of,
      the Work and Derivative Works thereof.

      "Contribution" shall mean any work of authorship, including
      the original version of the Work and any modifications or additions
      to that Work or Derivative Works thereof, that is intentionally
      submitted to Licensor for inclusion in the Work by the copyright owner
      or by an individual or Legal Entity authorized to submit on behalf of
      the copyright owner. For the purposes of this definition, "submitted"
      means any form of electronic, verbal, or written communication sent
      to the Licensor or its representatives, including but not limited to
      communication on electronic mailing lists, source code control systems,
      and issue tracking systems that are managed by, or on behalf of, the
      Licensor for the purpose of discussing and improving the Work, but
      excluding communication that is conspicuously marked or otherwise
      designated in writing by the copyright owner as "Not a Contribution."

      "Contributor" shall mean Licensor and any individual or Legal Entity
      on behalf of whom a Contribution has been received by Licensor and
      subsequently incorporated within the Work.

   2. Grant of Copyright License. Subject to the terms and conditions of
      this License, each Contributor hereby grants to You a perpetual,
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
      copyright license to reproduce, prepare Derivative Works of,
      publicly display, publicly perform, sublicense, and distribute the
      Work and such Derivative Works in Source or Object form.

   3. Grant of Patent License. Subject to the terms and conditions of
      this License, each Contributor hereby grants to You a perpetual,
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
      (except as stated in this section) patent license to make, have made,
      use, offer to sell, sell, import, and otherwise transfer the Work,
      where such license applies only to those patent claims licensable
      by such Contributor that are necessarily infringed by their
      Contribution(s) alone or by combination of their Contribution(s)
      with the Work to which such Contribution(s) was submitted. If You
      institute patent litigation against any entity (including a
      cross-claim or counterclaim in a lawsuit) alleging that the Work
      or a Contribution incorporated within the Work constitutes direct
      or contributory patent infringement, then any patent licenses
      granted to You under this License for that Work shall terminate
      as of the date such litigation is filed.

   4. Redistribution. You may reproduce and distribute copies of the
      Work or Derivative Works thereof in any medium, with or without
      modifications, and in Source or Object form, provided that You
      meet the following conditions:

      (a) You must give any other recipients of the Work or
          Derivative Works a copy of this License; and

      (b) You must cause any modified files to carry prominent notices
          stating that You changed the files; and

      (c) You must retain, in the Source form of any Derivative Works
          that You distribute, all copyright, patent, trademark, and
          attribution notices from the Source form of the Work,
          excluding those notices that do not pertain to any part of
          the Derivative Works; and

      (d) If the Work includes a "NOTICE" text file as part of its
          distribution, then any Derivative Works that You distribute must
          include a readable copy of the attribution notices contained
          within such NOTICE file, excluding those notices that do not
          pertain to any part of the Derivative Works, in at least one
          of the following places: within a NOTICE text file distributed
          as part of the Derivative Works; within the Source form or
          documentation, if provided along with the Derivative Works; or,
          within a display generated by the Derivative Works, if and
          wherever such third-party notices normally appear. The contents
          of the NOTICE file are for informational purposes only and
          do not modify the License. You may add Your own attribution
          notices within Derivative Works that You distribute, alongside
          or as an addendum to the NOTICE text from the Work, provided
          that such additional attribution notices cannot be construed
          as modifying the License.

      You may add Your own copyright statement to Your modifications and
      may provide additional or different license terms and conditions
      for use, reproduction, or distribution of Your modifications, or
      for any such Derivative Works as a whole, provided Your use,
      reproduction, and distribution of the Work otherwise complies with
      the conditions stated in this License.

   5. Submission of Contributions. Unless You explicitly state otherwise,
      any Contribution intentionally submitted for inclusion in the Work
      by You to the Licensor shall be under the terms and conditions of
      this License, without any additional terms or conditions.
      Notwithstanding the above, nothing herein shall supersede or modify
      the terms of any separate license agreement you may have executed
      with Licensor regarding such Contributions.

   6. Trademarks. This License does not grant permission to use the trade
      names, trademarks, service marks, or product names of the Licensor,
      except as required for reasonable and customary use in describing the
      origin of the Work and reproducing the content of the NOTICE file.

   7. Disclaimer of Warranty. Unless required by applicable law or
      agreed to in writing, Licensor provides the Work (and each
      Contributor provides its Contributions) on an "AS IS" BASIS,
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
      implied, including, without limitation, any warranties or conditions
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
      PARTICULAR PURPOSE. You are solely responsible for determining the
      appropriateness of using or redistributing the Work and assume any
      risks associated with Your exercise of permissions under this License.

   8. Limitation of Liability. In no event and under no legal theory,
      whether in tort (including negligence), contract, or otherwise,
      unless required by applicable law (such as deliberate and grossly
      negligent acts) or agreed to in writing, shall any Contributor be
      liable to You for damages, including any direct, indirect, special,
      incidental, or consequential damages of any character arising as a
      result of this License or out of the use or inability to use the
      Work (including but not limited to damages for loss of goodwill,
      work stoppage, computer failure or malfunction, or any and all
      other commercial damages or losses), even if such Contributor
      has been advised of the possibility of such damages.

   9. Accepting Warranty or Additional Liability. While redistributing
      the Work or Derivative Works thereof, You may choose to offer,
      and charge a fee for, acceptance of support, warranty, indemnity,
      or other liability obligations and/or rights consistent with this
      License. However, in accepting such obligations, You may act only
      on Your own behalf and on Your sole responsibility, not on behalf
      of any other Contributor, and only if You agree to indemnify,
      defend, and hold each Contributor harmless for any liability
      incurred by, or claims asserted against, such Contributor by reason
      of your accepting any such warranty or additional liability.


   END OF TERMS AND CONDITIONS

   APPENDIX - HOW TO APPLY THE APACHE LICENSE TO YOUR WORK
   
   To apply the Apache License to your work, attach the following boilerplate 
   notice, with the fields enclosed by brackets "[]" replaced with your own 
   identifying information. (Don't include the brackets!) The text should be 
   enclosed in the appropriate comment syntax for the file format. We also 
   recommend that a file or class name and description of purpose be included 
   on the same "printed page" as the copyright notice for easier 
   identification within third-party archives.
   
   Copyright [yyyy] [name of copyright owner]
   
   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.
   
   
Dependency licenses:

   # This source distribution includes third-party code under their licenses.
   # These licenses are compatible with the Apache License above.
   # Details of these dependencies can be found in the accompanying NOTICE file.
   # These licenses are included below with their full text.

  Creative Commons Public License, Attribution 3.0: |
    THE WORK (AS DEFINED BELOW) IS PROVIDED UNDER THE TERMS OF THIS CREATIVE
    COMMONS PUBLIC LICENSE ("CCPL" OR "LICENSE"). THE WORK IS PROTECTED BY
    COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS
    AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED.
    
    BY EXERCISING ANY RIGHTS TO THE WORK PROVIDED HERE, YOU ACCEPT AND AGREE TO BE
    BOUND BY THE TERMS OF THIS LICENSE. TO THE EXTENT THIS LICENSE MAY BE
    CONSIDERED TO BE A CONTRACT, THE LICENSOR GRANTS YOU THE RIGHTS CONTAINED HERE
    IN CONSIDERATION OF YOUR ACCEPTANCE OF SUCH TERMS AND CONDITIONS.
    
    1. Definitions
    
    "Collective Work" means a work, such as a periodical issue, anthology or
    encyclopedia, in which the Work in its entirety in unmodified form, along with
    one or more other contributions, constituting separate and independent works in
    themselves, are assembled into a collective whole. A work that constitutes a
    Collective Work will not be considered a Derivative Work (as defined below) for
    the purposes of this License.  "Derivative Work" means a work based upon the
    Work or upon the Work and other pre-existing works, such as a translation,
    musical arrangement, dramatization, fictionalization, motion picture version,
    sound recording, art reproduction, abridgment, condensation, or any other form
    in which the Work may be recast, transformed, or adapted, except that a work
    that constitutes a Collective Work will not be considered a Derivative Work for
    the purpose of this License. For the avoidance of doubt, where the Work is a
    musical composition or sound recording, the synchronization of the Work in
    timed-relation with a moving image ("synching") will be considered a Derivative
    Work for the purpose of this License.  "Licensor" means the individual,
    individuals, entity or entities that offers the Work under the terms of this
    License.  "Original Author" means the individual, individuals, entity or
    entities who created the Work.  "Work" means the copyrightable work of
    authorship offered under the terms of this License.  "You" means an individual
    or entity exercising rights under this License who has not previously violated
    the terms of this License with respect to the Work, or who has received express
    permission from the Licensor to exercise rights under this License despite a
    previous violation.  2. Fair Use Rights. Nothing in this license is intended to
    reduce, limit, or restrict any rights arising from fair use, first sale or
    other limitations on the exclusive rights of the copyright owner under
    copyright law or other applicable laws.
    
    3. License Grant. Subject to the terms and conditions of this License, Licensor
    hereby grants You a worldwide, royalty-free, non-exclusive, perpetual (for the
    duration of the applicable copyright) license to exercise the rights in the
    Work as stated below:
    
    to reproduce the Work, to incorporate the Work into one or more Collective
    Works, and to reproduce the Work as incorporated in the Collective Works; to
    create and reproduce Derivative Works provided that any such Derivative Work,
    including any translation in any medium, takes reasonable steps to clearly
    label, demarcate or otherwise identify that changes were made to the original
    Work. For example, a translation could be marked "The original work was
    translated from English to Spanish," or a modification could indicate "The
    original work has been modified.";; to distribute copies or phonorecords of,
    display publicly, perform publicly, and perform publicly by means of a digital
    audio transmission the Work including as incorporated in Collective Works; to
    distribute copies or phonorecords of, display publicly, perform publicly, and
    perform publicly by means of a digital audio transmission Derivative Works.
    For the avoidance of doubt, where the Work is a musical composition:
    
    Performance Royalties Under Blanket Licenses. Licensor waives the exclusive
    right to collect, whether individually or, in the event that Licensor is a
    member of a performance rights society (e.g. ASCAP, BMI, SESAC), via that
    society, royalties for the public performance or public digital performance
    (e.g. webcast) of the Work.  Mechanical Rights and Statutory Royalties.
    Licensor waives the exclusive right to collect, whether individually or via a
    music rights agency or designated agent (e.g. Harry Fox Agency), royalties for
    any phonorecord You create from the Work ("cover version") and distribute,
    subject to the compulsory license created by 17 USC Section 115 of the US
    Copyright Act (or the equivalent in other jurisdictions).  Webcasting Rights
    and Statutory Royalties. For the avoidance of doubt, where the Work is a sound
    recording, Licensor waives the exclusive right to collect, whether individually
    or via a performance-rights society (e.g. SoundExchange), royalties for the
    public digital performance (e.g. webcast) of the Work, subject to the
    compulsory license created by 17 USC Section 114 of the US Copyright Act (or
    the equivalent in other jurisdictions).  The above rights may be exercised in
    all media and formats whether now known or hereafter devised. The above rights
    include the right to make such modifications as are technically necessary to
    exercise the rights in other media and formats. All rights not expressly
    granted by Licensor are hereby reserved.
    
    4. Restrictions. The license granted in Section 3 above is expressly made
    subject to and limited by the following restrictions:
    
    You may distribute, publicly display, publicly perform, or publicly digitally
    perform the Work only under the terms of this License, and You must include a
    copy of, or the Uniform Resource Identifier for, this License with every copy
    or phonorecord of the Work You distribute, publicly display, publicly perform,
    or publicly digitally perform. You may not offer or impose any terms on the
    Work that restrict the terms of this License or the ability of a recipient of
    the Work to exercise the rights granted to that recipient under the terms of
    the License. You may not sublicense the Work. You must keep intact all notices
    that refer to this License and to the disclaimer of warranties. When You
    distribute, publicly display, publicly perform, or publicly digitally perform
    the Work, You may not impose any technological measures on the Work that
    restrict the ability of a recipient of the Work from You to exercise the rights
    granted to that recipient under the terms of the License. This Section 4(a)
    applies to the Work as incorporated in a Collective Work, but this does not
    require the Collective Work apart from the Work itself to be made subject to
    the terms of this License. If You create a Collective Work, upon notice from
    any Licensor You must, to the extent practicable, remove from the Collective
    Work any credit as required by Section 4(b), as requested. If You create a
    Derivative Work, upon notice from any Licensor You must, to the extent
    practicable, remove from the Derivative Work any credit as required by Section
    4(b), as requested.  If You distribute, publicly display, publicly perform, or
    publicly digitally perform the Work (as defined in Section 1 above) or any
    Derivative Works (as defined in Section 1 above) or Collective Works (as
    defined in Section 1 above), You must, unless a request has been made pursuant
    to Section 4(a), keep intact all copyright notices for the Work and provide,
    reasonable to the medium or means You are utilizing: (i) the name of the
    Original Author (or pseudonym, if applicable) if supplied, and/or (ii) if the
    Original Author and/or Licensor designate another party or parties (e.g. a
    sponsor institute, publishing entity, journal) for attribution ("Attribution
    Parties") in Licensor's copyright notice, terms of service or by other
    reasonable means, the name of such party or parties; the title of the Work if
    supplied; to the extent reasonably practicable, the Uniform Resource
    Identifier, if any, that Licensor specifies to be associated with the Work,
    unless such URI does not refer to the copyright notice or licensing information
    for the Work; and, consistent with Section 3(b) in the case of a Derivative
    Work, a credit identifying the use of the Work in the Derivative Work (e.g.,
    "French translation of the Work by Original Author," or "Screenplay based on
    original Work by Original Author"). The credit required by this Section 4(b)
    may be implemented in any reasonable manner; provided, however, that in the
    case of a Derivative Work or Collective Work, at a minimum such credit will
    appear, if a credit for all contributing authors of the Derivative Work or
    Collective Work appears, then as part of these credits and in a manner at least
    as prominent as the credits for the other contributing authors. For the
    avoidance of doubt, You may only use the credit required by this Section for
    the purpose of attribution in the manner set out above and, by exercising Your
    rights under this License, You may not implicitly or explicitly assert or imply
    any connection with, sponsorship or endorsement by the Original Author,
    Licensor and/or Attribution Parties, as appropriate, of You or Your use of the
    Work, without the separate, express prior written permission of the Original
    Author, Licensor and/or Attribution Parties.  5. Representations, Warranties
    and Disclaimer
    
    UNLESS OTHERWISE MUTUALLY AGREED TO BY THE PARTIES IN WRITING, LICENSOR OFFERS
    THE WORK AS-IS AND ONLY TO THE EXTENT OF ANY RIGHTS HELD IN THE LICENSED WORK
    BY THE LICENSOR. THE LICENSOR MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY
    KIND CONCERNING THE WORK, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, INCLUDING,
    WITHOUT LIMITATION, WARRANTIES OF TITLE, MARKETABILITY, MERCHANTIBILITY,
    FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF LATENT OR
    OTHER DEFECTS, ACCURACY, OR THE PRESENCE OF ABSENCE OF ERRORS, WHETHER OR NOT
    DISCOVERABLE. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION OF IMPLIED
    WARRANTIES, SO SUCH EXCLUSION MAY NOT APPLY TO YOU.
    
    6. Limitation on Liability. EXCEPT TO THE EXTENT REQUIRED BY APPLICABLE LAW, IN
    NO EVENT WILL LICENSOR BE LIABLE TO YOU ON ANY LEGAL THEORY FOR ANY SPECIAL,
    INCIDENTAL, CONSEQUENTIAL, PUNITIVE OR EXEMPLARY DAMAGES ARISING OUT OF THIS
    LICENSE OR THE USE OF THE WORK, EVEN IF LICENSOR HAS BEEN ADVISED OF THE
    POSSIBILITY OF SUCH DAMAGES.
    
    7. Termination
    
    This License and the rights granted hereunder will terminate automatically upon
    any breach by You of the terms of this License. Individuals or entities who
    have received Derivative Works (as defined in Section 1 above) or Collective
    Works (as defined in Section 1 above) from You under this License, however,
    will not have their licenses terminated provided such individuals or entities
    remain in full compliance with those licenses. Sections 1, 2, 5, 6, 7, and 8
    will survive any termination of this License.  Subject to the above terms and
    conditions, the license granted here is perpetual (for the duration of the
    applicable copyright in the Work). Notwithstanding the above, Licensor reserves
    the right to release the Work under different license terms or to stop
    distributing the Work at any time; provided, however that any such election
    will not serve to withdraw this License (or any other license that has been, or
    is required to be, granted under the terms of this License), and this License
    will continue in full force and effect unless terminated as stated above.  8.
    Miscellaneous
    
    Each time You distribute or publicly digitally perform the Work (as defined in
    Section 1 above) or a Collective Work (as defined in Section 1 above), the
    Licensor offers to the recipient a license to the Work on the same terms and
    conditions as the license granted to You under this License.  Each time You
    distribute or publicly digitally perform a Derivative Work, Licensor offers to
    the recipient a license to the original Work on the same terms and conditions
    as the license granted to You under this License.  If any provision of this
    License is invalid or unenforceable under applicable law, it shall not affect
    the validity or enforceability of the remainder of the terms of this License,
    and without further action by the parties to this agreement, such provision
    shall be reformed to the minimum extent necessary to make such provision valid
    and enforceable.  No term or provision of this License shall be deemed waived
    and no breach consented to unless such waiver or consent shall be in writing
    and signed by the party to be charged with such waiver or consent.  This
    License constitutes the entire agreement between the parties with respect to
    the Work licensed here. There are no understandings, agreements or
    representations with respect to the Work not specified here. Licensor shall not
    be bound by any additional provisions that may appear in any communication from
    You. This License may not be modified without the mutual written agreement of
    the Licensor and You.

  MIT License: |
    MIT License
    
    Copyright (c) as noted in accompanying NOTICE file. All rights reserved.
    
    Permission is hereby granted, free of charge, to any person obtaining a copy of this 
    software and associated documentation files (the "Software"), to deal in the Software 
    without restriction, including without limitation the rights to use, copy, modify, merge, 
    publish, distribute, sublicense, and/or sell copies of the Software, and to permit 
    persons to whom the Software is furnished to do so, subject to the following conditions:
    
    The above copyright notice and this permission notice shall be included in all copies or 
    substantial portions of the Software.
    
    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, 
    INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR 
    PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE 
    FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR 
    OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 
    DEALINGS IN THE SOFTWARE.

  Public Domain: |
    The project indicates it is in the public domain and does not require any license inclusion.
    

  SIL OFL 1.1: |
    Copyright (c) as noted in accompanying NOTICE file. All rights reserved.
    
    This Font Software is licensed under the SIL Open Font License, Version 1.1.
    This license is copied below, and is also available with a FAQ at:
    http://scripts.sil.org/OFL
    
    
    -----------------------------------------------------------
    SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
    -----------------------------------------------------------
    
    PREAMBLE
    The goals of the Open Font License (OFL) are to stimulate worldwide
    development of collaborative font projects, to support the font creation
    efforts of academic and linguistic communities, and to provide a free and
    open framework in which fonts may be shared and improved in partnership
    with others.
    
    The OFL allows the licensed fonts to be used, studied, modified and
    redistributed freely as long as they are not sold by themselves. The
    fonts, including any derivative works, can be bundled, embedded, 
    redistributed and/or sold with any software provided that any reserved
    names are not used by derivative works. The fonts and derivatives,
    however, cannot be released under any other type of license. The
    requirement for fonts to remain under this license does not apply
    to any document created using the fonts or their derivatives.
    
    DEFINITIONS
    "Font Software" refers to the set of files released by the Copyright
    Holder(s) under this license and clearly marked as such. This may
    include source files, build scripts and documentation.
    
    "Reserved Font Name" refers to any names specified as such after the
    copyright statement(s).
    
    "Original Version" refers to the collection of Font Software components as
    distributed by the Copyright Holder(s).
    
    "Modified Version" refers to any derivative made by adding to, deleting,
    or substituting -- in part or in whole -- any of the components of the
    Original Version, by changing formats or by porting the Font Software to a
    new environment.
    
    "Author" refers to any designer, engineer, programmer, technical
    writer or other person who contributed to the Font Software.
    
    PERMISSION & CONDITIONS
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of the Font Software, to use, study, copy, merge, embed, modify,
    redistribute, and sell modified and unmodified copies of the Font
    Software, subject to the following conditions:
    
    1) Neither the Font Software nor any of its individual components,
    in Original or Modified Versions, may be sold by itself.
    
    2) Original or Modified Versions of the Font Software may be bundled,
    redistributed and/or sold with any software, provided that each copy
    contains the above copyright notice and this license. These can be
    included either as stand-alone text files, human-readable headers or
    in the appropriate machine-readable metadata fields within text or
    binary files as long as those fields can be easily viewed by the user.
    
    3) No Modified Version of the Font Software may use the Reserved Font
    Name(s) unless explicit written permission is granted by the corresponding
    Copyright Holder. This restriction only applies to the primary font name as
    presented to the users.
    
    4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
    Software shall not be used to promote, endorse or advertise any
    Modified Version, except to acknowledge the contribution(s) of the
    Copyright Holder(s) and the Author(s) or with their explicit written
    permission.
    
    5) The Font Software, modified or unmodified, in part or in whole,
    must be distributed entirely under this license, and must not be
    distributed under any other license. The requirement for fonts to
    remain under this license does not apply to any document created
    using the Font Software.
    
    TERMINATION
    This license becomes null and void if any of the above conditions are
    not met.
    
    DISCLAIMER
    THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
    EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
    OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
    COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
    INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
    DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
    FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
    OTHER DEALINGS IN THE FONT SOFTWARE.

