[Accessibility] Re: Common Public License (CPL)
Olaf Jan Schmidt
ojschmidt at kde.org
Mon Mar 6 09:13:36 GMT 2006
[ Olaf Jan Schmidt ]
> You cannot use Epos or espeak in the same process as the IBM speech engine,
> because the license of proprietary libraries is incompatible with
> GPL-licensed speech engines. You also cannot link to a proprietary library
> from LGPL-licensed code (only the other way around)
I used misleading words for my comments, so I am trying again.
But please keep in kind that I am not a lawyer. I am trying to summaries my
understanding of the FSF's position, but I might be wrong. I am not writing
this to to give legal advice. I only wanted to explain why a stub library
(even BSD-licensed) would not work in this case, and why a common API for
speech engine drivers makes sense.
If you make free software dependent on a proprietary library, then it cannot
legally be distributed under the LGPL or GPL, at least according to the FSF.
Lawrence Rosen says that you can link to all libraries without legal problems,
which would mean that the GPL and the LGPL are more or less equal. But if the
FSF is right, then the LGPL only allows you to create a proprietary
application "that uses" the API of a LGPL library, not the other way around.
There are some exceptions:
a) The proprietary library is usually distributed with the operating system.
b) The library is dual- or triple-licensed (like Qt).
c) The author of the (L)GPL'ed code adds an exception clause to the GPL, as
KDE has done for Qt in the past. In the case of gnome-speech, this exception
can be assumed to be implied (as was the case for the first KDE
applications).
d) There is a GPL-compatible implementation of the API available, in addition
to the proprietary implementation. This could be the common driver API for
speech engines that I am suggesting.
In the last case, you are allowed to staticly link the software to the
proprietary library, but then you cannot distribute the resulting binary
under terms of the (L)GPL. You can also dynamically link the application to
the GPL-compatible binary and distribute it to someone who runs it with the
proprietary library, but you cannot legally combine them into a
pre-configured joint distribution.
Because of these additional hassles for distributors, it is a much cleaner
architecture to run the various speech engines in separate processes.
Olaf
--
Olaf Jan Schmidt, KDE Accessibility co-maintainer, open standards
accessibility networker, Protestant theology student and webmaster of
http://accessibility.kde.org/ and http://www.amen-online.de/
More information about the kde-core-devel
mailing list