Difference between revisions of "Licensing"

From Minetest Wiki
Jump to navigation Jump to search
(dsfsdfsdf)
Line 1: Line 1:
In the past few months, especially after the community released some Android builds of the engine, apps like “Starve game”, “Lime Minetest”, and the erstwhile “BuildCraft” have been cropping up in Google Play and the App Store. Simply put, these builds are simply a repackaging of the Minetest engine and subgame. These Minetest builds are usually obsolete, often include advertisements and do not undergo the rigorous testing subject to the Minetest engine.
+
Recently a considerable number of Minetest-based games have been appearing in the Android playstore, and Google Play. See the [[Overview of Minetest forks|list of Minetest forks]] for examples of these.
  
The [https://www.gnu.org/licenses/lgpl-2.1.html LGPL 2.1+ free software license], [http://wiki.minetest.net/Minetest under which Minetest is distributed] ''does'' allow implicit distribution of the compiled game, and subsequent modifications that are distributed by default. 
+
''Please look at: [http://www.flightgear.org/flightprosim.html FlightGear] as they have the same issue as Minetest has.''
  
Most games that use Minetest as their source for their (non-free?) version only link back to the original source code, not the modified source code, which must be made free for all paying (or not) paying users of the program.
+
== Complying with the License ==
  
''Please look at: [http://www.flightgear.org/flightprosim.html FlightGear] as they have the same issue as Minetest has.''
+
The code of both the Minetest Engine and Minetest Game are licensed under [https://www.gnu.org/licenses/lgpl-2.1.html LGPL 2.1+ free software license]. Other components may be similarly licensed, however this document does not cover them. Note that this document is only intended to be informative, for the real terms you should read the [https://www.gnu.org/licenses/lgpl-2.1.html LGPL 2.1+ license].
  
== List of known Minetest forks and those recognized by the community ==
+
As a general rule,  which must also be under LGPL 2.1, or a compatible license.
  
These are community recognized forks, or modifications to the original Minetest game, that operate under the LGPL and/or GPL, and are free to download, play and modify.
+
* You must link to the source code behind your app
 +
** Which must also be licensed under LGPL 2.1 or later, or a compatible license. See ''what if I use proprietary source code/libraries?''
 +
** If any modifications were made to the Minetest Engine or Game, you must state this inside of your application, and provide a means to download the **modified** source code.
 +
** If you did not modify any source code, you must still link to the source code behind the app - however this can be the official Minetest repo
 +
* You must not remove any copyright notices.
 +
* You must state significant changes to the software.
  
=== Freeminer ===
+
'''It is an infringement to link back to the original source code if you made modifications'''
  
[http://freeminer.org '''Freeminer'''] is an ongoing project started by ex-Minetest developers who wanted to merge some exciting features into the main engine. Unfortunately, the features they worked on caused performance issues with the game, due to which those patches were rejected. Disillusioned by the lack of innovative development,these developers split off from the main Minetest engine, and decided to create a voxel engine where perfection is not paramount, and the main target is to make new features. It is distributed under the GPLv3.
+
=== Where should I put any links? ===
  
=== Voxelands ===
+
You should place a link in the main menu (for example, in the credits tab).
  
[http://voxelands.com '''Voxelands'''] is a fork of Minetest 0.3.1, which is a heavily modified version and licensed under GPLv3+, which has much more content than what the vanilla Minetest 0.3.1 contained, like farming, new biomes and more tools.
+
=== What if I use proprietary source code/libraries? ===
  
== Minetest on Android ==
+
* '''Don't mix proprieary code with LGPL code.''' For example, if you use a proprietary ad library, then you can only call it from proprietary code.
 +
* '''Any LGPL code must be replaceable.''' The user must be able to use their own version of any LGPL code with your software. You must also provide documentation on how to do this.
 +
* Any proprietary code you wrote must not forbid reverse-compilation for the purpose of debugging modifications to the LGPL code.
 +
=== See also ===
  
Official Android builds for Minetest are [https://play.google.com/store/apps/details?id=net.minetest.minetest available for download] on the Google Play Store, and [https://github.com/minetest/minetest/releases on github]. All other apps in the play store are non-official, and may contain ads, or be broken otherwise. Old builds, which are considered outdated, are available [https://forum.minetest.net/viewtopic.php?f=42&t=9389 here].
+
* https://tldrlegal.com/license/gnu-lesser-general-public-license-v3-(lgpl-3)
 +
* https://www.gnu.org/licenses/lgpl-2.1.html
 +
* https://softwareengineering.stackexchange.com/questions/86142/what-exactly-do-i-need-to-do-if-i-use-a-lgpl-licenced-library
  
 
== What to do if I spot a program that is possibly infringing Minetest's license? ==
 
== What to do if I spot a program that is possibly infringing Minetest's license? ==
  
If you think that a certain program is infringing on Minetest's LGPL 2.1 license, please check with the program's website to see if it is licensed under similar terms, and if the source code is being distributed. If the license seems to be proprietary, and if the developer alleges that the program is their own work, then contact [mailto:celeron55@gmail.com celeron55]. Alternatively, join the [http://webchat.freenode.net/?channels=#minetest Minetest IRC channel] and report it there. It doesn't matter if anyone replies or not, it will be logged and the community will check on it themselves.
+
If you think that a certain program is infringing on Minetest's LGPL 2.1 license, please check with the program's website to see if it is licensed under similar terms, and if the source code is being distributed.If the license seems to be proprietary, and if the developer alleges that the program is their own work, then contact [mailto:celeron55@gmail.com celeron55]. Alternatively, join the [http://webchat.freenode.net/?channels=#minetest Minetest IRC channel] and report it there. It doesn't matter if anyone replies or not, it will be logged and the community will check on it themselves.
 +
 
  
 
=== What not to do if a program is infringing Minetest's license ===
 
=== What not to do if a program is infringing Minetest's license ===
 +
 +
'''DO NOT TAKE ANY ACTION AGAINST THE DEVELOPER''' - You must report it to the Minetest devs instead.
  
 
Even if it is as clear as day that a certain program is using code and artwork from Minetest and is not distributing it under similar conditions, please do not attempt, or do the following:
 
Even if it is as clear as day that a certain program is using code and artwork from Minetest and is not distributing it under similar conditions, please do not attempt, or do the following:

Revision as of 23:40, 11 May 2017

Recently a considerable number of Minetest-based games have been appearing in the Android playstore, and Google Play. See the list of Minetest forks for examples of these.

Please look at: FlightGear as they have the same issue as Minetest has.

Complying with the License

The code of both the Minetest Engine and Minetest Game are licensed under LGPL 2.1+ free software license. Other components may be similarly licensed, however this document does not cover them. Note that this document is only intended to be informative, for the real terms you should read the LGPL 2.1+ license.

As a general rule, which must also be under LGPL 2.1, or a compatible license.

  • You must link to the source code behind your app
    • Which must also be licensed under LGPL 2.1 or later, or a compatible license. See what if I use proprietary source code/libraries?
    • If any modifications were made to the Minetest Engine or Game, you must state this inside of your application, and provide a means to download the **modified** source code.
    • If you did not modify any source code, you must still link to the source code behind the app - however this can be the official Minetest repo
  • You must not remove any copyright notices.
  • You must state significant changes to the software.

It is an infringement to link back to the original source code if you made modifications

Where should I put any links?

You should place a link in the main menu (for example, in the credits tab).

What if I use proprietary source code/libraries?

  • Don't mix proprieary code with LGPL code. For example, if you use a proprietary ad library, then you can only call it from proprietary code.
  • Any LGPL code must be replaceable. The user must be able to use their own version of any LGPL code with your software. You must also provide documentation on how to do this.
  • Any proprietary code you wrote must not forbid reverse-compilation for the purpose of debugging modifications to the LGPL code.

See also

What to do if I spot a program that is possibly infringing Minetest's license?

If you think that a certain program is infringing on Minetest's LGPL 2.1 license, please check with the program's website to see if it is licensed under similar terms, and if the source code is being distributed.If the license seems to be proprietary, and if the developer alleges that the program is their own work, then contact celeron55. Alternatively, join the Minetest IRC channel and report it there. It doesn't matter if anyone replies or not, it will be logged and the community will check on it themselves.


What not to do if a program is infringing Minetest's license

DO NOT TAKE ANY ACTION AGAINST THE DEVELOPER - You must report it to the Minetest devs instead.

Even if it is as clear as day that a certain program is using code and artwork from Minetest and is not distributing it under similar conditions, please do not attempt, or do the following:

  1. Do not launch a witch-hunt. This is the 21st century. Please behave appropriately.
  2. Do not attempt to crack, grief, or crash their servers.
  3. Do not attempt to contact the infringing program's developer. Any contact made with the developer shall be after consensus with respected members of the community at large and the Core Development Team.

The above has largely only resulted in a lot of drama, mostly ending with the infringing developer gaining the upper hand and getting away with using Minetest's code while violating the license. Please don't do it.