842ae4bd224140319ae7feec1872b93dfd491143fielding GNU LESSER GENERAL PUBLIC LICENSE
842ae4bd224140319ae7feec1872b93dfd491143fielding Version 2.1, February 1999
842ae4bd224140319ae7feec1872b93dfd491143fielding Copyright (C) 1991, 1999 Free Software Foundation, Inc.
842ae4bd224140319ae7feec1872b93dfd491143fielding 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
842ae4bd224140319ae7feec1872b93dfd491143fielding Everyone is permitted to copy and distribute verbatim copies
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrse of this license document, but changing it is not allowed.
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrse[This is the first released version of the Lesser GPL. It also counts
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcnd as the successor of the GNU Library Public License, version 2, hence
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcnd the version number 2.1.]
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcnd The licenses for most software are designed to take away your
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndfreedom to share and change it. By contrast, the GNU General Public
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndLicenses are intended to guarantee your freedom to share and change
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndfree software--to make sure the software is free for all its users.
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcnd This license, the Lesser General Public License, applies to some
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndspecially designated software packages--typically libraries--of the
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndFree Software Foundation and other authors who decide to use it. You
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndcan use it too, but we suggest you first think carefully about whether
ce9621257ef9e54c1bbe5ad8a5f445a1f211c2dcndthis license or the ordinary General Public License is the better
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsestrategy to use in any particular case, based on the explanations below.
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrse When we speak of free software, we are referring to freedom of use,
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsenot price. Our General Public Licenses are designed to make sure that
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseyou have the freedom to distribute copies of free software (and charge
70535d6421eb979ac79d8f49d31cd94d75dd8b2fjortonfor this service if you wish); that you receive source code or can get
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseit if you want it; that you can change the software and use pieces of
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseit in new free programs; and that you are informed that you can do
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsethese things.
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrse To protect your rights, we need to make restrictions that forbid
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsedistributors to deny you these rights or to ask you to surrender these
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrserights. These restrictions translate to certain responsibilities for
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortonyou if you distribute copies of the library or if you modify it.
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jorton For example, if you distribute copies of the library, whether gratis
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseor for a fee, you must give the recipients all the rights that we gave
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseyou. You must make sure that they, too, receive or can get the source
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsecode. If you link other code with the library, you must provide
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsecomplete object files to the recipients, so that they can relink them
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsewith the library after making changes to the library and recompiling
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseit. And you must show them these terms so they know their rights.
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrse We protect your rights with a two-step method: (1) we copyright the
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrselibrary, and (2) we offer you this license, which gives you legal
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsepermission to copy, distribute and/or modify the library.
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrse To protect each distributor, we want to make it very clear that
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsethere is no warranty for the free library. Also, if the library is
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsemodified by someone else and passed on, the recipients should know
b5a5fa0a55cbbeb78a8c80c7928183eb09c55097jortonthat what they have is not the original version, so that the original
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseauthor's reputation will not be affected by problems that might be
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortonintroduced by others.
e8f95a682820a599fe41b22977010636be5c2717jim Finally, software patents pose a constant threat to the existence of
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortonany free program. We wish to make sure that a company cannot
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortoneffectively restrict the users of a free program by obtaining a
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortonrestrictive license from a patent holder. Therefore, we insist that
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortonany patent license obtained for a version of the library must be
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseconsistent with the full freedom of use specified in this license.
bd17c0d7cde28d71d2c62db92a7fa8b3d0772eadkbrand Most GNU software, including some libraries, is covered by the
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrseordinary GNU General Public License. This license, the GNU Lesser
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfGeneral Public License, applies to certain designated libraries, and
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfis quite different from the ordinary General Public License. We use
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfthis license for certain libraries in order to permit linking those
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sflibraries into non-free programs.
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sf When a program is linked with a library, whether statically or using
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfa shared library, the combination of the two is legally speaking a
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfcombined work, a derivative of the original library. The ordinary
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfGeneral Public License therefore permits such linking only if the
304257c2b0d71c1e4cf3c5c819bb6b60e7c82d51sfentire combination fits its criteria of freedom. The Lesser General
bd17c0d7cde28d71d2c62db92a7fa8b3d0772eadkbrandPublic License permits more lax criteria for linking other code with
cc003103e52ff9d5fe9bed567ef9438613ab4fbfrsethe library.
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantz We call this license the "Lesser" General Public License because it
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzdoes Less to protect the user's freedom than the ordinary General
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzPublic License. It also provides other free software developers Less
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzof an advantage over competing non-free programs. These disadvantages
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzare the reason we use the ordinary General Public License for many
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzlibraries. However, the Lesser license provides advantages in certain
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonspecial circumstances.
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantz For example, on rare occasions, there may be a special need to
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonencourage the widest possible use of a certain library, so that it becomes
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortona de-facto standard. To achieve this, non-free programs must be
c1b78a620dc5a3b0ba6d90ed0dd2ac3e1b0201b7jortonallowed to use the library. A more frequent case is that a free
c5f8a69aa8ce3dc9b7c3f99284ed912d375ae40ejortonlibrary does the same job as widely used non-free libraries. In this
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortoncase, there is little to gain by limiting the free library to free
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonsoftware only, so we use the Lesser General Public License.
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjorton In other cases, permission to use a particular library in non-free
c5f8a69aa8ce3dc9b7c3f99284ed912d375ae40ejortonprograms enables a greater number of people to use a large body of
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzfree software. For example, permission to use the GNU C Library in
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantznon-free programs enables many more people to use the whole GNU
9f2628baf370d9cf6197b7ca9358b0fb18bd1ce3sfoperating system, as well as its variant, the GNU/Linux operating
5bfaaf573bacb45c1cf290ce85ecc676587e8a64jim Although the Lesser General Public License is Less protective of the
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonusers' freedom, it does ensure that the user of a program that is
5bfaaf573bacb45c1cf290ce85ecc676587e8a64jimlinked with the Library has the freedom and the wherewithal to run
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonthat program using a modified version of the Library.
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjorton The precise terms and conditions for copying, distribution and
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonmodification follow. Pay close attention to the difference between a
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjorton"work based on the library" and a "work that uses the library". The
7d3e81b6534692d0a08d4b2ab3c364b92f9d7bdbjortonformer contains code derived from the library, whereas the latter must
e16695d440d82ec6f9a4b9af18ae38dbeaa19366jerenkrantzbe combined with the library in order to run.
8ec5cc2de6b079c1a686cc5f258806ae53928639jorton GNU LESSER GENERAL PUBLIC LICENSE
5bfaaf573bacb45c1cf290ce85ecc676587e8a64jim TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
8f435d95de2724d4bc75338a9af8ef995e451599kbrand 0. This License Agreement applies to any software library or other
8f435d95de2724d4bc75338a9af8ef995e451599kbrandprogram which contains a notice placed by the copyright holder or
8f435d95de2724d4bc75338a9af8ef995e451599kbrandother authorized party saying it may be distributed under the terms of
8ec5cc2de6b079c1a686cc5f258806ae53928639jortonthis Lesser General Public License (also called "this License").
8ec5cc2de6b079c1a686cc5f258806ae53928639jortonEach licensee is addressed as "you".
8f435d95de2724d4bc75338a9af8ef995e451599kbrand A "library" means a collection of software functions and/or data
5bfaaf573bacb45c1cf290ce85ecc676587e8a64jimprepared so as to be conveniently linked with application programs
8ec5cc2de6b079c1a686cc5f258806ae53928639jorton(which use some of those functions and data) to form executables.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand The "Library", below, refers to any such software library or work
8ec5cc2de6b079c1a686cc5f258806ae53928639jortonwhich has been distributed under these terms. A "work based on the
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandLibrary" means either the Library or any derivative work under
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandcopyright law: that is to say, a work containing the Library or a
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandportion of it, either verbatim or with modifications and/or translated
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandstraightforwardly into another language. (Hereinafter, translation is
8f435d95de2724d4bc75338a9af8ef995e451599kbrandincluded without limitation in the term "modification".)
8f435d95de2724d4bc75338a9af8ef995e451599kbrand "Source code" for a work means the preferred form of the work for
8f435d95de2724d4bc75338a9af8ef995e451599kbrandmaking modifications to it. For a library, complete source code means
8f435d95de2724d4bc75338a9af8ef995e451599kbrandall the source code for all modules it contains, plus any associated
8f435d95de2724d4bc75338a9af8ef995e451599kbrandinterface definition files, plus the scripts used to control compilation
8f435d95de2724d4bc75338a9af8ef995e451599kbrandand installation of the library.
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand Activities other than copying, distribution and modification are not
5400544d62947907986d570435dd16f02ca824e0sfcovered by this License; they are outside its scope. The act of
8f435d95de2724d4bc75338a9af8ef995e451599kbrandrunning a program using the Library is not restricted, and output from
8f435d95de2724d4bc75338a9af8ef995e451599kbrandsuch a program is covered only if its contents constitute a work based
8f435d95de2724d4bc75338a9af8ef995e451599kbrandon the Library (independent of the use of the Library in a tool for
8f435d95de2724d4bc75338a9af8ef995e451599kbrandwriting it). Whether that is true depends on what the Library does
8f435d95de2724d4bc75338a9af8ef995e451599kbrandand what the program that uses the Library does.
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand 1. You may copy and distribute verbatim copies of the Library's
25567fb55c56c266b35f816627a3d7fa560c9f07jortoncomplete source code as you receive it, in any medium, provided that
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandyou conspicuously and appropriately publish on each copy an
8f435d95de2724d4bc75338a9af8ef995e451599kbrandappropriate copyright notice and disclaimer of warranty; keep intact
8f435d95de2724d4bc75338a9af8ef995e451599kbrandall the notices that refer to this License and to the absence of any
8f435d95de2724d4bc75338a9af8ef995e451599kbrandwarranty; and distribute a copy of this License along with the
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand You may charge a fee for the physical act of transferring a copy,
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandand you may at your option offer warranty protection in exchange for a
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand 2. You may modify your copy or copies of the Library or any portion
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandof it, thus forming a work based on the Library, and copy and
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbranddistribute such modifications or work under the terms of Section 1
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandabove, provided that you also meet all of these conditions:
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand a) The modified work must itself be a software library.
0a144187e480568d7ba1f0825afcc48449d2dc0dkbrand b) You must cause the files modified to carry prominent notices
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand stating that you changed the files and the date of any change.
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand c) You must cause the whole of the work to be licensed at no
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand charge to all third parties under the terms of this License.
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand d) If a facility in the modified Library refers to a function or a
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand table of data to be supplied by an application program that uses
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand the facility, other than as an argument passed when the facility
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrand is invoked, then you must make a good faith effort to ensure that,
a05afdf697da2b6dd02312aab6465c20fcadb535sf in the event an application does not supply such function or
a05afdf697da2b6dd02312aab6465c20fcadb535sf table, the facility still operates, and performs whatever part of
a05afdf697da2b6dd02312aab6465c20fcadb535sf its purpose remains meaningful.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand (For example, a function in a library to compute square roots has
8f435d95de2724d4bc75338a9af8ef995e451599kbrand a purpose that is entirely well-defined independent of the
5400544d62947907986d570435dd16f02ca824e0sf application. Therefore, Subsection 2d requires that any
8f435d95de2724d4bc75338a9af8ef995e451599kbrand application-supplied function or table used by this function must
8f435d95de2724d4bc75338a9af8ef995e451599kbrand be optional: if the application does not supply it, the square
8f435d95de2724d4bc75338a9af8ef995e451599kbrand root function must still compute square roots.)
8f435d95de2724d4bc75338a9af8ef995e451599kbrandThese requirements apply to the modified work as a whole. If
8f435d95de2724d4bc75338a9af8ef995e451599kbrandidentifiable sections of that work are not derived from the Library,
8f435d95de2724d4bc75338a9af8ef995e451599kbrandand can be reasonably considered independent and separate works in
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthemselves, then this License, and its terms, do not apply to those
8f435d95de2724d4bc75338a9af8ef995e451599kbrandsections when you distribute them as separate works. But when you
8f435d95de2724d4bc75338a9af8ef995e451599kbranddistribute the same sections as part of a whole which is a work based
8f435d95de2724d4bc75338a9af8ef995e451599kbrandon the Library, the distribution of the whole must be on the terms of
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthis License, whose permissions for other licensees extend to the
8f435d95de2724d4bc75338a9af8ef995e451599kbrandentire whole, and thus to each and every part regardless of who wrote
8f435d95de2724d4bc75338a9af8ef995e451599kbrandThus, it is not the intent of this section to claim rights or contest
8f435d95de2724d4bc75338a9af8ef995e451599kbrandyour rights to work written entirely by you; rather, the intent is to
8f435d95de2724d4bc75338a9af8ef995e451599kbrandexercise the right to control the distribution of derivative or
8f435d95de2724d4bc75338a9af8ef995e451599kbrandcollective works based on the Library.
8f435d95de2724d4bc75338a9af8ef995e451599kbrandIn addition, mere aggregation of another work not based on the Library
8f435d95de2724d4bc75338a9af8ef995e451599kbrandwith the Library (or with a work based on the Library) on a volume of
8f435d95de2724d4bc75338a9af8ef995e451599kbranda storage or distribution medium does not bring the other work under
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthe scope of this License.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand 3. You may opt to apply the terms of the ordinary GNU General Public
8f435d95de2724d4bc75338a9af8ef995e451599kbrandLicense instead of this License to a given copy of the Library. To do
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthis, you must alter all the notices that refer to this License, so
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthat they refer to the ordinary GNU General Public License, version 2,
8f435d95de2724d4bc75338a9af8ef995e451599kbrandinstead of to this License. (If a newer version than version 2 of the
8f435d95de2724d4bc75338a9af8ef995e451599kbrandordinary GNU General Public License has appeared, then you can specify
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthat version instead if you wish.) Do not make any other change in
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthese notices.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand Once this change is made in a given copy, it is irreversible for
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthat copy, so the ordinary GNU General Public License applies to all
8f435d95de2724d4bc75338a9af8ef995e451599kbrandsubsequent copies and derivative works made from that copy.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand This option is useful when you wish to copy part of the code of
8f435d95de2724d4bc75338a9af8ef995e451599kbrandthe Library into a program that is not a library.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand 4. You may copy and distribute the Library (or a portion or
8f435d95de2724d4bc75338a9af8ef995e451599kbrandderivative of it, under Section 2) in object code or executable form
8f435d95de2724d4bc75338a9af8ef995e451599kbrandunder the terms of Sections 1 and 2 above provided that you accompany
0e6c63c34b6c118ec6c28ddadda5eefb2584bf7dkbrandit with the complete corresponding machine-readable source code, which
8f435d95de2724d4bc75338a9af8ef995e451599kbrandmust be distributed under the terms of Sections 1 and 2 above on a
8f435d95de2724d4bc75338a9af8ef995e451599kbrandmedium customarily used for software interchange.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand If distribution of object code is made by offering access to copy
8f435d95de2724d4bc75338a9af8ef995e451599kbrandfrom a designated place, then offering equivalent access to copy the
8f435d95de2724d4bc75338a9af8ef995e451599kbrandsource code from the same place satisfies the requirement to
8f435d95de2724d4bc75338a9af8ef995e451599kbranddistribute the source code, even though third parties are not
8f435d95de2724d4bc75338a9af8ef995e451599kbrandcompelled to copy the source along with the object code.
8f435d95de2724d4bc75338a9af8ef995e451599kbrand 5. A program that contains no derivative of any portion of the
8ec5cc2de6b079c1a686cc5f258806ae53928639jortonLibrary, but is designed to work with the Library by being compiled or
uses the Library", as object code and/or source code, so that the
system; it is up to the author/donor to decide if he or she is willing
12. If the distribution and/or use of the Library is restricted in
13. The Free Software Foundation may publish revised and/or new
EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
This library is free software; you can redistribute it and/or