wxwidgets is licensed under essentially = LGPL + static linking
...essentially the L-GPL (Library General Public Licence), with an exception stating that derived works in binary form may be distributed on the user's own terms. This is a solution that satisfies those who wish to produce GPL'ed software using wxWidgets, and also those producing proprietary software.
wxWidgets is Certified Open Source Software Participants in the discussion that led to this decision include the folk from Abisource, Robert Roebling, Julian Smart, Markus Fleck, Karsten Ballueder, and some advice from Richard Stallman. Richard has confirmed that the new licence is compatible with GPL'ed applications. However, there are no significant restrictions on proprietary applications.
The wxWindows Licence has been approved by the Open Source Initiative, and you can find the licence on their site here...
No, you probably don't need to put the BSD reference into the library, but you should.
When you re-release the BSD component within your GPLv3 package you are re-licensing the BSD component as well. At that point, the only license text that's required is the GPLv3 one.
The GPLv3 license contains the same or similar clauses as the BSD license. In particular, section 4 requires maintaining the copyright notices. Sections 15, 16, and 17 handle the disclaimer of warranty. And the section "How to apply these terms" goes into the details on propagating the conditions of the license.
However, as a courtesy to the original authors on the BSD licensed component, you should provide full attribution and a copy of the BSD license. Effectively you're saying "If you want to use this component from my distribution, then it's under GPLv3. However, you can access this component from its source under a BSD license."
Some supplementing points.
It means that the other license and the GNU GPL are compatible; you can combine code
released under the other license with code released under the GNU GPL in one larger
program.
All GNU GPL versions permit such combinations privately; they also permit distribution
of such combinations provided the combination is released under the same GNU GPL
version. The other license is compatible with the GPL if it permits this too.
The very last sentence (The other license is compatible...
) in that quoted section along with the preceding combination clause (they also permit distribution...
) is your permission (and requirement) to distribute the combination of your project + lxml as GPLv3.
The BSD license (without the advertising clause) is on FSF's list of compatible licenses. Specifically here. This is the same license the lxml team is using.
- Whether you provide a copy of lxml source is kind of a moot point.
Your program won't work without their program, so you can't really get around dragging their program into yours from a licensing point of view as far as the GPL is concerned. It's a "known" circumvention trick that isn't allowed. Fortunately, the licenses are compatible. Because you are choosing to release under the GPLv3 then you're re-licensing the lxml project as expressed / instantiated in your project. Essentially, you've forked the license on lxml but only for within your project.
The lxml team can continue to update and release their code under modified BSD, but the instantiation you use and any modifications you make to it within your project are considered as GPLv3. Note that you could still contribute directly to lxml and then they can release your contribution as BSD. But you can't do that through your GPL project.
Best Answer
If your program depends on an LGPL licensed module/library, then the basic requirement on you is that you must ensure that the users of your program or derived versions of it have the possibility to replace the LGPL licensed code with a different, compatible, version.
One way to ensure this is by putting your code under the (L)GPL license, which ensures that also the source code of derived projects remains available.
Another way is to link dynamically to the module/library, so that the module/library is located at run-time and can be replaced by the user.
As dynamic loading/linking is the default for Python (and just about all interpreted languages), your usage of the
blah
module also falls under this case.As you are not even distributing the
blah
module yourself, you just need to tell your users that they must download/install this module. You don't need to mention what license it is under or provide a copy of the license, because all that will be provided when your users take the action to obtain theblah
module.