Compare commits
	
		
			1 Commits
		
	
	
		
			master
			...
			unique_ids
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 767d3e5ef7 | 
							
								
								
									
										18
									
								
								.github/workflows/luacheck.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,18 +0,0 @@ | |||||||
|  |  | ||||||
| name: luacheck |  | ||||||
|  |  | ||||||
| on: [push, pull_request] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   build: |  | ||||||
|  |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|  |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v1 |  | ||||||
|     - name: apt |  | ||||||
|       run: sudo apt-get install -y luarocks |  | ||||||
|     - name: luacheck install |  | ||||||
|       run: luarocks install --local luacheck |  | ||||||
|     - name: luacheck run |  | ||||||
|       run: $HOME/.luarocks/bin/luacheck ./ |  | ||||||
							
								
								
									
										28
									
								
								.luacheckrc
									
									
									
									
									
								
							
							
						
						| @@ -1,28 +0,0 @@ | |||||||
| unused_args = false |  | ||||||
| allow_defined_top = true |  | ||||||
|  |  | ||||||
| exclude_files = {".luacheckrc"} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| globals = { |  | ||||||
| 	"minetest", |  | ||||||
| 	"vector", |  | ||||||
| 	"VoxelManip", |  | ||||||
| 	"VoxelArea", |  | ||||||
| 	"PseudoRandom", |  | ||||||
| 	"ItemStack", |  | ||||||
| 	"default", |  | ||||||
| 	"dump", |  | ||||||
| 	"moretrees", |  | ||||||
| 	"ethereal", |  | ||||||
| } |  | ||||||
|  |  | ||||||
| read_globals = { |  | ||||||
| 	string = {fields = {"split"}}, |  | ||||||
|     table = {fields = {"copy", "getn"}}, |  | ||||||
|  |  | ||||||
| 	"stairsplus", |  | ||||||
| 	"stairs", |  | ||||||
| 	"doors", |  | ||||||
| 	"xcompat", |  | ||||||
| } |  | ||||||
							
								
								
									
										960
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						| @@ -3,618 +3,390 @@ Minetest mod moretrees | |||||||
|  |  | ||||||
| All source code: | All source code: | ||||||
| 	© 2013, Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 	© 2013, Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | ||||||
| Date & cocos palm code (date_palm.lua, cocos_palm.lua) | 	Published under the terms and conditions of the WTFPL. | ||||||
| 	© 2016, Rogier <rogier777@gmail.com> | All sapling textures (textures/*_sapling.png): | ||||||
| All date & date palm textures, date-based food, cocos flower & green coconuts, |  | ||||||
| and all poplar textures: |  | ||||||
| 	© 2016, Rogier <rogier777@gmail.com> |  | ||||||
| 	- Three of the date palm textures are modifications of existing moretrees textures |  | ||||||
| 	- The green coconuts are a modification of the brown coconut |  | ||||||
| 	- The date cake batter is a modification of the acorn muffin batter |  | ||||||
| All other sapling textures (textures/*_sapling.png): |  | ||||||
| 	© 2013, Tim Huppertz <mitroman@naturalnet.de> | 	© 2013, Tim Huppertz <mitroman@naturalnet.de> | ||||||
|  | 	Published under the terms and conditions of CC-BY-SA-3.0 Unported. | ||||||
| All other textures: | All other textures: | ||||||
| 	© 2013, Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 	© 2013, Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | ||||||
|  | 	Published under the terms and conditions of CC-BY-SA-3.0 Unported. | ||||||
|  |  | ||||||
| ############################################################################### | ------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| License for all code: LGPL 3.0 |             DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE | ||||||
| License for all media and all other assets:  CC-by-SA 4.0 |                     Version 2, December 2004 | ||||||
|  |  | ||||||
| ############################################################################### |  Copyright (C) 2004 Sam Hocevar <sam@hocevar.net> | ||||||
|  |  | ||||||
|                    GNU LESSER GENERAL PUBLIC LICENSE |  Everyone is permitted to copy and distribute verbatim or modified | ||||||
|                        Version 3, 29 June 2007 |  copies of this license document, and changing it is allowed as long | ||||||
|  |  as the name is changed. | ||||||
|  |  | ||||||
|  Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/> |             DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE | ||||||
|  Everyone is permitted to copy and distribute verbatim copies |    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION | ||||||
|  of this license document, but changing it is not allowed. |  | ||||||
|  |  | ||||||
|  |   0. You just DO WHAT THE FUCK YOU WANT TO. | ||||||
|  |  | ||||||
|   This version of the GNU Lesser General Public License incorporates | This license is commonly known as "WTFPL". | ||||||
| the terms and conditions of version 3 of the GNU General Public |  | ||||||
| License, supplemented by the additional permissions listed below. |  | ||||||
|  |  | ||||||
|   0. Additional Definitions. | ------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
|   As used herein, "this License" refers to version 3 of the GNU Lesser | Creative Commons Legal Code | ||||||
| General Public License, and the "GNU GPL" refers to version 3 of the GNU |  | ||||||
| General Public License. |  | ||||||
|  |  | ||||||
|   "The Library" refers to a covered work governed by this License, | Attribution-ShareAlike 3.0 Unported | ||||||
| other than an Application or a Combined Work as defined below. |  | ||||||
|  |  | ||||||
|   An "Application" is any work that makes use of an interface provided |     CREATIVE COMMONS CORPORATION IS NOT A LAW FIRM AND DOES NOT PROVIDE | ||||||
| by the Library, but which is not otherwise based on the Library. |     LEGAL SERVICES. DISTRIBUTION OF THIS LICENSE DOES NOT CREATE AN | ||||||
| Defining a subclass of a class defined by the Library is deemed a mode |     ATTORNEY-CLIENT RELATIONSHIP. CREATIVE COMMONS PROVIDES THIS | ||||||
| of using an interface provided by the Library. |     INFORMATION ON AN "AS-IS" BASIS. CREATIVE COMMONS MAKES NO WARRANTIES | ||||||
|  |     REGARDING THE INFORMATION PROVIDED, AND DISCLAIMS LIABILITY FOR | ||||||
|  |     DAMAGES RESULTING FROM ITS USE. | ||||||
|  |  | ||||||
|   A "Combined Work" is a work produced by combining or linking an |  | ||||||
| Application with the Library.  The particular version of the Library |  | ||||||
| with which the Combined Work was made is also called the "Linked |  | ||||||
| Version". |  | ||||||
|  |  | ||||||
|   The "Minimal Corresponding Source" for a Combined Work means the |  | ||||||
| Corresponding Source for the Combined Work, excluding any source code |  | ||||||
| for portions of the Combined Work that, considered in isolation, are |  | ||||||
| based on the Application, and not on the Linked Version. |  | ||||||
|  |  | ||||||
|   The "Corresponding Application Code" for a Combined Work means the |  | ||||||
| object code and/or source code for the Application, including any data |  | ||||||
| and utility programs needed for reproducing the Combined Work from the |  | ||||||
| Application, but excluding the System Libraries of the Combined Work. |  | ||||||
|  |  | ||||||
|   1. Exception to Section 3 of the GNU GPL. |  | ||||||
|  |  | ||||||
|   You may convey a covered work under sections 3 and 4 of this License |  | ||||||
| without being bound by section 3 of the GNU GPL. |  | ||||||
|  |  | ||||||
|   2. Conveying Modified Versions. |  | ||||||
|  |  | ||||||
|   If you modify a copy of the Library, and, in your modifications, a |  | ||||||
| facility refers to a function or data to be supplied by an Application |  | ||||||
| that uses the facility (other than as an argument passed when the |  | ||||||
| facility is invoked), then you may convey a copy of the modified |  | ||||||
| version: |  | ||||||
|  |  | ||||||
|    a) under this License, provided that you make a good faith effort to |  | ||||||
|    ensure that, in the event an Application does not supply the |  | ||||||
|    function or data, the facility still operates, and performs |  | ||||||
|    whatever part of its purpose remains meaningful, or |  | ||||||
|  |  | ||||||
|    b) under the GNU GPL, with none of the additional permissions of |  | ||||||
|    this License applicable to that copy. |  | ||||||
|  |  | ||||||
|   3. Object Code Incorporating Material from Library Header Files. |  | ||||||
|  |  | ||||||
|   The object code form of an Application may incorporate material from |  | ||||||
| a header file that is part of the Library.  You may convey such object |  | ||||||
| code under terms of your choice, provided that, if the incorporated |  | ||||||
| material is not limited to numerical parameters, data structure |  | ||||||
| layouts and accessors, or small macros, inline functions and templates |  | ||||||
| (ten or fewer lines in length), you do both of the following: |  | ||||||
|  |  | ||||||
|    a) Give prominent notice with each copy of the object code that the |  | ||||||
|    Library is used in it and that the Library and its use are |  | ||||||
|    covered by this License. |  | ||||||
|  |  | ||||||
|    b) Accompany the object code with a copy of the GNU GPL and this license |  | ||||||
|    document. |  | ||||||
|  |  | ||||||
|   4. Combined Works. |  | ||||||
|  |  | ||||||
|   You may convey a Combined Work under terms of your choice that, |  | ||||||
| taken together, effectively do not restrict modification of the |  | ||||||
| portions of the Library contained in the Combined Work and reverse |  | ||||||
| engineering for debugging such modifications, if you also do each of |  | ||||||
| the following: |  | ||||||
|  |  | ||||||
|    a) Give prominent notice with each copy of the Combined Work that |  | ||||||
|    the Library is used in it and that the Library and its use are |  | ||||||
|    covered by this License. |  | ||||||
|  |  | ||||||
|    b) Accompany the Combined Work with a copy of the GNU GPL and this license |  | ||||||
|    document. |  | ||||||
|  |  | ||||||
|    c) For a Combined Work that displays copyright notices during |  | ||||||
|    execution, include the copyright notice for the Library among |  | ||||||
|    these notices, as well as a reference directing the user to the |  | ||||||
|    copies of the GNU GPL and this license document. |  | ||||||
|  |  | ||||||
|    d) Do one of the following: |  | ||||||
|  |  | ||||||
|        0) Convey the Minimal Corresponding Source under the terms of this |  | ||||||
|        License, and the Corresponding Application Code in a form |  | ||||||
|        suitable for, and under terms that permit, the user to |  | ||||||
|        recombine or relink the Application with a modified version of |  | ||||||
|        the Linked Version to produce a modified Combined Work, in the |  | ||||||
|        manner specified by section 6 of the GNU GPL for conveying |  | ||||||
|        Corresponding Source. |  | ||||||
|  |  | ||||||
|        1) Use a suitable shared library mechanism for linking with the |  | ||||||
|        Library.  A suitable mechanism is one that (a) uses at run time |  | ||||||
|        a copy of the Library already present on the user's computer |  | ||||||
|        system, and (b) will operate properly with a modified version |  | ||||||
|        of the Library that is interface-compatible with the Linked |  | ||||||
|        Version. |  | ||||||
|  |  | ||||||
|    e) Provide Installation Information, but only if you would otherwise |  | ||||||
|    be required to provide such information under section 6 of the |  | ||||||
|    GNU GPL, and only to the extent that such information is |  | ||||||
|    necessary to install and execute a modified version of the |  | ||||||
|    Combined Work produced by recombining or relinking the |  | ||||||
|    Application with a modified version of the Linked Version. (If |  | ||||||
|    you use option 4d0, the Installation Information must accompany |  | ||||||
|    the Minimal Corresponding Source and Corresponding Application |  | ||||||
|    Code. If you use option 4d1, you must provide the Installation |  | ||||||
|    Information in the manner specified by section 6 of the GNU GPL |  | ||||||
|    for conveying Corresponding Source.) |  | ||||||
|  |  | ||||||
|   5. Combined Libraries. |  | ||||||
|  |  | ||||||
|   You may place library facilities that are a work based on the |  | ||||||
| Library side by side in a single library together with other library |  | ||||||
| facilities that are not Applications and are not covered by this |  | ||||||
| License, and convey such a combined library under terms of your |  | ||||||
| choice, if you do both of the following: |  | ||||||
|  |  | ||||||
|    a) Accompany the combined library with a copy of the same work based |  | ||||||
|    on the Library, uncombined with any other library facilities, |  | ||||||
|    conveyed under the terms of this License. |  | ||||||
|  |  | ||||||
|    b) Give prominent notice with the combined library that part of it |  | ||||||
|    is a work based on the Library, and explaining where to find the |  | ||||||
|    accompanying uncombined form of the same work. |  | ||||||
|  |  | ||||||
|   6. Revised Versions of the GNU Lesser General Public License. |  | ||||||
|  |  | ||||||
|   The Free Software Foundation may publish revised and/or new versions |  | ||||||
| of the GNU Lesser General Public License from time to time. Such new |  | ||||||
| versions will be similar in spirit to the present version, but may |  | ||||||
| differ in detail to address new problems or concerns. |  | ||||||
|  |  | ||||||
|   Each version is given a distinguishing version number. If the |  | ||||||
| Library as you received it specifies that a certain numbered version |  | ||||||
| of the GNU Lesser General Public License "or any later version" |  | ||||||
| applies to it, you have the option of following the terms and |  | ||||||
| conditions either of that published version or of any later version |  | ||||||
| published by the Free Software Foundation. If the Library as you |  | ||||||
| received it does not specify a version number of the GNU Lesser |  | ||||||
| General Public License, you may choose any version of the GNU Lesser |  | ||||||
| General Public License ever published by the Free Software Foundation. |  | ||||||
|  |  | ||||||
|   If the Library as you received it specifies that a proxy can decide |  | ||||||
| whether future versions of the GNU Lesser General Public License shall |  | ||||||
| apply, that proxy's public statement of acceptance of any version is |  | ||||||
| permanent authorization for you to choose that version for the |  | ||||||
| Library. |  | ||||||
|  |  | ||||||
| ############################################################################### |  | ||||||
|  |  | ||||||
| Attribution-ShareAlike 4.0 International |  | ||||||
|  |  | ||||||
| ======================================================================= |  | ||||||
|  |  | ||||||
| Creative Commons Corporation ("Creative Commons") is not a law firm and |  | ||||||
| does not provide legal services or legal advice. Distribution of |  | ||||||
| Creative Commons public licenses does not create a lawyer-client or |  | ||||||
| other relationship. Creative Commons makes its licenses and related |  | ||||||
| information available on an "as-is" basis. Creative Commons gives no |  | ||||||
| warranties regarding its licenses, any material licensed under their |  | ||||||
| terms and conditions, or any related information. Creative Commons |  | ||||||
| disclaims all liability for damages resulting from their use to the |  | ||||||
| fullest extent possible. |  | ||||||
|  |  | ||||||
| Using Creative Commons Public Licenses |  | ||||||
|  |  | ||||||
| Creative Commons public licenses provide a standard set of terms and |  | ||||||
| conditions that creators and other rights holders may use to share |  | ||||||
| original works of authorship and other material subject to copyright |  | ||||||
| and certain other rights specified in the public license below. The |  | ||||||
| following considerations are for informational purposes only, are not |  | ||||||
| exhaustive, and do not form part of our licenses. |  | ||||||
|  |  | ||||||
|      Considerations for licensors: Our public licenses are |  | ||||||
|      intended for use by those authorized to give the public |  | ||||||
|      permission to use material in ways otherwise restricted by |  | ||||||
|      copyright and certain other rights. Our licenses are |  | ||||||
|      irrevocable. Licensors should read and understand the terms |  | ||||||
|      and conditions of the license they choose before applying it. |  | ||||||
|      Licensors should also secure all rights necessary before |  | ||||||
|      applying our licenses so that the public can reuse the |  | ||||||
|      material as expected. Licensors should clearly mark any |  | ||||||
|      material not subject to the license. This includes other CC- |  | ||||||
|      licensed material, or material used under an exception or |  | ||||||
|      limitation to copyright. More considerations for licensors: |  | ||||||
| 	wiki.creativecommons.org/Considerations_for_licensors |  | ||||||
|  |  | ||||||
|      Considerations for the public: By using one of our public |  | ||||||
|      licenses, a licensor grants the public permission to use the |  | ||||||
|      licensed material under specified terms and conditions. If |  | ||||||
|      the licensor's permission is not necessary for any reason--for |  | ||||||
|      example, because of any applicable exception or limitation to |  | ||||||
|      copyright--then that use is not regulated by the license. Our |  | ||||||
|      licenses grant only permissions under copyright and certain |  | ||||||
|      other rights that a licensor has authority to grant. Use of |  | ||||||
|      the licensed material may still be restricted for other |  | ||||||
|      reasons, including because others have copyright or other |  | ||||||
|      rights in the material. A licensor may make special requests, |  | ||||||
|      such as asking that all changes be marked or described. |  | ||||||
|      Although not required by our licenses, you are encouraged to |  | ||||||
|      respect those requests where reasonable. More considerations |  | ||||||
|      for the public:  |  | ||||||
| 	wiki.creativecommons.org/Considerations_for_licensees |  | ||||||
|  |  | ||||||
| ======================================================================= |  | ||||||
|  |  | ||||||
| Creative Commons Attribution-ShareAlike 4.0 International Public |  | ||||||
| License | License | ||||||
|  |  | ||||||
| By exercising the Licensed Rights (defined below), You accept and agree | THE WORK (AS DEFINED BELOW) IS PROVIDED UNDER THE TERMS OF THIS CREATIVE | ||||||
| to be bound by the terms and conditions of this Creative Commons | COMMONS PUBLIC LICENSE ("CCPL" OR "LICENSE"). THE WORK IS PROTECTED BY | ||||||
| Attribution-ShareAlike 4.0 International Public License ("Public | COPYRIGHT AND/OR OTHER APPLICABLE LAW. ANY USE OF THE WORK OTHER THAN AS | ||||||
| License"). To the extent this Public License may be interpreted as a | AUTHORIZED UNDER THIS LICENSE OR COPYRIGHT LAW IS PROHIBITED. | ||||||
| contract, You are granted the Licensed Rights in consideration of Your |  | ||||||
| acceptance of these terms and conditions, and the Licensor grants You |  | ||||||
| such rights in consideration of benefits the Licensor receives from |  | ||||||
| making the Licensed Material available under these terms and |  | ||||||
| conditions. |  | ||||||
|  |  | ||||||
|  | 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. | ||||||
|  |  | ||||||
| Section 1 -- Definitions. | 1. Definitions | ||||||
|  |  | ||||||
|   a. Adapted Material means material subject to Copyright and Similar |  a. "Adaptation" means a work based upon the Work, or upon the Work and | ||||||
|      Rights that is derived from or based upon the Licensed Material |     other pre-existing works, such as a translation, adaptation, | ||||||
|      and in which the Licensed Material is translated, altered, |     derivative work, arrangement of music or other alterations of a | ||||||
|      arranged, transformed, or otherwise modified in a manner requiring |     literary or artistic work, or phonogram or performance and includes | ||||||
|      permission under the Copyright and Similar Rights held by the |     cinematographic adaptations or any other form in which the Work may be | ||||||
|      Licensor. For purposes of this Public License, where the Licensed |     recast, transformed, or adapted including in any form recognizably | ||||||
|      Material is a musical work, performance, or sound recording, |     derived from the original, except that a work that constitutes a | ||||||
|      Adapted Material is always produced where the Licensed Material is |     Collection will not be considered an Adaptation for the purpose of | ||||||
|      synched in timed relation with a moving image. |     this License. For the avoidance of doubt, where the Work is a musical | ||||||
|  |     work, performance or phonogram, the synchronization of the Work in | ||||||
|   b. Adapter's License means the license You apply to Your Copyright |     timed-relation with a moving image ("synching") will be considered an | ||||||
|      and Similar Rights in Your contributions to Adapted Material in |     Adaptation for the purpose of this License. | ||||||
|      accordance with the terms and conditions of this Public License. |  b. "Collection" means a collection of literary or artistic works, such as | ||||||
|  |     encyclopedias and anthologies, or performances, phonograms or | ||||||
|   c. BY-SA Compatible License means a license listed at |     broadcasts, or other works or subject matter other than works listed | ||||||
|      creativecommons.org/compatiblelicenses, approved by Creative |     in Section 1(f) below, which, by reason of the selection and | ||||||
|      Commons as essentially the equivalent of this Public License. |     arrangement of their contents, constitute intellectual creations, in | ||||||
|  |     which the Work is included in its entirety in unmodified form along | ||||||
|   d. Copyright and Similar Rights means copyright and/or similar rights |     with one or more other contributions, each constituting separate and | ||||||
|      closely related to copyright including, without limitation, |     independent works in themselves, which together are assembled into a | ||||||
|      performance, broadcast, sound recording, and Sui Generis Database |     collective whole. A work that constitutes a Collection will not be | ||||||
|      Rights, without regard to how the rights are labeled or |     considered an Adaptation (as defined below) for the purposes of this | ||||||
|      categorized. For purposes of this Public License, the rights |  | ||||||
|      specified in Section 2(b)(1)-(2) are not Copyright and Similar |  | ||||||
|      Rights. |  | ||||||
|  |  | ||||||
|   e. Effective Technological Measures means those measures that, in the |  | ||||||
|      absence of proper authority, may not be circumvented under laws |  | ||||||
|      fulfilling obligations under Article 11 of the WIPO Copyright |  | ||||||
|      Treaty adopted on December 20, 1996, and/or similar international |  | ||||||
|      agreements. |  | ||||||
|  |  | ||||||
|   f. Exceptions and Limitations means fair use, fair dealing, and/or |  | ||||||
|      any other exception or limitation to Copyright and Similar Rights |  | ||||||
|      that applies to Your use of the Licensed Material. |  | ||||||
|  |  | ||||||
|   g. License Elements means the license attributes listed in the name |  | ||||||
|      of a Creative Commons Public License. The License Elements of this |  | ||||||
|      Public License are Attribution and ShareAlike. |  | ||||||
|  |  | ||||||
|   h. Licensed Material means the artistic or literary work, database, |  | ||||||
|      or other material to which the Licensor applied this Public |  | ||||||
|     License. |     License. | ||||||
|  |  c. "Creative Commons Compatible License" means a license that is listed | ||||||
|   i. Licensed Rights means the rights granted to You subject to the |     at http://creativecommons.org/compatiblelicenses that has been | ||||||
|      terms and conditions of this Public License, which are limited to |     approved by Creative Commons as being essentially equivalent to this | ||||||
|      all Copyright and Similar Rights that apply to Your use of the |     License, including, at a minimum, because that license: (i) contains | ||||||
|      Licensed Material and that the Licensor has authority to license. |     terms that have the same purpose, meaning and effect as the License | ||||||
|  |     Elements of this License; and, (ii) explicitly permits the relicensing | ||||||
|   j. Licensor means the individual(s) or entity(ies) granting rights |     of adaptations of works made available under that license under this | ||||||
|      under this Public License. |     License or a Creative Commons jurisdiction license with the same | ||||||
|  |     License Elements as this License. | ||||||
|   k. Share means to provide material to the public by any means or |  d. "Distribute" means to make available to the public the original and | ||||||
|      process that requires permission under the Licensed Rights, such |     copies of the Work or Adaptation, as appropriate, through sale or | ||||||
|      as reproduction, public display, public performance, distribution, |     other transfer of ownership. | ||||||
|      dissemination, communication, or importation, and to make material |  e. "License Elements" means the following high-level license attributes | ||||||
|      available to the public including in ways that members of the |     as selected by Licensor and indicated in the title of this License: | ||||||
|      public may access the material from a place and at a time |     Attribution, ShareAlike. | ||||||
|      individually chosen by them. |  f. "Licensor" means the individual, individuals, entity or entities that | ||||||
|  |     offer(s) the Work under the terms of this License. | ||||||
|   l. Sui Generis Database Rights means rights other than copyright |  g. "Original Author" means, in the case of a literary or artistic work, | ||||||
|      resulting from Directive 96/9/EC of the European Parliament and of |     the individual, individuals, entity or entities who created the Work | ||||||
|      the Council of 11 March 1996 on the legal protection of databases, |     or if no individual or entity can be identified, the publisher; and in | ||||||
|      as amended and/or succeeded, as well as other essentially |     addition (i) in the case of a performance the actors, singers, | ||||||
|      equivalent rights anywhere in the world. |     musicians, dancers, and other persons who act, sing, deliver, declaim, | ||||||
|  |     play in, interpret or otherwise perform literary or artistic works or | ||||||
|   m. You means the individual or entity exercising the Licensed Rights |     expressions of folklore; (ii) in the case of a phonogram the producer | ||||||
|      under this Public License. Your has a corresponding meaning. |     being the person or legal entity who first fixes the sounds of a | ||||||
|  |     performance or other sounds; and, (iii) in the case of broadcasts, the | ||||||
|  |     organization that transmits the broadcast. | ||||||
| Section 2 -- Scope. |  h. "Work" means the literary and/or artistic work offered under the terms | ||||||
|  |     of this License including without limitation any production in the | ||||||
|   a. License grant. |     literary, scientific and artistic domain, whatever may be the mode or | ||||||
|  |     form of its expression including digital form, such as a book, | ||||||
|        1. Subject to the terms and conditions of this Public License, |     pamphlet and other writing; a lecture, address, sermon or other work | ||||||
|           the Licensor hereby grants You a worldwide, royalty-free, |     of the same nature; a dramatic or dramatico-musical work; a | ||||||
|           non-sublicensable, non-exclusive, irrevocable license to |     choreographic work or entertainment in dumb show; a musical | ||||||
|           exercise the Licensed Rights in the Licensed Material to: |     composition with or without words; a cinematographic work to which are | ||||||
|  |     assimilated works expressed by a process analogous to cinematography; | ||||||
|             a. reproduce and Share the Licensed Material, in whole or |     a work of drawing, painting, architecture, sculpture, engraving or | ||||||
|                in part; and |     lithography; a photographic work to which are assimilated works | ||||||
|  |     expressed by a process analogous to photography; a work of applied | ||||||
|             b. produce, reproduce, and Share Adapted Material. |     art; an illustration, map, plan, sketch or three-dimensional work | ||||||
|  |     relative to geography, topography, architecture or science; a | ||||||
|        2. Exceptions and Limitations. For the avoidance of doubt, where |     performance; a broadcast; a phonogram; a compilation of data to the | ||||||
|           Exceptions and Limitations apply to Your use, this Public |     extent it is protected as a copyrightable work; or a work performed by | ||||||
|           License does not apply, and You do not need to comply with |     a variety or circus performer to the extent it is not otherwise | ||||||
|           its terms and conditions. |     considered a literary or artistic work. | ||||||
|  |  i. "You" means an individual or entity exercising rights under this | ||||||
|        3. Term. The term of this Public License is specified in Section |     License who has not previously violated the terms of this License with | ||||||
|           6(a). |     respect to the Work, or who has received express permission from the | ||||||
|  |     Licensor to exercise rights under this License despite a previous | ||||||
|        4. Media and formats; technical modifications allowed. The |     violation. | ||||||
|           Licensor authorizes You to exercise the Licensed Rights in |  j. "Publicly Perform" means to perform public recitations of the Work and | ||||||
|           all media and formats whether now known or hereafter created, |     to communicate to the public those public recitations, by any means or | ||||||
|           and to make technical modifications necessary to do so. The |     process, including by wire or wireless means or public digital | ||||||
|           Licensor waives and/or agrees not to assert any right or |     performances; to make available to the public Works in such a way that | ||||||
|           authority to forbid You from making technical modifications |     members of the public may access these Works from a place and at a | ||||||
|           necessary to exercise the Licensed Rights, including |     place individually chosen by them; to perform the Work to the public | ||||||
|           technical modifications necessary to circumvent Effective |     by any means or process and the communication to the public of the | ||||||
|           Technological Measures. For purposes of this Public License, |     performances of the Work, including by public digital performance; to | ||||||
|           simply making modifications authorized by this Section 2(a) |     broadcast and rebroadcast the Work by any means including signs, | ||||||
|           (4) never produces Adapted Material. |     sounds or images. | ||||||
|  |  k. "Reproduce" means to make copies of the Work by any means including | ||||||
|        5. Downstream recipients. |     without limitation by sound or visual recordings and the right of | ||||||
|  |     fixation and reproducing fixations of the Work, including storage of a | ||||||
|             a. Offer from the Licensor -- Licensed Material. Every |     protected performance or phonogram in digital form or other electronic | ||||||
|                recipient of the Licensed Material automatically |     medium. | ||||||
|                receives an offer from the Licensor to exercise the |  | ||||||
|                Licensed Rights under the terms and conditions of this | 2. Fair Dealing Rights. Nothing in this License is intended to reduce, | ||||||
|                Public License. | limit, or restrict any uses free from copyright or rights arising from | ||||||
|  | limitations or exceptions that are provided for in connection with the | ||||||
|             b. Additional offer from the Licensor -- Adapted Material. | copyright protection under copyright law or other applicable laws. | ||||||
|                Every recipient of Adapted Material from You |  | ||||||
|                automatically receives an offer from the Licensor to | 3. License Grant. Subject to the terms and conditions of this License, | ||||||
|                exercise the Licensed Rights in the Adapted Material | Licensor hereby grants You a worldwide, royalty-free, non-exclusive, | ||||||
|                under the conditions of the Adapter's License You apply. | perpetual (for the duration of the applicable copyright) license to | ||||||
|  | exercise the rights in the Work as stated below: | ||||||
|             c. No downstream restrictions. You may not offer or impose |  | ||||||
|                any additional or different terms or conditions on, or |  a. to Reproduce the Work, to incorporate the Work into one or more | ||||||
|                apply any Effective Technological Measures to, the |     Collections, and to Reproduce the Work as incorporated in the | ||||||
|                Licensed Material if doing so restricts exercise of the |     Collections; | ||||||
|                Licensed Rights by any recipient of the Licensed |  b. to create and Reproduce Adaptations provided that any such Adaptation, | ||||||
|                Material. |     including any translation in any medium, takes reasonable steps to | ||||||
|  |     clearly label, demarcate or otherwise identify that changes were made | ||||||
|        6. No endorsement. Nothing in this Public License constitutes or |     to the original Work. For example, a translation could be marked "The | ||||||
|           may be construed as permission to assert or imply that You |     original work was translated from English to Spanish," or a | ||||||
|           are, or that Your use of the Licensed Material is, connected |     modification could indicate "The original work has been modified."; | ||||||
|           with, or sponsored, endorsed, or granted official status by, |  c. to Distribute and Publicly Perform the Work including as incorporated | ||||||
|           the Licensor or others designated to receive attribution as |     in Collections; and, | ||||||
|           provided in Section 3(a)(1)(A)(i). |  d. to Distribute and Publicly Perform Adaptations. | ||||||
|  |  e. For the avoidance of doubt: | ||||||
|   b. Other rights. |  | ||||||
|  |      i. Non-waivable Compulsory License Schemes. In those jurisdictions in | ||||||
|        1. Moral rights, such as the right of integrity, are not |         which the right to collect royalties through any statutory or | ||||||
|           licensed under this Public License, nor are publicity, |         compulsory licensing scheme cannot be waived, the Licensor | ||||||
|           privacy, and/or other similar personality rights; however, to |         reserves the exclusive right to collect such royalties for any | ||||||
|           the extent possible, the Licensor waives and/or agrees not to |         exercise by You of the rights granted under this License; | ||||||
|           assert any such rights held by the Licensor to the limited |     ii. Waivable Compulsory License Schemes. In those jurisdictions in | ||||||
|           extent necessary to allow You to exercise the Licensed |         which the right to collect royalties through any statutory or | ||||||
|           Rights, but not otherwise. |         compulsory licensing scheme can be waived, the Licensor waives the | ||||||
|  |         exclusive right to collect such royalties for any exercise by You | ||||||
|        2. Patent and trademark rights are not licensed under this |         of the rights granted under this License; and, | ||||||
|           Public License. |    iii. Voluntary License Schemes. The Licensor waives the right to | ||||||
|  |         collect royalties, whether individually or, in the event that the | ||||||
|        3. To the extent possible, the Licensor waives any right to |         Licensor is a member of a collecting society that administers | ||||||
|           collect royalties from You for the exercise of the Licensed |         voluntary licensing schemes, via that society, from any exercise | ||||||
|           Rights, whether directly or through a collecting society |         by You of the rights granted under this License. | ||||||
|           under any voluntary or waivable statutory or compulsory |  | ||||||
|           licensing scheme. In all other cases the Licensor expressly | The above rights may be exercised in all media and formats whether now | ||||||
|           reserves any right to collect such royalties. | 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. Subject to Section 8(f), all rights not expressly | ||||||
| Section 3 -- License Conditions. | granted by Licensor are hereby reserved. | ||||||
|  |  | ||||||
| Your exercise of the Licensed Rights is expressly made subject to the | 4. Restrictions. The license granted in Section 3 above is expressly made | ||||||
| following conditions. | subject to and limited by the following restrictions: | ||||||
|  |  | ||||||
|   a. Attribution. |  a. You may Distribute or Publicly Perform the Work only under the terms | ||||||
|  |     of this License. You must include a copy of, or the Uniform Resource | ||||||
|        1. If You Share the Licensed Material (including in modified |     Identifier (URI) for, this License with every copy of the Work You | ||||||
|           form), You must: |     Distribute or Publicly Perform. You may not offer or impose any terms | ||||||
|  |     on the Work that restrict the terms of this License or the ability of | ||||||
|             a. retain the following if it is supplied by the Licensor |     the recipient of the Work to exercise the rights granted to that | ||||||
|                with the Licensed Material: |     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 | ||||||
|                  i. identification of the creator(s) of the Licensed |     to the disclaimer of warranties with every copy of the Work You | ||||||
|                     Material and any others designated to receive |     Distribute or Publicly Perform. When You Distribute or Publicly | ||||||
|                     attribution, in any reasonable manner requested by |     Perform the Work, You may not impose any effective technological | ||||||
|                     the Licensor (including by pseudonym if |     measures on the Work that restrict the ability of a recipient of the | ||||||
|                     designated); |     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 | ||||||
|                 ii. a copyright notice; |     incorporated in a Collection, but this does not require the Collection | ||||||
|  |     apart from the Work itself to be made subject to the terms of this | ||||||
|                iii. a notice that refers to this Public License; |     License. If You create a Collection, upon notice from any Licensor You | ||||||
|  |     must, to the extent practicable, remove from the Collection any credit | ||||||
|                 iv. a notice that refers to the disclaimer of |     as required by Section 4(c), as requested. If You create an | ||||||
|                     warranties; |     Adaptation, upon notice from any Licensor You must, to the extent | ||||||
|  |     practicable, remove from the Adaptation any credit as required by | ||||||
|                  v. a URI or hyperlink to the Licensed Material to the |     Section 4(c), as requested. | ||||||
|                     extent reasonably practicable; |  b. You may Distribute or Publicly Perform an Adaptation only under the | ||||||
|  |     terms of: (i) this License; (ii) a later version of this License with | ||||||
|             b. indicate if You modified the Licensed Material and |     the same License Elements as this License; (iii) a Creative Commons | ||||||
|                retain an indication of any previous modifications; and |     jurisdiction license (either this or a later license version) that | ||||||
|  |     contains the same License Elements as this License (e.g., | ||||||
|             c. indicate the Licensed Material is licensed under this |     Attribution-ShareAlike 3.0 US)); (iv) a Creative Commons Compatible | ||||||
|                Public License, and include the text of, or the URI or |     License. If you license the Adaptation under one of the licenses | ||||||
|                hyperlink to, this Public License. |     mentioned in (iv), you must comply with the terms of that license. If | ||||||
|  |     you license the Adaptation under the terms of any of the licenses | ||||||
|        2. You may satisfy the conditions in Section 3(a)(1) in any |     mentioned in (i), (ii) or (iii) (the "Applicable License"), you must | ||||||
|           reasonable manner based on the medium, means, and context in |     comply with the terms of the Applicable License generally and the | ||||||
|           which You Share the Licensed Material. For example, it may be |     following provisions: (I) You must include a copy of, or the URI for, | ||||||
|           reasonable to satisfy the conditions by providing a URI or |     the Applicable License with every copy of each Adaptation You | ||||||
|           hyperlink to a resource that includes the required |     Distribute or Publicly Perform; (II) You may not offer or impose any | ||||||
|           information. |     terms on the Adaptation that restrict the terms of the Applicable | ||||||
|  |     License or the ability of the recipient of the Adaptation to exercise | ||||||
|        3. If requested by the Licensor, You must remove any of the |     the rights granted to that recipient under the terms of the Applicable | ||||||
|           information required by Section 3(a)(1)(A) to the extent |     License; (III) You must keep intact all notices that refer to the | ||||||
|           reasonably practicable. |     Applicable License and to the disclaimer of warranties with every copy | ||||||
|  |     of the Work as included in the Adaptation You Distribute or Publicly | ||||||
|   b. ShareAlike. |     Perform; (IV) when You Distribute or Publicly Perform the Adaptation, | ||||||
|  |     You may not impose any effective technological measures on the | ||||||
|      In addition to the conditions in Section 3(a), if You Share |     Adaptation that restrict the ability of a recipient of the Adaptation | ||||||
|      Adapted Material You produce, the following conditions also apply. |     from You to exercise the rights granted to that recipient under the | ||||||
|  |     terms of the Applicable License. This Section 4(b) applies to the | ||||||
|        1. The Adapter's License You apply must be a Creative Commons |     Adaptation as incorporated in a Collection, but this does not require | ||||||
|           license with the same License Elements, this version or |     the Collection apart from the Adaptation itself to be made subject to | ||||||
|           later, or a BY-SA Compatible License. |     the terms of the Applicable License. | ||||||
|  |  c. If You Distribute, or Publicly Perform the Work or any Adaptations or | ||||||
|        2. You must include the text of, or the URI or hyperlink to, the |     Collections, You must, unless a request has been made pursuant to | ||||||
|           Adapter's License You apply. You may satisfy this condition |     Section 4(a), keep intact all copyright notices for the Work and | ||||||
|           in any reasonable manner based on the medium, means, and |     provide, reasonable to the medium or means You are utilizing: (i) the | ||||||
|           context in which You Share Adapted Material. |     name of the Original Author (or pseudonym, if applicable) if supplied, | ||||||
|  |     and/or if the Original Author and/or Licensor designate another party | ||||||
|        3. You may not offer or impose any additional or different terms |     or parties (e.g., a sponsor institute, publishing entity, journal) for | ||||||
|           or conditions on, or apply any Effective Technological |     attribution ("Attribution Parties") in Licensor's copyright notice, | ||||||
|           Measures to, Adapted Material that restrict exercise of the |     terms of service or by other reasonable means, the name of such party | ||||||
|           rights granted under the Adapter's License You apply. |     or parties; (ii) the title of the Work if supplied; (iii) to the | ||||||
|  |     extent reasonably practicable, the URI, if any, that Licensor | ||||||
|  |     specifies to be associated with the Work, unless such URI does not | ||||||
| Section 4 -- Sui Generis Database Rights. |     refer to the copyright notice or licensing information for the Work; | ||||||
|  |     and (iv) , consistent with Ssection 3(b), in the case of an | ||||||
| Where the Licensed Rights include Sui Generis Database Rights that |     Adaptation, a credit identifying the use of the Work in the Adaptation | ||||||
| apply to Your use of the Licensed Material: |     (e.g., "French translation of the Work by Original Author," or | ||||||
|  |     "Screenplay based on original Work by Original Author"). The credit | ||||||
|   a. for the avoidance of doubt, Section 2(a)(1) grants You the right |     required by this Section 4(c) may be implemented in any reasonable | ||||||
|      to extract, reuse, reproduce, and Share all or a substantial |     manner; provided, however, that in the case of a Adaptation or | ||||||
|      portion of the contents of the database; |     Collection, at a minimum such credit will appear, if a credit for all | ||||||
|  |     contributing authors of the Adaptation or Collection appears, then as | ||||||
|   b. if You include all or a substantial portion of the database |     part of these credits and in a manner at least as prominent as the | ||||||
|      contents in a database in which You have Sui Generis Database |     credits for the other contributing authors. For the avoidance of | ||||||
|      Rights, then the database in which You have Sui Generis Database |     doubt, You may only use the credit required by this Section for the | ||||||
|      Rights (but not its individual contents) is Adapted Material, |     purpose of attribution in the manner set out above and, by exercising | ||||||
|  |     Your rights under this License, You may not implicitly or explicitly | ||||||
|      including for purposes of Section 3(b); and |     assert or imply any connection with, sponsorship or endorsement by the | ||||||
|   c. You must comply with the conditions in Section 3(a) if You Share |     Original Author, Licensor and/or Attribution Parties, as appropriate, | ||||||
|      all or a substantial portion of the contents of the database. |     of You or Your use of the Work, without the separate, express prior | ||||||
|  |     written permission of the Original Author, Licensor and/or Attribution | ||||||
| For the avoidance of doubt, this Section 4 supplements and does not |     Parties. | ||||||
| replace Your obligations under this Public License where the Licensed |  d. Except as otherwise agreed in writing by the Licensor or as may be | ||||||
| Rights include other Copyright and Similar Rights. |     otherwise permitted by applicable law, if You Reproduce, Distribute or | ||||||
|  |     Publicly Perform the Work either by itself or as part of any | ||||||
|  |     Adaptations or Collections, You must not distort, mutilate, modify or | ||||||
| Section 5 -- Disclaimer of Warranties and Limitation of Liability. |     take other derogatory action in relation to the Work which would be | ||||||
|  |     prejudicial to the Original Author's honor or reputation. Licensor | ||||||
|   a. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE |     agrees that in those jurisdictions (e.g. Japan), in which any exercise | ||||||
|      EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS |     of the right granted in Section 3(b) of this License (the right to | ||||||
|      AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF |     make Adaptations) would be deemed to be a distortion, mutilation, | ||||||
|      ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS, |     modification or other derogatory action prejudicial to the Original | ||||||
|      IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION, |     Author's honor and reputation, the Licensor will waive or not assert, | ||||||
|      WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR |     as appropriate, this Section, to the fullest extent permitted by the | ||||||
|      PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS, |     applicable national law, to enable You to reasonably exercise Your | ||||||
|      ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT |     right under Section 3(b) of this License (right to make Adaptations) | ||||||
|      KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT |     but not otherwise. | ||||||
|      ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU. |  | ||||||
|  | 5. Representations, Warranties and Disclaimer | ||||||
|   b. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE |  | ||||||
|      TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION, | UNLESS OTHERWISE MUTUALLY AGREED TO BY THE PARTIES IN WRITING, LICENSOR | ||||||
|      NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT, | OFFERS THE WORK AS-IS AND MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY | ||||||
|      INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES, | KIND CONCERNING THE WORK, EXPRESS, IMPLIED, STATUTORY OR OTHERWISE, | ||||||
|      COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR | INCLUDING, WITHOUT LIMITATION, WARRANTIES OF TITLE, MERCHANTIBILITY, | ||||||
|      USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN | FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF | ||||||
|      ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR | LATENT OR OTHER DEFECTS, ACCURACY, OR THE PRESENCE OF ABSENCE OF ERRORS, | ||||||
|      DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR | WHETHER OR NOT DISCOVERABLE. SOME JURISDICTIONS DO NOT ALLOW THE EXCLUSION | ||||||
|      IN PART, THIS LIMITATION MAY NOT APPLY TO YOU. | OF IMPLIED WARRANTIES, SO SUCH EXCLUSION MAY NOT APPLY TO YOU. | ||||||
|  |  | ||||||
|   c. The disclaimer of warranties and limitation of liability provided | 6. Limitation on Liability. EXCEPT TO THE EXTENT REQUIRED BY APPLICABLE | ||||||
|      above shall be interpreted in a manner that, to the extent | LAW, IN NO EVENT WILL LICENSOR BE LIABLE TO YOU ON ANY LEGAL THEORY FOR | ||||||
|      possible, most closely approximates an absolute disclaimer and | ANY SPECIAL, INCIDENTAL, CONSEQUENTIAL, PUNITIVE OR EXEMPLARY DAMAGES | ||||||
|      waiver of all liability. | ARISING OUT OF THIS LICENSE OR THE USE OF THE WORK, EVEN IF LICENSOR HAS | ||||||
|  | BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. | ||||||
|  |  | ||||||
| Section 6 -- Term and Termination. | 7. Termination | ||||||
|  |  | ||||||
|   a. This Public License applies for the term of the Copyright and |  a. This License and the rights granted hereunder will terminate | ||||||
|      Similar Rights licensed here. However, if You fail to comply with |     automatically upon any breach by You of the terms of this License. | ||||||
|      this Public License, then Your rights under this Public License |     Individuals or entities who have received Adaptations or Collections | ||||||
|      terminate automatically. |     from You under this License, however, will not have their licenses | ||||||
|  |     terminated provided such individuals or entities remain in full | ||||||
|   b. Where Your right to use the Licensed Material has terminated under |     compliance with those licenses. Sections 1, 2, 5, 6, 7, and 8 will | ||||||
|      Section 6(a), it reinstates: |     survive any termination of this License. | ||||||
|  |  b. Subject to the above terms and conditions, the license granted here is | ||||||
|        1. automatically as of the date the violation is cured, provided |     perpetual (for the duration of the applicable copyright in the Work). | ||||||
|           it is cured within 30 days of Your discovery of the |     Notwithstanding the above, Licensor reserves the right to release the | ||||||
|           violation; or |     Work under different license terms or to stop distributing the Work at | ||||||
|  |     any time; provided, however that any such election will not serve to | ||||||
|        2. upon express reinstatement by the Licensor. |     withdraw this License (or any other license that has been, or is | ||||||
|  |     required to be, granted under the terms of this License), and this | ||||||
|      For the avoidance of doubt, this Section 6(b) does not affect any |     License will continue in full force and effect unless terminated as | ||||||
|      right the Licensor may have to seek remedies for Your violations |     stated above. | ||||||
|      of this Public License. |  | ||||||
|  | 8. Miscellaneous | ||||||
|   c. For the avoidance of doubt, the Licensor may also offer the |  | ||||||
|      Licensed Material under separate terms or conditions or stop |  a. Each time You Distribute or Publicly Perform the Work or a Collection, | ||||||
|      distributing the Licensed Material at any time; however, doing so |     the Licensor offers to the recipient a license to the Work on the same | ||||||
|      will not terminate this Public License. |     terms and conditions as the license granted to You under this License. | ||||||
|  |  b. Each time You Distribute or Publicly Perform an Adaptation, Licensor | ||||||
|   d. Sections 1, 5, 6, 7, and 8 survive termination of this Public |     offers to the recipient a license to the original Work on the same | ||||||
|      License. |     terms and conditions as the license granted to You under this License. | ||||||
|  |  c. If any provision of this License is invalid or unenforceable under | ||||||
|  |     applicable law, it shall not affect the validity or enforceability of | ||||||
| Section 7 -- Other Terms and Conditions. |     the remainder of the terms of this License, and without further action | ||||||
|  |     by the parties to this agreement, such provision shall be reformed to | ||||||
|   a. The Licensor shall not be bound by any additional or different |     the minimum extent necessary to make such provision valid and | ||||||
|      terms or conditions communicated by You unless expressly agreed. |     enforceable. | ||||||
|  |  d. No term or provision of this License shall be deemed waived and no | ||||||
|   b. Any arrangements, understandings, or agreements regarding the |     breach consented to unless such waiver or consent shall be in writing | ||||||
|      Licensed Material not stated herein are separate from and |     and signed by the party to be charged with such waiver or consent. | ||||||
|      independent of the terms and conditions of this Public License. |  e. 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 | ||||||
| Section 8 -- Interpretation. |     here. Licensor shall not be bound by any additional provisions that | ||||||
|  |     may appear in any communication from You. This License may not be | ||||||
|   a. For the avoidance of doubt, this Public License does not, and |     modified without the mutual written agreement of the Licensor and You. | ||||||
|      shall not be interpreted to, reduce, limit, restrict, or impose |  f. The rights granted under, and the subject matter referenced, in this | ||||||
|      conditions on any use of the Licensed Material that could lawfully |     License were drafted utilizing the terminology of the Berne Convention | ||||||
|      be made without permission under this Public License. |     for the Protection of Literary and Artistic Works (as amended on | ||||||
|  |     September 28, 1979), the Rome Convention of 1961, the WIPO Copyright | ||||||
|   b. To the extent possible, if any provision of this Public License is |     Treaty of 1996, the WIPO Performances and Phonograms Treaty of 1996 | ||||||
|      deemed unenforceable, it shall be automatically reformed to the |     and the Universal Copyright Convention (as revised on July 24, 1971). | ||||||
|      minimum extent necessary to make it enforceable. If the provision |     These rights and subject matter take effect in the relevant | ||||||
|      cannot be reformed, it shall be severed from this Public License |     jurisdiction in which the License terms are sought to be enforced | ||||||
|      without affecting the enforceability of the remaining terms and |     according to the corresponding provisions of the implementation of | ||||||
|      conditions. |     those treaty provisions in the applicable national law. If the | ||||||
|  |     standard suite of rights granted under applicable copyright law | ||||||
|   c. No term or condition of this Public License will be waived and no |     includes additional rights not granted under this License, such | ||||||
|      failure to comply consented to unless expressly agreed to by the |     additional rights are deemed to be included in the License; this | ||||||
|      Licensor. |     License is not intended to restrict the license of any rights under | ||||||
|  |     applicable law. | ||||||
|   d. Nothing in this Public License constitutes or may be interpreted |  | ||||||
|      as a limitation upon, or waiver of, any privileges and immunities |  | ||||||
|      that apply to the Licensor or You, including from the legal | Creative Commons Notice | ||||||
|      processes of any jurisdiction or authority. |  | ||||||
|  |     Creative Commons is not a party to this License, and makes no warranty | ||||||
|  |     whatsoever in connection with the Work. Creative Commons will not be | ||||||
| ======================================================================= |     liable to You or any party on any legal theory for any damages | ||||||
|  |     whatsoever, including without limitation any general, special, | ||||||
| Creative Commons is not a party to its public |     incidental or consequential damages arising in connection to this | ||||||
| licenses. Notwithstanding, Creative Commons may elect to apply one of |     license. Notwithstanding the foregoing two (2) sentences, if Creative | ||||||
| its public licenses to material it publishes and in those instances |     Commons has expressly identified itself as the Licensor hereunder, it | ||||||
| will be considered the “Licensor.” The text of the Creative Commons |     shall have all rights and obligations of Licensor. | ||||||
| public licenses is dedicated to the public domain under the CC0 Public |  | ||||||
| Domain Dedication. Except for the limited purpose of indicating that |     Except for the limited purpose of indicating to the public that the | ||||||
| material is shared under a Creative Commons public license or as |     Work is licensed under the CCPL, Creative Commons does not authorize | ||||||
| otherwise permitted by the Creative Commons policies published at |     the use by either party of the trademark "Creative Commons" or any | ||||||
| creativecommons.org/policies, Creative Commons does not authorize the |     related trademark or logo of Creative Commons without the prior | ||||||
| use of the trademark "Creative Commons" or any other trademark or logo |     written consent of Creative Commons. Any permitted use will be in | ||||||
| of Creative Commons without its prior written consent including, |     compliance with Creative Commons' then-current trademark usage | ||||||
| without limitation, in connection with any unauthorized modifications |     guidelines, as may be published on its website or otherwise made | ||||||
| to any of its public licenses or any other arrangements, |     available upon request from time to time. For the avoidance of doubt, | ||||||
| understandings, or agreements concerning use of licensed material. For |     this trademark restriction does not form part of the License. | ||||||
| the avoidance of doubt, this paragraph does not form part of the |  | ||||||
| public licenses. |     Creative Commons may be contacted at http://creativecommons.org/. | ||||||
|  |  | ||||||
| Creative Commons may be contacted at creativecommons.org. |  | ||||||
|   | |||||||
| @@ -8,5 +8,4 @@ jungle trees mod, and big contributions by RealBadAngel. | |||||||
| Brought together into one mod and made L-systems compatible by Vanessa | Brought together into one mod and made L-systems compatible by Vanessa | ||||||
| Ezekowitz. | Ezekowitz. | ||||||
|  |  | ||||||
| Dependencies: `xcompat`   | Dependencies: <a href="https://github.com/VanessaE/plantlife">plants_lib</a> and default | ||||||
| see mod.conf for more |  | ||||||
|   | |||||||
							
								
								
									
										250
									
								
								biome_defs.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,173 +1,183 @@ | |||||||
|  |  | ||||||
| -- TODO |  | ||||||
| -- Use biomes in the decoration definition depending on their heat_point humidity_point |  | ||||||
| -- instead of spawning it with a rather low fill_ratio everywhere |  | ||||||
| local ratio_abundant =  0.001 |  | ||||||
| local ratio_common =    0.0005 |  | ||||||
| local ratio_normal =    0.0003 |  | ||||||
| local ratio_uncommon =  0.0002 |  | ||||||
| local ratio_rare =      0.0001 |  | ||||||
| local ratio_very_rare = 0.00003 |  | ||||||
|  |  | ||||||
| local coniferous_place_on = { |  | ||||||
| 	xcompat.materials.dirt_with_grass, |  | ||||||
| 	"default:dirt_with_coniferous_litter" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| moretrees.beech_biome = { | moretrees.beech_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
| 	fill_ratio = ratio_normal, | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 8, | ||||||
|  | 	seed_diff = 2, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 20, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.palm_biome = { | moretrees.palm_biome = { | ||||||
| 	place_on = xcompat.materials.sand, | 	surface = "default:sand", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 5, | ||||||
|  | 	seed_diff = 330, | ||||||
| 	min_elevation = -1, | 	min_elevation = -1, | ||||||
| 	max_elevation = 1, | 	max_elevation = 1, | ||||||
| 	fill_ratio = ratio_abundant, | 	near_nodes = {"default:water_source"}, | ||||||
| } | 	near_nodes_size = 15, | ||||||
|  | 	near_nodes_count = 10, | ||||||
| moretrees.date_palm_biome = { | 	temp_min = 0.25, | ||||||
| 	place_on = xcompat.materials.desert_sand, | 	temp_max = -0.15, | ||||||
| 	min_elevation = -1, | 	rarity = 50, | ||||||
| 	max_elevation = 8, | 	max_count = 10, | ||||||
| 	fill_ratio = ratio_common, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| moretrees.date_palm_biome_2 = { |  | ||||||
| 	place_on = xcompat.materials.desert_sand, |  | ||||||
| 	min_elevation = 9, |  | ||||||
| 	max_elevation = 30, |  | ||||||
| 	spawn_by = {xcompat.materials.water_source}, |  | ||||||
| 	num_spawn_by = 1, |  | ||||||
| 	fill_ratio = ratio_abundant, |  | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.apple_tree_biome = { | moretrees.apple_tree_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 331, | ||||||
| 	min_elevation = 1, | 	min_elevation = 1, | ||||||
| 	max_elevation = 10, | 	max_elevation = 10, | ||||||
| 	biomes = {"deciduous_forest"}, | 	temp_min = 0.1, | ||||||
| 	fill_ratio = ratio_rare, | 	temp_max = -0.15, | ||||||
|  | 	rarity = 75, | ||||||
|  | 	max_count = 5, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.oak_biome = { | moretrees.oak_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 15, | ||||||
|  | 	seed_diff = 332, | ||||||
| 	min_elevation = 0, | 	min_elevation = 0, | ||||||
| 	max_elevation = 10, | 	max_elevation = 10, | ||||||
| 	fill_ratio = ratio_normal, | 	temp_min = 0.4, | ||||||
|  | 	temp_max = 0.2, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 5, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.sequoia_biome = { | moretrees.sequoia_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 333, | ||||||
| 	min_elevation = 0, | 	min_elevation = 0, | ||||||
| 	max_elevation = 10, | 	max_elevation = 10, | ||||||
| 	fill_ratio = ratio_rare, | 	temp_min = 1, | ||||||
|  | 	temp_max = -0.4, | ||||||
|  | 	rarity = 90, | ||||||
|  | 	max_count = 5, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.birch_biome = { | moretrees.birch_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 5, | ||||||
|  | 	seed_diff = 334, | ||||||
| 	min_elevation = 10, | 	min_elevation = 10, | ||||||
| 	max_elevation = 15, | 	max_elevation = 15, | ||||||
| 	fill_ratio = ratio_common, | 	temp_min = 0.9, | ||||||
|  | 	temp_max = 0.3, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 10, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.willow_biome = { | moretrees.willow_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 337, | ||||||
| 	min_elevation = -5, | 	min_elevation = -5, | ||||||
| 	max_elevation = 5, | 	max_elevation = 5, | ||||||
| 	fill_ratio = ratio_uncommon, | 	near_nodes = {"default:water_source"}, | ||||||
|  | 	near_nodes_size = 15, | ||||||
|  | 	near_nodes_count = 5, | ||||||
|  | 	rarity = 75, | ||||||
|  | 	max_count = 5, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | moretrees.acacia_biome = { | ||||||
|  | 	surface = { "default:dirt_with_grass", "default:desert_sand" }, | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 15, | ||||||
|  | 	seed_diff = 1, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 15, | ||||||
|  | 	plantlife_limit = -1, | ||||||
|  | 	humidity_min = 0.3, | ||||||
|  | 	humidity_max = 0, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.rubber_tree_biome = { | moretrees.rubber_tree_biome = { | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 338, | ||||||
| 	min_elevation = -5, | 	min_elevation = -5, | ||||||
| 	max_elevation = 8, | 	max_elevation = 5, | ||||||
| 	fill_ratio = ratio_normal, | 	near_nodes = {"default:water_source"}, | ||||||
|  | 	near_nodes_size = 15, | ||||||
|  | 	near_nodes_count = 10, | ||||||
|  | 	temp_min = -0.15, | ||||||
|  | 	rarity = 75, | ||||||
|  | 	max_count = 10, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.jungletree_biome = { | moretrees.jungletree_biome = { | ||||||
| 	place_on = { | 	surface = "default:dirt_with_grass", | ||||||
| 		xcompat.materials.dirt, | 	avoid_nodes = moretrees.avoidnodes, | ||||||
| 		xcompat.materials.dirt_with_grass, | 	avoid_radius = 5, | ||||||
| 		"woodsoils:dirt_with_leaves_1", | 	seed_diff = 329, | ||||||
| 		"woodsoils:grass_with_leaves_1", | 	min_elevation = -5, | ||||||
| 		"woodsoils:grass_with_leaves_2", | 	max_elevation = 10, | ||||||
| 		"default:dirt_with_rainforest_litter", | 	temp_min = 0.25, | ||||||
| 	}, | 	near_nodes = {"default:water_source"}, | ||||||
| 	min_elevation = 1, | 	near_nodes_size = 20, | ||||||
| 	spawn_by = minetest.get_modpath("default") and {"default:jungletree"} or nil, | 	near_nodes_count = 7, | ||||||
| 	num_spawn_by = minetest.get_modpath("default") and 1 or nil, | 	rarity = 10, | ||||||
| 	biomes = {"rainforest", "rainforest_swamp"}, | 	max_count = 10, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.spruce_biome = { | moretrees.spruce_biome = { | ||||||
| 	place_on = coniferous_place_on, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 335, | ||||||
| 	min_elevation = 20, | 	min_elevation = 20, | ||||||
| 	fill_ratio = ratio_uncommon, | 	temp_min = 0.9, | ||||||
|  | 	temp_max = 0.7, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 5, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.cedar_biome = { | moretrees.pine_biome = { | ||||||
| 	place_on = coniferous_place_on, | 	surface = "default:dirt_with_grass", | ||||||
| 	min_elevation = 0,  --Added to solve an issue where cedar trees would sometimes spawn deep underground | 	avoid_nodes = moretrees.avoidnodes, | ||||||
| 	fill_ratio = ratio_rare, | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 336, | ||||||
|  | 	near_nodes = {"default:water_source"}, | ||||||
|  | 	near_nodes_size = 15, | ||||||
|  | 	near_nodes_count = 5, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 10, | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| -- Poplar requires a lot of water. |  | ||||||
| moretrees.poplar_biome = { |  | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, |  | ||||||
| 	min_elevation = 0, |  | ||||||
| 	max_elevation = 50, |  | ||||||
| 	spawn_by = {xcompat.materials.water_source}, |  | ||||||
| 	num_spawn_by = 3, |  | ||||||
| 	fill_ratio = ratio_abundant, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| -- Spawn an occasional poplar elsewhere. |  | ||||||
| moretrees.poplar_biome_2 = { |  | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, |  | ||||||
| 	min_elevation = 0, |  | ||||||
| 	max_elevation = 50, |  | ||||||
| 	fill_ratio = ratio_very_rare, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| -- Subterranean lakes provide enough water for poplars to grow |  | ||||||
| moretrees.poplar_biome_3 = { |  | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, |  | ||||||
| 	min_elevation = -50, |  | ||||||
| 	max_elevation = 0, |  | ||||||
| 	spawn_by = {xcompat.materials.water_source}, |  | ||||||
| 	num_spawn_by = 3, |  | ||||||
| 	fill_ratio = ratio_abundant, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| moretrees.poplar_small_biome = { |  | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, |  | ||||||
| 	min_elevation = 0, |  | ||||||
| 	max_elevation = 50, |  | ||||||
| 	spawn_by = {xcompat.materials.water_source}, |  | ||||||
| 	num_spawn_by = 1, |  | ||||||
| 	fill_ratio = ratio_normal, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| moretrees.poplar_small_biome_2 = { |  | ||||||
| 	place_on = xcompat.materials.dirt_with_grass, |  | ||||||
| 	min_elevation = 0, |  | ||||||
| 	max_elevation = 50, |  | ||||||
| 	spawn_by = {xcompat.materials.water_source}, |  | ||||||
| 	num_spawn_by = 5, |  | ||||||
| 	fill_ratio = ratio_abundant, |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| moretrees.fir_biome = { | moretrees.fir_biome = { | ||||||
| 	place_on = coniferous_place_on, | 	surface = "default:dirt_with_grass", | ||||||
|  | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 359, | ||||||
| 	min_elevation = 25, | 	min_elevation = 25, | ||||||
| 	fill_ratio = ratio_normal, | 	temp_min = 0.9, | ||||||
|  | 	temp_max = 0.3, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 10, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.fir_biome_snow = { | moretrees.fir_biome_snow = { | ||||||
| 	place_on = {"snow:dirt_with_snow", "snow:snow"}, | 	surface = {"snow:dirt_with_snow", "snow:snow"}, | ||||||
| 	below_nodes = {xcompat.materials.dirt, xcompat.materials.dirt_with_grass, "snow:dirt_with_snow"}, | 	below_nodes = {"default:dirt", "default:dirt_with_grass", "snow:dirt_with_snow"}, | ||||||
| 	fill_ratio = ratio_normal, | 	avoid_nodes = moretrees.avoidnodes, | ||||||
|  | 	avoid_radius = 10, | ||||||
|  | 	seed_diff = 359, | ||||||
|  | 	rarity = 50, | ||||||
|  | 	max_count = 10, | ||||||
|  | 	check_air = false, | ||||||
|  | 	delete_above = true, | ||||||
|  | 	spawn_replace_node = true | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										339
									
								
								cocos_palm.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,339 +0,0 @@ | |||||||
| -- © 2016, Rogier <rogier777@gmail.com> |  | ||||||
| -- Translation support |  | ||||||
| local S = minetest.get_translator("moretrees") |  | ||||||
|  |  | ||||||
| -- Some constants |  | ||||||
|  |  | ||||||
| local coconut_drop_ichance = 8 |  | ||||||
|  |  | ||||||
| -- Make the cocos palm fruit trunk a real trunk (it is generated as a fruit) |  | ||||||
| local trunk = minetest.registered_nodes["moretrees:palm_trunk"] |  | ||||||
| local ftrunk = {} |  | ||||||
| local gftrunk = {} |  | ||||||
| for k,v in pairs(trunk) do |  | ||||||
| 	ftrunk[k] = v |  | ||||||
| 	gftrunk[k] = v |  | ||||||
| end |  | ||||||
| ftrunk.tiles = {} |  | ||||||
| gftrunk.tiles = {} |  | ||||||
| for k,v in pairs(trunk.tiles) do |  | ||||||
| 	ftrunk.tiles[k] = v |  | ||||||
| 	gftrunk.tiles[k] = v |  | ||||||
| end |  | ||||||
| ftrunk.drop = "moretrees:palm_trunk" |  | ||||||
| gftrunk.drop = "moretrees:palm_trunk" |  | ||||||
| ftrunk.after_destruct = function(pos, oldnode) |  | ||||||
| 	local coconuts = minetest.find_nodes_in_area( |  | ||||||
| 		{x=pos.x-1, y=pos.y, z=pos.z-1}, |  | ||||||
| 		{x=pos.x+1, y=pos.y, z=pos.z+1}, |  | ||||||
| 		{"group:moretrees_coconut"} |  | ||||||
| 	) |  | ||||||
| 	for _,coconutpos in pairs(coconuts) do |  | ||||||
| 		-- minetest.dig_node(coconutpos) does not cause nearby coconuts to be dropped :-( ... |  | ||||||
| 		--minetest.dig_node(coconutpos) |  | ||||||
| 		local items = minetest.get_node_drops(minetest.get_node(coconutpos).name) |  | ||||||
| 		minetest.swap_node(coconutpos, {name = "air"}) |  | ||||||
| 		for _, itemname in pairs(items) do |  | ||||||
| 			minetest.add_item(coconutpos, itemname) |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
| -- Make the different trunk types distinguishable (but barely) |  | ||||||
| ftrunk.tiles[1] = "moretrees_palm_trunk_top.png^[transformR90" |  | ||||||
| gftrunk.tiles[1] = "moretrees_palm_trunk_top.png^[transformR180" |  | ||||||
| gftrunk.description = gftrunk.description.." (gen)" |  | ||||||
| minetest.register_node("moretrees:palm_fruit_trunk", ftrunk) |  | ||||||
| minetest.register_node("moretrees:palm_fruit_trunk_gen", gftrunk) |  | ||||||
|  |  | ||||||
| local coconut_regrow_abm_spec = { |  | ||||||
| 	nodenames = { "moretrees:palm_fruit_trunk" }, |  | ||||||
| 	interval = moretrees.coconut_flower_interval, |  | ||||||
| 	chance = moretrees.coconut_flower_chance, |  | ||||||
| 	action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 		local coconuts = minetest.find_nodes_in_area( |  | ||||||
| 			{x=pos.x-1, y=pos.y, z=pos.z-1}, |  | ||||||
| 			{x=pos.x+1, y=pos.y, z=pos.z+1}, |  | ||||||
| 			"group:moretrees_coconut" |  | ||||||
| 		) |  | ||||||
| 		-- Expected growth interval increases exponentially with number of coconuts already hanging. |  | ||||||
| 		-- Also: if more coconuts are hanging, the chance of picking an empty spot decreases as well... |  | ||||||
| 		if math.random(2^#coconuts) <= 2 then |  | ||||||
| 			-- Grow in area of 3x3 round trunk |  | ||||||
| 			local dx=math.floor(math.random(3)-2) |  | ||||||
| 			local dz=math.floor(math.random(3)-2) |  | ||||||
| 			local coconutpos = {x=pos.x+dx, y=pos.y, z=pos.z+dz} |  | ||||||
| 			local coconutnode = minetest.get_node(coconutpos) |  | ||||||
| 			if coconutnode.name == "air" then |  | ||||||
| 				minetest.swap_node(coconutpos, {name="moretrees:coconut_0"}) |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| } |  | ||||||
| if moretrees.coconuts_regrow then |  | ||||||
| 	minetest.register_abm(coconut_regrow_abm_spec) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Spawn initial coconuts |  | ||||||
|  |  | ||||||
| -- Spawn initial coconuts |  | ||||||
| -- (Instead of coconuts, a generated-palm fruit trunk is generated with the tree. This |  | ||||||
| --  ABM converts the trunk to a regular fruit trunk, and spawns some coconuts) |  | ||||||
| minetest.register_abm({ |  | ||||||
| 	nodenames = { "moretrees:palm_fruit_trunk_gen" }, |  | ||||||
| 	interval = 6, |  | ||||||
| 	chance = 1, |  | ||||||
| 	min_y = -16, |  | ||||||
| 	max_y = 48, |  | ||||||
| 	label = "converts palm trunk to a regular fruit trunk, and spawns some coconuts", |  | ||||||
| 	action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 		minetest.swap_node(pos, {name="moretrees:palm_fruit_trunk"}) |  | ||||||
| 		local poslist = minetest.find_nodes_in_area( |  | ||||||
| 			{x=pos.x-1, y=pos.y, z=pos.z-1}, |  | ||||||
| 			{x=pos.x+1, y=pos.y, z=pos.z+1}, |  | ||||||
| 			"air" |  | ||||||
| 		) |  | ||||||
| 		local genlist = {} |  | ||||||
| 		for k,v in pairs(poslist) do |  | ||||||
| 			genlist[k] = {x = math.random(100), pos = v} |  | ||||||
| 		end |  | ||||||
| 		table.sort(genlist, function(a, b) return a.x < b.x; end) |  | ||||||
| 		local count = 0 |  | ||||||
| 		for _, gen in pairs(genlist) do |  | ||||||
| 			minetest.swap_node(gen.pos, {name = "moretrees:coconut_3"}) |  | ||||||
| 			count = count + 1 |  | ||||||
| 			if count == 4 then |  | ||||||
| 				break |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end, |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| -- Register coconuts, and make them regrow |  | ||||||
|  |  | ||||||
| local coconut_growfn = function(pos, elapsed) |  | ||||||
| 	local node = minetest.get_node(pos) |  | ||||||
| 	local delay = moretrees.coconut_grow_interval |  | ||||||
| 	if not node then |  | ||||||
| 		return |  | ||||||
| 	elseif not moretrees.coconuts_regrow then |  | ||||||
| 		-- Regrowing has been turned off. Make coconust grow instantly |  | ||||||
| 		minetest.swap_node(pos, {name="moretrees:coconut_3"}) |  | ||||||
| 		return |  | ||||||
| 	elseif node.name == "moretrees:coconut_3" then |  | ||||||
| 		-- Drop coconuts (i.e. remove them), so that new coconuts can grow. |  | ||||||
| 		-- Coconuts will drop as items with a small chance |  | ||||||
| 		if math.random(coconut_drop_ichance) == 1 then |  | ||||||
| 			if moretrees.coconut_item_drop_ichance > 0 |  | ||||||
| 				and math.random(moretrees.coconut_item_drop_ichance) == 1 then |  | ||||||
| 				local items = minetest.get_node_drops(minetest.get_node(pos).name) |  | ||||||
| 				for _, itemname in pairs(items) do |  | ||||||
| 					minetest.add_item(pos, itemname) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 			minetest.swap_node(pos, {name = "air"}) |  | ||||||
| 		end |  | ||||||
| 	else |  | ||||||
| 		-- Grow coconuts to the next stage |  | ||||||
| 		local offset = string.len("moretrees:coconut_x") |  | ||||||
| 		local n = string.sub(node.name, offset) |  | ||||||
| 		minetest.swap_node(pos, {name=string.sub(node.name, 1, offset-1)..n+1}) |  | ||||||
| 	end |  | ||||||
| 	-- Don't catch up when elapsed time is large. Regular visits are needed for growth... |  | ||||||
| 	local timer = minetest.get_node_timer(pos) |  | ||||||
| 	timer:start(delay + math.random(moretrees.coconut_grow_interval)) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| local coconut_starttimer = function(pos, elapsed) |  | ||||||
| 	local timer = minetest.get_node_timer(pos) |  | ||||||
| 	local base_interval = moretrees.coconut_grow_interval * 2 / 3 |  | ||||||
| 	timer:set(base_interval + math.random(base_interval), elapsed or 0) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| for _,suffix in ipairs({"_0", "_1", "_2", "_3", ""}) do |  | ||||||
| 	local name |  | ||||||
| 	if suffix == "_0" then |  | ||||||
| 		name = S("Coconut Flower") |  | ||||||
| 	else |  | ||||||
| 		name = S("Coconut") |  | ||||||
| 	end |  | ||||||
| 	local drop = "" |  | ||||||
| 	local coco_group = 1 |  | ||||||
| 	local tile = "moretrees_coconut"..suffix..".png" |  | ||||||
| 	local timerfn = coconut_growfn |  | ||||||
| 	local constructfn = coconut_starttimer |  | ||||||
| 	if suffix == "_3" then |  | ||||||
| 		drop = "moretrees:coconut" |  | ||||||
| 		tile = "moretrees_coconut.png" |  | ||||||
| 	elseif suffix == "" then |  | ||||||
| 		drop = nil |  | ||||||
| 		coco_group = nil |  | ||||||
| 		timerfn = nil |  | ||||||
| 		constructfn = nil |  | ||||||
| 	end |  | ||||||
| 	local coconutdef = { |  | ||||||
| 		description = name, |  | ||||||
| 		tiles = {tile}, |  | ||||||
| 		drawtype = "plantlike", |  | ||||||
| 		paramtype = "light", |  | ||||||
| 		sunlight_propagates = true, |  | ||||||
| 		walkable = false, |  | ||||||
| 		is_ground_content = false, |  | ||||||
| 		groups = { fleshy=3, dig_immediate=3, flammable=2, moretrees_coconut=coco_group }, |  | ||||||
| 		inventory_image = tile.."^[transformR180", |  | ||||||
| 		wield_image = tile.."^[transformR180", |  | ||||||
| 		sounds = xcompat.sounds.node_sound_default(), |  | ||||||
| 		drop = drop, |  | ||||||
| 		selection_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.3, -0.3, -0.3, 0.3, 0.3, 0.3} |  | ||||||
| 		}, |  | ||||||
| 		on_timer = timerfn, |  | ||||||
| 		on_construct = constructfn, |  | ||||||
|  |  | ||||||
| 	} |  | ||||||
| 	minetest.register_node("moretrees:coconut"..suffix, coconutdef) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- convert exisiting cocos palms. This is a bit tricky... |  | ||||||
| -- Try to make sure that this is indeed a generated tree, and not manually-placed trunks and/or coconuts |  | ||||||
| if moretrees.coconuts_convert_existing_palms then |  | ||||||
| 	local spec = { |  | ||||||
| 		name = "moretrees:convert_existing_cocos_palms_to_regrow_coconuts", |  | ||||||
| 		nodenames = "moretrees:coconut", |  | ||||||
| 		action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 			local trunks |  | ||||||
| 			local cvtrunks |  | ||||||
| 			local leaves |  | ||||||
| 			local coconuts |  | ||||||
| 			-- One regular trunk must be adjacent to  the coconut |  | ||||||
| 			trunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=pos.x-1, y=pos.y, z=pos.z-1}, |  | ||||||
| 				{x=pos.x+1, y=pos.y, z=pos.z+1}, |  | ||||||
| 				"moretrees:palm_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #trunks ~= 1 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			local tpos = trunks[1] |  | ||||||
| 			-- 1 or 2 other trunks must be one level below to the trunk being converted. |  | ||||||
| 			trunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y-1, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y-1, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #trunks < 1 or #trunks > 2 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- 1 or 2 other trunks must be two levels below to the trunk being converted. |  | ||||||
| 			trunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y-2, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y-2, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #trunks < 1 or #trunks > 2 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- 1 or 2 trunks must at the level of the trunk being converted. |  | ||||||
| 			cvtrunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #cvtrunks < 1 or #cvtrunks > 2 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- No trunks may be one level above the trunk being converted. |  | ||||||
| 			trunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y+1, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y+1, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #trunks ~= 0 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- Leaves must be one level above the trunk being converted. |  | ||||||
| 			leaves = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y+1, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y+1, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_leaves" |  | ||||||
| 			) |  | ||||||
| 			if #leaves == 0 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- Leaves must be two levels above the trunk being converted. |  | ||||||
| 			leaves = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y+2, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y+2, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_leaves" |  | ||||||
| 			) |  | ||||||
| 			if #leaves == 0 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- No cocos fruit trunk may already be adjacent to the coconut |  | ||||||
| 			trunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=pos.x-1, y=pos.y, z=pos.z-1}, |  | ||||||
| 				{x=pos.x+1, y=pos.y, z=pos.z+1}, |  | ||||||
| 				"moretrees:palm_fruit_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #trunks ~= 0 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- No cocos fruit trunk may be adjacent to or below the trunk being converted. |  | ||||||
| 			trunks = minetest.find_nodes_in_area( |  | ||||||
| 				{x=tpos.x-1, y=tpos.y-2, z=tpos.z-1}, |  | ||||||
| 				{x=tpos.x+1, y=tpos.y, z=tpos.z+1}, |  | ||||||
| 				"moretrees:palm_fruit_trunk" |  | ||||||
| 			) |  | ||||||
| 			if #trunks ~= 0 then |  | ||||||
| 				return |  | ||||||
| 			end |  | ||||||
| 			-- Convert trunk and all coconuts nearby. Maybe convert 2 trunks, just in case... |  | ||||||
| 			for _, tpos_1 in pairs(cvtrunks) do |  | ||||||
| 				minetest.swap_node(tpos_1, {name = "moretrees:palm_fruit_trunk"}) |  | ||||||
| 				coconuts = minetest.find_nodes_in_area( |  | ||||||
| 					{x=tpos_1.x-1, y=tpos_1.y, z=tpos_1.z-1}, |  | ||||||
| 					{x=tpos_1.x+1, y=tpos_1.y, z=tpos_1.z+1}, |  | ||||||
| 					"moretrees:coconut" |  | ||||||
| 				) |  | ||||||
| 				for _, coconutpos in pairs(coconuts) do |  | ||||||
| 					minetest.swap_node(coconutpos, {name = "moretrees:coconut_3"}) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end, |  | ||||||
| 	} |  | ||||||
| 	if minetest.register_lbm then |  | ||||||
| 		minetest.register_lbm(spec) |  | ||||||
| 	else |  | ||||||
| 		spec.interval = 3691 |  | ||||||
| 		spec.chance = 10 |  | ||||||
| 		minetest.register_abm(spec) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- If regrowing was previously disabled, but is enabled now, make sure timers are started for existing coconuts |  | ||||||
| if moretrees.coconuts_regrow then |  | ||||||
| 	local spec = { |  | ||||||
| 		name = "moretrees:restart_coconut_regrow_timer", |  | ||||||
| 		nodenames = "group:moretrees_coconut", |  | ||||||
| 		action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 			local timer = minetest.get_node_timer(pos) |  | ||||||
| 			if not timer:is_started() then |  | ||||||
| 				coconut_starttimer(pos) |  | ||||||
| 			else |  | ||||||
| 				local timeout = timer:get_timeout() |  | ||||||
| 				local elapsed = timer:get_elapsed() |  | ||||||
| 				if timeout - elapsed > moretrees.coconut_grow_interval * 4/3 then |  | ||||||
| 					coconut_starttimer(pos, math.random(moretrees.coconut_grow_interval * 4/3)) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end, |  | ||||||
| 	} |  | ||||||
| 	if minetest.register_lbm then |  | ||||||
| 		minetest.register_lbm(spec) |  | ||||||
| 	else |  | ||||||
| 		spec.interval = 3659 |  | ||||||
| 		spec.chance = 10 |  | ||||||
| 		minetest.register_abm(spec) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
							
								
								
									
										170
									
								
								crafts.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,9 +1,16 @@ | |||||||
| local S = minetest.get_translator("moretrees") | local S = moretrees.intllib | ||||||
|  |  | ||||||
| for i in ipairs(moretrees.treelist) do | for i in ipairs(moretrees.treelist) do | ||||||
| 	local treename = moretrees.treelist[i][1] | 	local treename = moretrees.treelist[i][1] | ||||||
|  |  | ||||||
| 	if moretrees.enable_planks then | 	minetest.register_craft({ | ||||||
|  | 		output = "moretrees:"..treename.."_trunk 2", | ||||||
|  | 		recipe = { | ||||||
|  | 			{"moretrees:"..treename.."_trunk_sideways"}, | ||||||
|  | 			{"moretrees:"..treename.."_trunk_sideways"} | ||||||
|  | 		} | ||||||
|  | 	}) | ||||||
|  |  | ||||||
| 	minetest.register_craft({ | 	minetest.register_craft({ | ||||||
| 		type = "shapeless", | 		type = "shapeless", | ||||||
| 		output = "moretrees:"..treename.."_planks 4", | 		output = "moretrees:"..treename.."_planks 4", | ||||||
| @@ -11,7 +18,14 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 			"moretrees:"..treename.."_trunk" | 			"moretrees:"..treename.."_trunk" | ||||||
| 		} | 		} | ||||||
| 	}) | 	}) | ||||||
| 	end |  | ||||||
|  | 	minetest.register_craft({ | ||||||
|  | 		type = "shapeless", | ||||||
|  | 		output = "moretrees:"..treename.."_planks 4", | ||||||
|  | 		recipe = { | ||||||
|  | 			"moretrees:"..treename.."_trunk_sideways" | ||||||
|  | 		} | ||||||
|  | 	}) | ||||||
|  |  | ||||||
| 	minetest.register_craft({ | 	minetest.register_craft({ | ||||||
| 		type = "fuel", | 		type = "fuel", | ||||||
| @@ -40,8 +54,7 @@ minetest.register_craftitem("moretrees:coconut_milk", { | |||||||
| 	description = S("Coconut Milk"), | 	description = S("Coconut Milk"), | ||||||
| 	inventory_image = "moretrees_coconut_milk_inv.png", | 	inventory_image = "moretrees_coconut_milk_inv.png", | ||||||
| 	wield_image = "moretrees_coconut_milk.png", | 	wield_image = "moretrees_coconut_milk.png", | ||||||
| 	on_use = minetest.item_eat(2, "vessels:drinking_glass"), | 	on_use = minetest.item_eat(2), | ||||||
| 	groups = {vessel = 1}, |  | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:raw_coconut", { | minetest.register_craftitem("moretrees:raw_coconut", { | ||||||
| @@ -50,35 +63,6 @@ minetest.register_craftitem("moretrees:raw_coconut", { | |||||||
| 	on_use = minetest.item_eat(4), | 	on_use = minetest.item_eat(4), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:date", { |  | ||||||
| 	description = S("Date"), |  | ||||||
| 	inventory_image = "moretrees_date.png", |  | ||||||
| 	on_use = minetest.item_eat(1), |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:date_nut_snack", { |  | ||||||
| 	description = S("Date & nut snack"), |  | ||||||
| 	inventory_image = "moretrees_date_nut_snack.png", |  | ||||||
| 	on_use = minetest.item_eat(4), |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:date_nut_batter", { |  | ||||||
| 	description = S("Date-nut cake batter"), |  | ||||||
| 	inventory_image = "moretrees_date_nut_batter.png", |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:date_nut_cake", { |  | ||||||
| 	description = S("Date-nut cake"), |  | ||||||
| 	inventory_image = "moretrees_date_nut_cake.png", |  | ||||||
| 	on_use = minetest.item_eat(32), |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:date_nut_bar", { |  | ||||||
| 	description = S("Date-nut energy bar"), |  | ||||||
| 	inventory_image = "moretrees_date_nut_bar.png", |  | ||||||
| 	on_use = minetest.item_eat(4), |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:acorn_muffin_batter", { | minetest.register_craftitem("moretrees:acorn_muffin_batter", { | ||||||
| 	description = S("Acorn Muffin batter"), | 	description = S("Acorn Muffin batter"), | ||||||
| 	inventory_image = "moretrees_acorn_muffin_batter.png", | 	inventory_image = "moretrees_acorn_muffin_batter.png", | ||||||
| @@ -96,9 +80,9 @@ minetest.register_craftitem("moretrees:spruce_nuts", { | |||||||
| 	on_use = minetest.item_eat(1), | 	on_use = minetest.item_eat(1), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craftitem("moretrees:cedar_nuts", { | minetest.register_craftitem("moretrees:pine_nuts", { | ||||||
| 	description = S("Roasted Cedar Cone Nuts"), | 	description = S("Roasted Pine Cone Nuts"), | ||||||
| 	inventory_image = "moretrees_cedar_nuts.png", | 	inventory_image = "moretrees_pine_nuts.png", | ||||||
| 	on_use = minetest.item_eat(1), | 	on_use = minetest.item_eat(1), | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -120,117 +104,11 @@ for i in ipairs(moretrees.cutting_tools) do | |||||||
| 		}, | 		}, | ||||||
| 		replacements = { | 		replacements = { | ||||||
| 			{ "moretrees:coconut", "moretrees:raw_coconut" }, | 			{ "moretrees:coconut", "moretrees:raw_coconut" }, | ||||||
|  | 			{ tool, tool } | ||||||
| 		} | 		} | ||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| -- give tool back with wear preserved |  | ||||||
| minetest.register_on_craft(function(itemstack, player, old_craft_grid, craft_inv) |  | ||||||
| 	if (itemstack:get_name() == "moretrees:coconut_milk") then |  | ||||||
| 		for i, j in pairs(old_craft_grid) do |  | ||||||
| 			-- find tool used to do the craft |  | ||||||
| 			local ocg_name = j:get_name() |  | ||||||
| 			if ((ocg_name ~= "") and (ocg_name ~= "moretrees:coconut") and (ocg_name ~= "vessels:drinking_glass")) then |  | ||||||
| 				-- abort if using cutting board |  | ||||||
| 				if minetest.get_item_group(ocg_name, "food_cutting_board") == 1 then |  | ||||||
| 					return |  | ||||||
| 				end |  | ||||||
| 				-- create a new tool and set wear |  | ||||||
| 				local t = ItemStack(ocg_name) |  | ||||||
| 				local w = j:get_wear() |  | ||||||
| 				-- works if tool used is an axe |  | ||||||
| 				local uses = j:get_tool_capabilities().groupcaps.choppy.uses or 0 |  | ||||||
| 				if (w == 0 and uses ~= 0) then |  | ||||||
| 					-- tool has never been used |  | ||||||
| 					-- use tool once |  | ||||||
| 					t:set_wear(65535/(9*(uses - 1))) |  | ||||||
| 				else |  | ||||||
| 					-- set wear back |  | ||||||
| 					t:set_wear(w) |  | ||||||
| 					-- use tool once |  | ||||||
| 					if (uses ~= 0) then |  | ||||||
| 						t:add_wear(65535/(9*(uses - 1))) |  | ||||||
| 					end |  | ||||||
| 				end |  | ||||||
| 				-- add to craft inventory |  | ||||||
| 				craft_inv:add_item("craft", t) |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| end) |  | ||||||
|  |  | ||||||
| -- coconut milk using food_cutting_board from farming redo |  | ||||||
| if minetest.registered_items["farming:cutting_board"] then |  | ||||||
| 	minetest.register_craft({ |  | ||||||
| 		type = "shapeless", |  | ||||||
| 		output = "moretrees:coconut_milk", |  | ||||||
| 		recipe = { |  | ||||||
| 			"moretrees:coconut", |  | ||||||
| 			"vessels:drinking_glass", |  | ||||||
| 			"group:food_cutting_board", |  | ||||||
| 		}, |  | ||||||
| 		replacements = { |  | ||||||
| 			{ "moretrees:coconut", "moretrees:raw_coconut" }, |  | ||||||
| 			{ "group:food_cutting_board", "farming:cutting_board" }, |  | ||||||
| 		} |  | ||||||
| 	}) |  | ||||||
| end |  | ||||||
|  |  | ||||||
|  |  | ||||||
| minetest.register_craft({ |  | ||||||
| 	type = "shapeless", |  | ||||||
| 	output = "moretrees:date_nut_snack", |  | ||||||
| 	recipe = { |  | ||||||
| 		"moretrees:date", |  | ||||||
| 		"moretrees:date", |  | ||||||
| 		"moretrees:date", |  | ||||||
| 		"moretrees:spruce_nuts", |  | ||||||
| 		"moretrees:cedar_nuts", |  | ||||||
| 		"moretrees:fir_nuts", |  | ||||||
| 	} |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| -- The date-nut cake is an exceptional food item due to its highly |  | ||||||
| -- concentrated nature (32 food units). Because of that, it requires |  | ||||||
| -- many different ingredients, and, starting from the base ingredients |  | ||||||
| -- found or harvested in nature, it requires many steps to prepare. |  | ||||||
| local flour |  | ||||||
| if minetest.registered_nodes["farming:flour"] then |  | ||||||
| 	flour = "farming:flour" |  | ||||||
| else |  | ||||||
| 	flour = "moretrees:acorn_muffin_batter" |  | ||||||
| end |  | ||||||
| minetest.register_craft({ |  | ||||||
| 	type = "shapeless", |  | ||||||
| 	output = "moretrees:date_nut_batter", |  | ||||||
| 	recipe = { |  | ||||||
| 		"moretrees:date_nut_snack", |  | ||||||
| 		"moretrees:date_nut_snack", |  | ||||||
| 		"moretrees:date_nut_snack", |  | ||||||
| 		"moretrees:coconut_milk", |  | ||||||
| 		"moretrees:date_nut_snack", |  | ||||||
| 		"moretrees:raw_coconut", |  | ||||||
| 		"moretrees:coconut_milk", |  | ||||||
| 		flour, |  | ||||||
| 		"moretrees:raw_coconut", |  | ||||||
| 	}, |  | ||||||
| 	replacements = { |  | ||||||
| 		{ "moretrees:coconut_milk", "vessels:drinking_glass 2" } |  | ||||||
| 	} |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craft({ |  | ||||||
| 	type = "cooking", |  | ||||||
| 	output = "moretrees:date_nut_cake", |  | ||||||
| 	recipe = "moretrees:date_nut_batter", |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craft({ |  | ||||||
| 	type = "shapeless", |  | ||||||
| 	output = "moretrees:date_nut_bar 8", |  | ||||||
| 	recipe = {"moretrees:date_nut_cake"}, |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	type = "shapeless", | 	type = "shapeless", | ||||||
| 	output = "moretrees:acorn_muffin_batter", | 	output = "moretrees:acorn_muffin_batter", | ||||||
| @@ -260,8 +138,8 @@ minetest.register_craft({ | |||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
| 	type = "cooking", | 	type = "cooking", | ||||||
| 	output = "moretrees:cedar_nuts 4", | 	output = "moretrees:pine_nuts 4", | ||||||
| 	recipe = "moretrees:cedar_cone", | 	recipe = "moretrees:pine_cone", | ||||||
| }) | }) | ||||||
|  |  | ||||||
| minetest.register_craft({ | minetest.register_craft({ | ||||||
|   | |||||||
							
								
								
									
										770
									
								
								date_palm.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,770 +0,0 @@ | |||||||
| -- Date palms. |  | ||||||
| -- |  | ||||||
| -- Date palms grow in hot and dry desert, but they require water. This makes them |  | ||||||
| -- a bit harder to find. If found in the middle of the desert, their presence |  | ||||||
| -- indicates a water source below the surface. |  | ||||||
| -- |  | ||||||
| -- As an additional feature (which can be disabled), dates automatically regrow after |  | ||||||
| -- harvesting (provided a male tree is sufficiently nearby). |  | ||||||
| -- If regrowing is enabled, then ripe dates will not hang forever. Most will disappear |  | ||||||
| -- (e.g. eaten by birds, ...), and a small fraction will drop as items. |  | ||||||
|  |  | ||||||
| -- © 2016, Rogier <rogier777@gmail.com> |  | ||||||
|  |  | ||||||
| local S = minetest.get_translator("moretrees") |  | ||||||
|  |  | ||||||
| -- Some constants |  | ||||||
|  |  | ||||||
| local dates_drop_ichance = 4 |  | ||||||
| local stems_drop_ichance = 4 |  | ||||||
| local flowers_wither_ichance = 3 |  | ||||||
|  |  | ||||||
| -- implementation |  | ||||||
|  |  | ||||||
| local dates_regrow_prob |  | ||||||
| if moretrees.dates_regrow_unpollinated_percent <= 0 then |  | ||||||
| 	dates_regrow_prob = 0 |  | ||||||
| elseif moretrees.dates_regrow_unpollinated_percent >= 100 then |  | ||||||
| 	dates_regrow_prob = 1 |  | ||||||
| else |  | ||||||
| 	dates_regrow_prob = 1 - math.pow(moretrees.dates_regrow_unpollinated_percent/100, 1/flowers_wither_ichance) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Make the date palm fruit trunk a real trunk (it is generated as a fruit) |  | ||||||
| local trunk = minetest.registered_nodes["moretrees:date_palm_trunk"] |  | ||||||
| local ftrunk = {} |  | ||||||
| local fftrunk = {} |  | ||||||
| local mftrunk = {} |  | ||||||
| for k,v in pairs(trunk) do |  | ||||||
| 	ftrunk[k] = v |  | ||||||
| end |  | ||||||
| ftrunk.tiles = {} |  | ||||||
| for k,v in pairs(trunk.tiles) do |  | ||||||
| 	ftrunk.tiles[k] = v |  | ||||||
| end |  | ||||||
| ftrunk.drop = "moretrees:date_palm_trunk" |  | ||||||
| ftrunk.after_destruct = function(pos, oldnode) |  | ||||||
| 	local dates = minetest.find_nodes_in_area( |  | ||||||
| 		{x=pos.x-2, y=pos.y, z=pos.z-2}, |  | ||||||
| 		{x=pos.x+2, y=pos.y, z=pos.z+2}, |  | ||||||
| 		{"group:moretrees_dates"} |  | ||||||
| 	) |  | ||||||
| 	for _,datespos in pairs(dates) do |  | ||||||
| 		-- minetest.dig_node(datespos) does not cause nearby dates to be dropped :-( ... |  | ||||||
| 		local items = minetest.get_node_drops(minetest.get_node(datespos).name) |  | ||||||
| 		minetest.swap_node(datespos, {name = "air"}) |  | ||||||
| 		for _, itemname in pairs(items) do |  | ||||||
| 			minetest.add_item(datespos, itemname) |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
| for k,v in pairs(ftrunk) do |  | ||||||
| 	mftrunk[k] = v |  | ||||||
| 	fftrunk[k] = v |  | ||||||
| end |  | ||||||
| fftrunk.tiles = {} |  | ||||||
| mftrunk.tiles = {} |  | ||||||
| for k,v in pairs(trunk.tiles) do |  | ||||||
| 	fftrunk.tiles[k] = v |  | ||||||
| 	mftrunk.tiles[k] = v |  | ||||||
| end |  | ||||||
| -- Make the different types of trunk distinguishable (but not too easily) |  | ||||||
| ftrunk.tiles[1] = "moretrees_date_palm_trunk_top.png^[transformR180" |  | ||||||
| ftrunk.description = ftrunk.description.." (gen)" |  | ||||||
| fftrunk.tiles[1] = "moretrees_date_palm_trunk_top.png^[transformR90" |  | ||||||
| mftrunk.tiles[1] = "moretrees_date_palm_trunk_top.png^[transformR-90" |  | ||||||
| minetest.register_node("moretrees:date_palm_fruit_trunk", ftrunk) |  | ||||||
| minetest.register_node("moretrees:date_palm_ffruit_trunk", fftrunk) |  | ||||||
| minetest.register_node("moretrees:date_palm_mfruit_trunk", mftrunk) |  | ||||||
|  |  | ||||||
| -- ABM to grow new date blossoms |  | ||||||
| local date_regrow_abm_spec = { |  | ||||||
| 	nodenames = { "moretrees:date_palm_ffruit_trunk", "moretrees:date_palm_mfruit_trunk" }, |  | ||||||
| 	interval = moretrees.dates_flower_interval, |  | ||||||
| 	chance = moretrees.dates_flower_chance, |  | ||||||
| 	action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 		local dates = minetest.find_nodes_in_area( |  | ||||||
| 			{x=pos.x-2, y=pos.y, z=pos.z-2}, {x=pos.x+2, y=pos.y, z=pos.z+2}, |  | ||||||
| 			"group:moretrees_dates" |  | ||||||
| 		) |  | ||||||
|  |  | ||||||
| 		-- New blossom interval increases exponentially with number of dates already hanging |  | ||||||
| 		-- In addition: if more dates are hanging, the chance of picking an empty spot decreases as well... |  | ||||||
| 		if math.random(2^#dates) <= 2 then |  | ||||||
| 			-- Grow in area of 5x5 round trunk; higher probability in 3x3 area close to trunk |  | ||||||
| 			local dx=math.floor((math.random(50)-18)/16) |  | ||||||
| 			local dz=math.floor((math.random(50)-18)/16) |  | ||||||
| 			local datepos = {x=pos.x+dx, y=pos.y, z=pos.z+dz} |  | ||||||
| 			local datenode = minetest.get_node(datepos) |  | ||||||
| 			if datenode.name == "air" then |  | ||||||
| 				if node.name == "moretrees:date_palm_ffruit_trunk" then |  | ||||||
| 					minetest.swap_node(datepos, {name="moretrees:dates_f0"}) |  | ||||||
| 				else |  | ||||||
| 					minetest.swap_node(datepos, {name="moretrees:dates_m0"}) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| } |  | ||||||
| if moretrees.dates_regrow_pollinated or moretrees.dates_regrow_unpollinated_percent > 0 then |  | ||||||
| 	minetest.register_abm(date_regrow_abm_spec) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Choose male or female palm, and spawn initial dates |  | ||||||
| -- (Instead of dates, a dates fruit trunk is generated with the tree. This |  | ||||||
| --  ABM converts the trunk to a female or male fruit trunk, and spawns some |  | ||||||
| --  hanging dates) |  | ||||||
| minetest.register_abm({ |  | ||||||
| 	nodenames = { "moretrees:date_palm_fruit_trunk" }, |  | ||||||
| 	interval = 1, |  | ||||||
| 	chance = 1, |  | ||||||
| 	action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 		local type |  | ||||||
| 		if math.random(100) <= moretrees.dates_female_percent then |  | ||||||
| 			type = "f" |  | ||||||
| 			minetest.swap_node(pos, {name="moretrees:date_palm_ffruit_trunk"}) |  | ||||||
| 		else |  | ||||||
| 			type = "m" |  | ||||||
| 			minetest.swap_node(pos, {name="moretrees:date_palm_mfruit_trunk"}) |  | ||||||
| 		end |  | ||||||
| 		local dates1 = minetest.find_nodes_in_area( |  | ||||||
| 			{x=pos.x-1, y=pos.y, z=pos.z-1}, |  | ||||||
| 			{x=pos.x+1, y=pos.y, z=pos.z+1}, |  | ||||||
| 			"air" |  | ||||||
| 		) |  | ||||||
| 		for _,genpos in pairs(dates1) do |  | ||||||
| 			if math.random(100) <= 20 then |  | ||||||
| 				if type == "m" then |  | ||||||
| 					minetest.swap_node(genpos, {name = "moretrees:dates_n"}) |  | ||||||
| 				else |  | ||||||
| 					minetest.swap_node(genpos, {name = "moretrees:dates_f4"}) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 		local dates2 = minetest.find_nodes_in_area( |  | ||||||
| 			{x=pos.x-2, y=pos.y, z=pos.z-2}, |  | ||||||
| 			{x=pos.x+2, y=pos.y, z=pos.z+2}, |  | ||||||
| 			"air" |  | ||||||
| 		) |  | ||||||
| 		for _,genpos in pairs(dates2) do |  | ||||||
| 			if math.random(100) <= 5 then |  | ||||||
| 				if type == "m" then |  | ||||||
| 					minetest.swap_node(genpos, {name = "moretrees:dates_n"}) |  | ||||||
| 				else |  | ||||||
| 					minetest.swap_node(genpos, {name = "moretrees:dates_f4"}) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end, |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| -- Dates growing functions. |  | ||||||
|  |  | ||||||
| -- This is a bit complex, as the purpose is to find male flowers at horizontal distances of over |  | ||||||
| -- 100 nodes. As searching such a large area is time consuming, this is optimized in four ways: |  | ||||||
| -- - The search result (the locations of male trees) is cached, so that it can be used again |  | ||||||
| -- - Only 1/9th of the desired area is searched at a time. A new search is only performed if no male |  | ||||||
| --   flowers are found in the previously searched parts. |  | ||||||
| -- - Search results are shared with other female palms nearby. |  | ||||||
| -- - If previous searches for male palms have consumed too much CPU time, the search is skipped |  | ||||||
| --   (This means no male palms will be found, and the pollination of the flowers affected will be |  | ||||||
| --   delayed. If this happens repeatedly, eventually, the female flowers will wither...) |  | ||||||
| -- A caching method was selected that is suited for the case where most date trees are long-lived, |  | ||||||
| -- and where the number of trees nearby is limited: |  | ||||||
| -- - Locations of male palms are stored as metadata for every female palm. This means that a player |  | ||||||
| --   visiting a remote area with some date palms will not cause extensive searches for male palms as |  | ||||||
| --   long overdue blossoming ABMs are triggered for every date palm. |  | ||||||
| -- - Even when male palms *are* cut down, a cache refill will only be performed if the cached results do not |  | ||||||
| --   contain a male palm with blossoms. |  | ||||||
| -- The method will probably perform suboptimally: |  | ||||||
| -- - If female palms are frequently chopped down and replanted. |  | ||||||
| --   Freshly grown palms will need to search for male palms again |  | ||||||
| --   (this is mitigated by the long blossoming interval, which increases the chance that search |  | ||||||
| --    results have already been shared) |  | ||||||
| -- - If an area contains a large number of male and female palms. |  | ||||||
| --   In this area, every female palm will have an almost identical list of male palm locations |  | ||||||
| --   as metadata. |  | ||||||
| -- - If all male palms within range of a number of female palms have been chopped down (with possibly |  | ||||||
| --   new ones planted). Although an attempt was made to share search results in this case as well, |  | ||||||
| --   a number of similar searches will unavoidably be performed by the different female palms. |  | ||||||
| -- - If no male palms are in range of a female palm. In that case, there will be frequent searches |  | ||||||
| --   for newly-grown male palms. |  | ||||||
|  |  | ||||||
| -- Search statistics - used to limit the search load. |  | ||||||
| local sect_search_stats = {}		-- Search statistics - server-wide |  | ||||||
| local function reset_sect_search_stats() |  | ||||||
| 	sect_search_stats.count = 0		-- # of searches |  | ||||||
| 	sect_search_stats.skip = 0		-- # of times skipped |  | ||||||
| 	sect_search_stats.sum = 0		-- total time spent |  | ||||||
| 	sect_search_stats.min = 999999999	-- min time spent |  | ||||||
| 	sect_search_stats.max = 0		-- max time spent |  | ||||||
| end |  | ||||||
| reset_sect_search_stats() |  | ||||||
| sect_search_stats.last_us = 0			-- last time a search was done (microseconds, max: 2^32) |  | ||||||
| sect_search_stats.last_s = 0			-- last time a search was done (system time in seconds) |  | ||||||
|  |  | ||||||
| -- Find male trunks in one section (=1/9 th) of the searchable area. |  | ||||||
| -- sect is -4 to 4, where 0 is the center section |  | ||||||
| local function find_fruit_trunks_near(ftpos, sect) |  | ||||||
| 	local r = moretrees.dates_pollination_distance + 2 * math.sqrt(2) |  | ||||||
| 	local sect_hr = math.floor(r / 3 + 0.9999) |  | ||||||
| 	local sect_vr = math.floor(r / 2 + 0.9999) |  | ||||||
| 	local t0us = minetest.get_us_time() |  | ||||||
| 	local t0s = os.time() |  | ||||||
|  |  | ||||||
| 	-- Compute elapsed time since last search. |  | ||||||
| 	-- Unfortunately, the time value wraps after about 71 minutes (2^32 microseconds), |  | ||||||
| 	-- so it must be corrected to obtain the actual elapsed time. |  | ||||||
| 	if t0us < sect_search_stats.last_us then |  | ||||||
| 		-- Correct a simple wraparound. |  | ||||||
| 		-- This is not sufficient, as the time value may have wrapped more than once... |  | ||||||
| 		sect_search_stats.last_us = sect_search_stats.last_us - 2^32 |  | ||||||
| 	end |  | ||||||
| 	if t0s - sect_search_stats.last_s > 2^32/1000000 then |  | ||||||
| 		-- One additional correction is enough for our purposes. |  | ||||||
| 		-- For exact results, more corrections may be needed though... |  | ||||||
| 		-- (and even not applying this correction at all would still only yield |  | ||||||
| 		--  a minimal risk of a non-serious miscalculation...) |  | ||||||
| 		sect_search_stats.last_us = sect_search_stats.last_us - 2^32 |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- Skip the search if it is consuming too much CPU time |  | ||||||
| 	if sect_search_stats.count > 0 and moretrees.dates_blossom_search_iload > 0 |  | ||||||
| 			and sect_search_stats.sum / sect_search_stats.count > moretrees.dates_blossom_search_time_treshold |  | ||||||
| 			and t0us - sect_search_stats.last_us < moretrees.dates_blossom_search_iload |  | ||||||
| 			* (sect_search_stats.sum / sect_search_stats.count) then |  | ||||||
| 		sect_search_stats.skip = sect_search_stats.skip + 1 |  | ||||||
| 		return nil |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	local basevec = { x = ftpos.x + 2 * sect.x * sect_hr, |  | ||||||
| 			  y = ftpos.y, |  | ||||||
| 			  z = ftpos.z + 2 * sect.z * sect_hr} |  | ||||||
| 	-- find_nodes_in_area is limited to 82^3, make sure to not overrun it |  | ||||||
| 	local sizevec = { x = sect_hr, y = sect_vr, z = sect_hr } |  | ||||||
| 	if sect_hr * sect_hr * sect_vr > 41^3 then |  | ||||||
| 		sizevec = vector.apply(sizevec, function(a) return math.min(a, 41) end) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	local all_palms = minetest.find_nodes_in_area( |  | ||||||
| 				vector.subtract(basevec, sizevec), |  | ||||||
| 				vector.add(basevec, sizevec), |  | ||||||
| 				{"moretrees:date_palm_mfruit_trunk", "moretrees:date_palm_ffruit_trunk"}) |  | ||||||
|  |  | ||||||
| 	-- Collect different palms in separate lists. |  | ||||||
| 	local female_palms = {} |  | ||||||
| 	local male_palms = {} |  | ||||||
| 	local all_male_palms = {} |  | ||||||
| 	for _, pos in pairs(all_palms) do |  | ||||||
| 		if pos.x ~= ftpos.x or pos.y ~= ftpos.y or pos.z ~= ftpos.z then |  | ||||||
| 			local node = minetest.get_node(pos) |  | ||||||
| 			if node and node.name == "moretrees:date_palm_ffruit_trunk" then |  | ||||||
| 				table.insert(female_palms,pos) |  | ||||||
| 			elseif node then |  | ||||||
| 				table.insert(all_male_palms,pos) |  | ||||||
| 				-- In sector 0, all palms are of interest. |  | ||||||
| 				-- In other sectors, forget about palms that are too far away. |  | ||||||
| 				if sect == 0 then |  | ||||||
| 					table.insert(male_palms,pos) |  | ||||||
| 				else |  | ||||||
| 					local ssq = 0 |  | ||||||
| 					for _, c in pairs({"x", "z"}) do |  | ||||||
| 						local dc = pos[c] - ftpos[c] |  | ||||||
| 						ssq = ssq + dc * dc |  | ||||||
| 					end |  | ||||||
| 					if math.sqrt(ssq) <= r then |  | ||||||
| 						table.insert(male_palms,pos) |  | ||||||
| 					end |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- Update search statistics |  | ||||||
| 	local t1us = minetest.get_us_time() |  | ||||||
| 	if t1us < t0us then |  | ||||||
| 		-- Wraparound. Assume the search lasted less than 2^32 microseconds (~71 min) |  | ||||||
| 		-- (so no need to apply another correction) |  | ||||||
| 		t0us = t0us - 2^32 |  | ||||||
| 	end |  | ||||||
| 	sect_search_stats.last_us = t0us |  | ||||||
| 	sect_search_stats.last_s = t0s |  | ||||||
| 	sect_search_stats.count = sect_search_stats.count + 1 |  | ||||||
| 	sect_search_stats.sum = sect_search_stats.sum + t1us-t0us |  | ||||||
| 	if t1us - t0us < sect_search_stats.min then |  | ||||||
| 		sect_search_stats.min = t1us - t0us |  | ||||||
| 	end |  | ||||||
| 	if t1us - t0us > sect_search_stats.max then |  | ||||||
| 		sect_search_stats.max = t1us - t0us |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	return male_palms, female_palms, all_male_palms |  | ||||||
| end |  | ||||||
|  |  | ||||||
| local function dates_print_search_stats(log) |  | ||||||
| 	local stats |  | ||||||
| 	if sect_search_stats.count > 0 then |  | ||||||
| 		stats = string.format("Male date tree searching stats: searches: %d/%d:  average: %d µs  (%d..%d)", |  | ||||||
| 			sect_search_stats.count, sect_search_stats.count + sect_search_stats.skip, |  | ||||||
| 			sect_search_stats.sum/sect_search_stats.count, sect_search_stats.min, sect_search_stats.max) |  | ||||||
| 	else |  | ||||||
| 		stats = string.format("Male date tree searching stats: searches: 0/0:  average: (no searches yet)") |  | ||||||
| 	end |  | ||||||
| 	if log then |  | ||||||
| 		minetest.log("action", "[moretrees] " .. stats) |  | ||||||
| 	end |  | ||||||
| 	return true, stats |  | ||||||
| end |  | ||||||
|  |  | ||||||
| minetest.register_chatcommand("dates_stats", { |  | ||||||
| 	description = "Print male date palm search statistics", |  | ||||||
| 	params = "|chat|log|reset", |  | ||||||
| 	privs = { server = true }, |  | ||||||
| 	func = function(name, param) |  | ||||||
| 		param = string.lower(param:gsub("%s+", "")) |  | ||||||
| 		if param == "" or param == "chat" then |  | ||||||
| 			return dates_print_search_stats(false) |  | ||||||
| 		elseif param == "log" then |  | ||||||
| 			return dates_print_search_stats(true) |  | ||||||
| 		elseif param == "reset" then |  | ||||||
| 			reset_sect_search_stats() |  | ||||||
| 			return true |  | ||||||
| 		else |  | ||||||
| 			return false, "Invalid subcommand; expected: '' or 'chat' or 'log' or 'reset'" |  | ||||||
| 		end |  | ||||||
| 	end, |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| -- Find the female trunk near the female flowers to be pollinated |  | ||||||
| local function find_female_trunk(fbpos) |  | ||||||
| 	local trunks = minetest.find_nodes_in_area({x=fbpos.x-2, y=fbpos.y, z=fbpos.z-2}, |  | ||||||
| 						{x=fbpos.x+2, y=fbpos.y, z=fbpos.z+2}, |  | ||||||
| 						"moretrees:date_palm_ffruit_trunk") |  | ||||||
| 	local ftpos |  | ||||||
| 	local d = 99 |  | ||||||
| 	for x, pos in pairs(trunks) do |  | ||||||
| 		local ssq = 0 |  | ||||||
| 		for _, c in pairs({"x", "z"}) do |  | ||||||
| 			local dc = pos[c] - fbpos[c] |  | ||||||
| 			ssq = ssq + dc * dc |  | ||||||
| 		end |  | ||||||
| 		if math.sqrt(ssq) < d then |  | ||||||
| 			ftpos = pos |  | ||||||
| 			d = math.sqrt(ssq) |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| 	return ftpos |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Find male blossom near a male trunk, |  | ||||||
| -- the male blossom must be in range of a specific female blossom as well |  | ||||||
| local function find_male_blossom_near_trunk(fbpos, mtpos) |  | ||||||
| 	local r = moretrees.dates_pollination_distance |  | ||||||
| 	local blossoms = minetest.find_nodes_in_area({x=mtpos.x-2, y=mtpos.y, z=mtpos.z-2}, |  | ||||||
| 						{x=mtpos.x+2, y=mtpos.y, z=mtpos.z+2}, |  | ||||||
| 						"moretrees:dates_m0") |  | ||||||
| 	for x, mbpos in pairs(blossoms) do |  | ||||||
| 		local ssq = 0 |  | ||||||
| 		for _, c in pairs({"x", "z"}) do |  | ||||||
| 			local dc = mbpos[c] - fbpos[c] |  | ||||||
| 			ssq = ssq + dc * dc |  | ||||||
| 		end |  | ||||||
| 		if math.sqrt(ssq) <= r then |  | ||||||
| 			return mbpos |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Find a male blossom in range of a specific female blossom, |  | ||||||
| -- using a nested list of male blossom positions |  | ||||||
| local function find_male_blossom_in_mpalms(ftpos, fbpos, mpalms) |  | ||||||
| 	-- Process the elements of mpalms.sect (index -4 .. 4) in random order |  | ||||||
| 	-- First, compute the order in which the sectors will be searched |  | ||||||
| 	local sect_index = {} |  | ||||||
| 	local sect_rnd = {} |  | ||||||
| 	for i = -4,4 do |  | ||||||
| 		local n = math.random(1023) |  | ||||||
| 		sect_index[n] =  i |  | ||||||
| 		table.insert(sect_rnd, n) |  | ||||||
| 	end |  | ||||||
| 	table.sort(sect_rnd) |  | ||||||
|  |  | ||||||
| 	-- Search the sectors |  | ||||||
| 	local sect_old = 0 |  | ||||||
| 	local sect_time = minetest.get_gametime() |  | ||||||
| 	for _, n in pairs(sect_rnd) do |  | ||||||
| 		-- Record the oldest sector, so that it can be searched if no male |  | ||||||
| 		-- blossoms were found |  | ||||||
| 		if not mpalms.sect_time[sect_index[n]] then |  | ||||||
| 			sect_old = sect_index[n] |  | ||||||
| 			sect_time = 0 |  | ||||||
| 		elseif mpalms.sect_time[sect_index[n]] < sect_time then |  | ||||||
| 			sect_old = sect_index[n] |  | ||||||
| 			sect_time = mpalms.sect_time[sect_index[n]] |  | ||||||
| 		end |  | ||||||
| 		if mpalms.sect[sect_index[n]] and #mpalms.sect[sect_index[n]] then |  | ||||||
| 			for px, mtpos in pairs(mpalms.sect[sect_index[n]]) do |  | ||||||
| 				local node = minetest.get_node(mtpos) |  | ||||||
| 				if node and node.name == "moretrees:date_palm_mfruit_trunk" then |  | ||||||
| 					local mbpos = find_male_blossom_near_trunk(fbpos, mtpos) |  | ||||||
| 					if mbpos then |  | ||||||
| 						return mbpos |  | ||||||
| 					end |  | ||||||
| 				elseif node and node.name ~= "ignore" then |  | ||||||
| 					-- no more male trunk here. |  | ||||||
| 					mpalms.sect[sect_index[n]][px] = nil |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| 	return nil, sect_old |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Find a male blossom in range of a specific female blossom, |  | ||||||
| -- using the cache associated with the given female trunk |  | ||||||
| -- If necessary, recompute part of the cache |  | ||||||
| local last_search_result = {} |  | ||||||
| local function find_male_blossom_with_ftrunk(fbpos,ftpos) |  | ||||||
| 	local meta = minetest.get_meta(ftpos) |  | ||||||
| 	local mpalms |  | ||||||
| 	local cache_changed = true |  | ||||||
|  |  | ||||||
| 	-- Load cache. If distance has changed, start with empty cache instead. |  | ||||||
| 	local mpalms_dist = meta:get_int("male_palms_dist") |  | ||||||
| 	if mpalms_dist and mpalms_dist == moretrees.dates_pollination_distance then |  | ||||||
| 		mpalms = meta:get_string("male_palms") |  | ||||||
| 		if mpalms and mpalms ~= "" then |  | ||||||
| 			mpalms = minetest.deserialize(mpalms) |  | ||||||
| 			cache_changed = false |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| 	if not mpalms or not mpalms.sect then |  | ||||||
| 		mpalms = {} |  | ||||||
| 		mpalms.sect = {} |  | ||||||
| 		mpalms.sect_time = {} |  | ||||||
| 		meta:set_int("male_palms_dist", moretrees.dates_pollination_distance) |  | ||||||
| 		cache_changed = true |  | ||||||
| 	end |  | ||||||
| 	local fpalms_list |  | ||||||
| 	local all_mpalms_list |  | ||||||
| 	local sector0_searched = false |  | ||||||
|  |  | ||||||
| 	-- Always make sure that sector 0 is cached |  | ||||||
| 	if not mpalms.sect[0] then |  | ||||||
| 		mpalms.sect[0], fpalms_list, all_mpalms_list = find_fruit_trunks_near(ftpos, {x = 0, z = 0}) |  | ||||||
| 		mpalms.sect_time[0] = minetest.get_gametime() |  | ||||||
| 		sector0_searched = true |  | ||||||
| 		cache_changed = true |  | ||||||
| 		last_search_result.female = fpalms_list |  | ||||||
| 		last_search_result.male = all_mpalms_list |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- Find male palms |  | ||||||
| 	local mbpos, sect_old = find_male_blossom_in_mpalms(ftpos, fbpos, mpalms) |  | ||||||
|  |  | ||||||
| 	-- If not found, (re)generate the cache for an additional sector. But don't search it yet (for performance reasons) |  | ||||||
| 	-- (Use the globally cached results if possible) |  | ||||||
| 	if not mbpos and not sector0_searched then |  | ||||||
| 		if not mpalms.sect_time[0] or mpalms.sect_time[0] == 0 or math.random(3) == 1 then |  | ||||||
| 			-- Higher probability of re-searching the center sector |  | ||||||
| 			sect_old = 0 |  | ||||||
| 		end |  | ||||||
| 		-- Use globally cached result if possible |  | ||||||
| 		mpalms.sect[sect_old] = nil |  | ||||||
| 		if sect_old == 0 and mpalms.sect_time[0] and mpalms.sect_time[0] > 0 |  | ||||||
| 				and last_search_result.male and #last_search_result.male then |  | ||||||
| 			for _, pos in pairs(last_search_result.female) do |  | ||||||
| 				if pos.x == ftpos.x and pos.y == ftpos.y and pos.z == ftpos.z then |  | ||||||
| 					mpalms.sect[sect_old] = last_search_result.male |  | ||||||
| 					-- Next time, don't use the cached result |  | ||||||
| 					mpalms.sect_time[sect_old] = nil |  | ||||||
| 					cache_changed = true |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 		-- Else do a new search |  | ||||||
| 		if not mpalms.sect[sect_old] then |  | ||||||
| 			mpalms.sect[sect_old], fpalms_list, all_mpalms_list = find_fruit_trunks_near( |  | ||||||
| 				ftpos, |  | ||||||
| 				{x = (sect_old + 4) % 3 - 1, z = (sect_old + 4) / 3 - 1} |  | ||||||
| 			) |  | ||||||
| 			cache_changed = true |  | ||||||
| 			if sect_old == 0 then |  | ||||||
| 				-- Save the results if it is sector 0 |  | ||||||
| 				-- (chance of reusing results from another sector are smaller) |  | ||||||
| 				last_search_result.female = fpalms_list |  | ||||||
| 				last_search_result.male = all_mpalms_list |  | ||||||
| 			end |  | ||||||
| 			if mpalms.sect[sect_old] then |  | ||||||
| 				mpalms.sect_time[sect_old] = minetest.get_gametime() |  | ||||||
| 			else |  | ||||||
| 				mpalms.sect_time[sect_old] = nil |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- Share search results with other female trunks in the same area |  | ||||||
| 	-- Note that the list of female trunks doesn't (shouldn't :-) contain the current female trunk. |  | ||||||
| 	if fpalms_list and #fpalms_list and #all_mpalms_list then |  | ||||||
| 		local all_mpalms = {} |  | ||||||
| 		all_mpalms.sect = {} |  | ||||||
| 		all_mpalms.sect_time = {} |  | ||||||
| 		all_mpalms.sect[0] = all_mpalms_list |  | ||||||
| 		-- Don't set sect_time[0], so that the cached sector will be re-searched soon (if necessary) |  | ||||||
| 		local all_mpalms_serialized = minetest.serialize(all_mpalms) |  | ||||||
| 		for _, pos in pairs(fpalms_list) do |  | ||||||
| 			local fmeta = minetest.get_meta(pos) |  | ||||||
| 			local fdist = fmeta:get_int("male_palms_dist") |  | ||||||
| 			if not fdist or fdist ~= moretrees.dates_pollination_distance then |  | ||||||
| 				fmeta:set_string("male_palms", all_mpalms_serialized) |  | ||||||
| 				fmeta:set_int("male_palms_dist", moretrees.dates_pollination_distance) |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- Save cache. |  | ||||||
| 	if cache_changed then |  | ||||||
| 		meta:set_string("male_palms", minetest.serialize(mpalms)) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	return mbpos |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Find a male blossom in range of a specific female blossom |  | ||||||
| local function find_male_blossom(fbpos) |  | ||||||
| 	local ftpos = find_female_trunk(fbpos) |  | ||||||
| 	if ftpos then |  | ||||||
| 		return find_male_blossom_with_ftrunk(fbpos, ftpos) |  | ||||||
| 	end |  | ||||||
| 	return nil |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- Growing function for dates |  | ||||||
| local dates_growfn = function(pos, elapsed) |  | ||||||
| 	local node = minetest.get_node(pos) |  | ||||||
| 	local delay = moretrees.dates_grow_interval |  | ||||||
| 	local action |  | ||||||
| 	if not node then |  | ||||||
| 		return |  | ||||||
| 	elseif not moretrees.dates_regrow_pollinated and dates_regrow_prob == 0 then |  | ||||||
| 		-- Regrowing of dates is disabled. |  | ||||||
| 		if string.find(node.name, "moretrees:dates_f") then |  | ||||||
| 			minetest.swap_node(pos, {name="moretrees:dates_f4"}) |  | ||||||
| 		elseif string.find(node.name, "moretrees:dates_m") then |  | ||||||
| 			minetest.swap_node(pos, {name="moretrees:dates_n"}) |  | ||||||
| 		else |  | ||||||
| 			minetest.swap_node(pos, {name = "air"}) |  | ||||||
| 		end |  | ||||||
| 		return |  | ||||||
| 	elseif node.name == "moretrees:dates_f0" and math.random(100) <= 100 * dates_regrow_prob then |  | ||||||
| 		-- Dates grow unpollinated |  | ||||||
| 		minetest.swap_node(pos, {name="moretrees:dates_f1"}) |  | ||||||
| 		action = "nopollinate" |  | ||||||
| 	elseif node.name == "moretrees:dates_f0" and moretrees.dates_regrow_pollinated and find_male_blossom(pos) then |  | ||||||
| 		-- Pollinate flowers |  | ||||||
| 		minetest.swap_node(pos, {name="moretrees:dates_f1"}) |  | ||||||
| 		action = "pollinate" |  | ||||||
| 	elseif string.match(node.name, "0$") then |  | ||||||
| 		-- Make female unpollinated and male flowers last a bit longer |  | ||||||
| 		if math.random(flowers_wither_ichance) == 1 then |  | ||||||
| 			if node.name == "moretrees:dates_f0" then |  | ||||||
| 				minetest.swap_node(pos, {name="moretrees:dates_fn"}) |  | ||||||
| 			else |  | ||||||
| 				minetest.swap_node(pos, {name="moretrees:dates_n"}) |  | ||||||
| 			end |  | ||||||
| 			action = "wither" |  | ||||||
| 		else |  | ||||||
| 			action = "nowither" |  | ||||||
| 		end |  | ||||||
| 	elseif node.name == "moretrees:dates_f4" then |  | ||||||
| 		-- Remove dates, and optionally drop them as items |  | ||||||
| 		if math.random(dates_drop_ichance) == 1 then |  | ||||||
| 			if moretrees.dates_item_drop_ichance > 0 and math.random(moretrees.dates_item_drop_ichance) == 1 then |  | ||||||
| 				local items = minetest.get_node_drops(minetest.get_node(pos).name) |  | ||||||
| 				for _, itemname in pairs(items) do |  | ||||||
| 					minetest.add_item(pos, itemname) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 			minetest.swap_node(pos, {name="moretrees:dates_n"}) |  | ||||||
| 			action = "drop" |  | ||||||
| 		else |  | ||||||
| 			action = "nodrop" |  | ||||||
| 		end |  | ||||||
| 	elseif string.match(node.name, "n$") then |  | ||||||
| 		-- Remove stems. |  | ||||||
| 		if math.random(stems_drop_ichance) == 1 then |  | ||||||
| 			minetest.swap_node(pos, {name = "air"}) |  | ||||||
| 			return "stemdrop" |  | ||||||
| 		end |  | ||||||
| 		action = "nostemdrop" |  | ||||||
| 	else |  | ||||||
| 		-- Grow dates |  | ||||||
| 		local offset = 18 |  | ||||||
| 		local n = string.sub(node.name, offset) |  | ||||||
| 		minetest.swap_node(pos, {name=string.sub(node.name, 1, offset-1)..n+1}) |  | ||||||
| 		action = "grow" |  | ||||||
| 	end |  | ||||||
| 	-- Don't catch up when elapsed time is large. Regular visits are needed for growth... |  | ||||||
| 	local timer = minetest.get_node_timer(pos) |  | ||||||
| 	timer:start(delay + math.random(moretrees.dates_grow_interval)) |  | ||||||
| 	return action |  | ||||||
| end |  | ||||||
|  |  | ||||||
| --[[ |  | ||||||
| -- Alternate growth function for dates. |  | ||||||
| -- It calls the primary growth function, but also measures CPU time consumed. |  | ||||||
| -- Use this function to analyze date growing performance. |  | ||||||
| local stat = {} |  | ||||||
| stat.count = 0 |  | ||||||
| local dates_growfn_profiling = function(pos, elapsed) |  | ||||||
| 	local t0 = minetest.get_us_time() |  | ||||||
| 	local action = dates_growfn(pos, elapsed) |  | ||||||
| 	local t1 = minetest.get_us_time() |  | ||||||
| 	if t1 < t0 then |  | ||||||
| 		t1 = t1 + 2^32 |  | ||||||
| 	end |  | ||||||
| 	stat.count = stat.count + 1 |  | ||||||
| 	if not stat[action] then |  | ||||||
| 		stat[action] = {} |  | ||||||
| 		stat[action].count = 0 |  | ||||||
| 		stat[action].sum = 0 |  | ||||||
| 		stat[action].min = 9999999999 |  | ||||||
| 		stat[action].max = 0 |  | ||||||
| 	end |  | ||||||
| 	stat[action].count = stat[action].count + 1 |  | ||||||
| 	stat[action].sum = stat[action].sum + t1-t0 |  | ||||||
| 	if t1-t0 < stat[action].min then |  | ||||||
| 		stat[action].min = t1-t0 |  | ||||||
| 	end |  | ||||||
| 	if t1-t0 > stat[action].max then |  | ||||||
| 		stat[action].max = t1-t0 |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	if stat.count % 10 == 0 then |  | ||||||
| 		io.write(".") |  | ||||||
| 		io.flush() |  | ||||||
| 	end |  | ||||||
| 	if stat.count % 100 == 0 then |  | ||||||
| 		print(string.format("Date grow statistics %5d:", stat.count)) |  | ||||||
| 		local sum = 0 |  | ||||||
| 		local count = 0 |  | ||||||
| 		if sect_search_stats.count > 0 and stat.pollinate and stat.pollinate.count > 0 then |  | ||||||
| 			print(string.format("\t%-12s: %6d (%4.1f%%): %6dus (%d..%d)", |  | ||||||
| 				"search", sect_search_stats.count, |  | ||||||
| 				100*sect_search_stats.count/stat.pollinate.count, |  | ||||||
| 				sect_search_stats.sum/sect_search_stats.count, |  | ||||||
| 				sect_search_stats.min, sect_search_stats.max)) |  | ||||||
| 		else |  | ||||||
| 			print(string.format("\t%-12s: %6d (%4.1f%%): %6dus (%d..%d)", |  | ||||||
| 				"search", sect_search_stats.count, |  | ||||||
| 				0, 0, 0, 0)) |  | ||||||
| 		end |  | ||||||
| 		for action,data in pairs(stat) do |  | ||||||
| 			if action ~= "count" then |  | ||||||
| 				count = count + data.count |  | ||||||
| 				sum = sum + data.sum |  | ||||||
| 				print(string.format("\t%-12s: %6d (%4.1f%%): %6dus (%d..%d)", |  | ||||||
| 					action, data.count, |  | ||||||
| 					100*data.count/stat.count, data.sum/data.count, |  | ||||||
| 					data.min, data.max)) |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 		print(string.format("\t%-12s: %6d ( 100%%): %6dus", |  | ||||||
| 			"TOTAL", count, sum/count)) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
| --]] |  | ||||||
|  |  | ||||||
| -- Register dates |  | ||||||
|  |  | ||||||
| local dates_starttimer = function(pos, elapsed) |  | ||||||
| 	local timer = minetest.get_node_timer(pos) |  | ||||||
| 	local base_interval = moretrees.dates_grow_interval * 2 / 3 |  | ||||||
| 	timer:set(base_interval + math.random(base_interval), elapsed or 0) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| local dates_drop = { |  | ||||||
| 	items = { |  | ||||||
| 		{items = { "moretrees:date" }}, |  | ||||||
| 		{items = { "moretrees:date" }}, |  | ||||||
| 		{items = { "moretrees:date" }}, |  | ||||||
| 		{items = { "moretrees:date" }}, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 2 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 2 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 2 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 2 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 5 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 5 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 5 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 5 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 20 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 20 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 20 }, |  | ||||||
| 		{items = { "moretrees:date" }, rarity = 20 }, |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
|  |  | ||||||
| for _,suffix in ipairs({"f0", "f1", "f2", "f3", "f4", "m0", "fn", "n"}) do |  | ||||||
| 	local name |  | ||||||
| 	if suffix == "f0" or suffix == "m0" then |  | ||||||
| 		name = S("Date Flowers") |  | ||||||
| 	elseif suffix == "n" or suffix == "fn" then |  | ||||||
| 		name = S("Date Stem") |  | ||||||
| 	else |  | ||||||
| 		name = S("Dates") |  | ||||||
| 	end |  | ||||||
| 	local dropfn = suffix == "f4" and dates_drop or "" |  | ||||||
| 	local datedef = { |  | ||||||
| 		description = name, |  | ||||||
| 		tiles = {"moretrees_dates_"..suffix..".png"}, |  | ||||||
| 		visual_scale = 2, |  | ||||||
| 		drawtype = "plantlike", |  | ||||||
| 		paramtype = "light", |  | ||||||
| 		sunlight_propagates = true, |  | ||||||
| 		walkable = false, |  | ||||||
| 		is_ground_content = false, |  | ||||||
| 		groups = { fleshy=3, dig_immediate=3, flammable=2, moretrees_dates=1 }, |  | ||||||
| 		inventory_image = "moretrees_dates_"..suffix..".png^[transformR0", |  | ||||||
| 		wield_image = "moretrees_dates_"..suffix..".png^[transformR90", |  | ||||||
| 		sounds = xcompat.sounds.node_sound_default(), |  | ||||||
| 		drop = dropfn, |  | ||||||
| 		selection_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.3, -0.3, -0.3, 0.3, 3.5, 0.3} |  | ||||||
| 		}, |  | ||||||
| 		on_timer = dates_growfn, |  | ||||||
| 		on_construct = (moretrees.dates_regrow_pollinated or moretrees.dates_regrow_unpollinated_percent > 0) |  | ||||||
| 				and dates_starttimer, |  | ||||||
|  |  | ||||||
| 	} |  | ||||||
| 	minetest.register_node("moretrees:dates_"..suffix, datedef) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- If regrowing was previously disabled, but is enabled now, make sure timers are started for existing dates |  | ||||||
| if moretrees.dates_regrow_pollinated or moretrees.dates_regrow_unpollinated_percent > 0 then |  | ||||||
| 	local spec = { |  | ||||||
| 		name = "moretrees:restart_dates_regrow_timer", |  | ||||||
| 		nodenames = "group:moretrees_dates", |  | ||||||
| 		action = function(pos, node, active_object_count, active_object_count_wider) |  | ||||||
| 			local timer = minetest.get_node_timer(pos) |  | ||||||
| 			if not timer:is_started() then |  | ||||||
| 				dates_starttimer(pos) |  | ||||||
| 			else |  | ||||||
| 				local timeout = timer:get_timeout() |  | ||||||
| 				local elapsed = timer:get_elapsed() |  | ||||||
| 				if timeout - elapsed > moretrees.dates_grow_interval * 4/3 then |  | ||||||
| 					dates_starttimer(pos, math.random(moretrees.dates_grow_interval * 4/3)) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		end, |  | ||||||
| 	} |  | ||||||
| 	if minetest.register_lbm then |  | ||||||
| 		minetest.register_lbm(spec) |  | ||||||
| 	else |  | ||||||
| 		spec.interval = 3557 |  | ||||||
| 		spec.chance = 10 |  | ||||||
| 		minetest.register_abm(spec) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
							
								
								
									
										87
									
								
								default_settings.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,87 @@ | |||||||
|  | -- Global configuration variables | ||||||
|  |  | ||||||
|  | -- Enable the various kinds of trees. | ||||||
|  |  | ||||||
|  | moretrees.enable_apple_tree		= true | ||||||
|  | moretrees.enable_oak			= true | ||||||
|  | moretrees.enable_sequoia		= true | ||||||
|  | moretrees.enable_palm			= true | ||||||
|  | moretrees.enable_pine			= true | ||||||
|  | moretrees.enable_rubber_tree	= true | ||||||
|  | moretrees.enable_willow			= true | ||||||
|  | moretrees.enable_acacia			= true | ||||||
|  | moretrees.enable_birch			= true | ||||||
|  | moretrees.enable_spruce			= true | ||||||
|  | moretrees.enable_jungle_tree	= true | ||||||
|  | moretrees.enable_fir			= true | ||||||
|  | moretrees.enable_beech			= false | ||||||
|  |  | ||||||
|  | -- set this to true to make moretrees spawn saplings at mapgen time instead | ||||||
|  | -- of fully-grown trees, which will grow into full trees very quickly.  With | ||||||
|  | -- older versions of plants_lib, doing this will reduce mapgen lag. | ||||||
|  |  | ||||||
|  | moretrees.spawn_saplings		= false | ||||||
|  |  | ||||||
|  | -- Set this to true to allow usage of the stairsplus mod in moreblocks | ||||||
|  |  | ||||||
|  | moretrees.enable_stairsplus		= true | ||||||
|  |  | ||||||
|  | -- Set this to true if you want the plantlike drawtype for leaves, which  | ||||||
|  | -- improves some peoples' framerates without resorting to making leaf nodes opaque. | ||||||
|  | -- Affects default leaves and default jungle leaves also. | ||||||
|  |  | ||||||
|  | moretrees.plantlike_leaves		= false | ||||||
|  |  | ||||||
|  | -- Set this to true to enable leaf decay of all trees except the default ones. | ||||||
|  |  | ||||||
|  | moretrees.enable_leafdecay		= true | ||||||
|  |  | ||||||
|  | -- Enable this one if you want this mod's leafdecay code to affect the old | ||||||
|  | -- default trees too; this setting is independent of the one above.  You'll | ||||||
|  | -- want to manually disable the default leafdecay code in minetest_game if | ||||||
|  | -- you enable this, otherwise you'll have two sets of leaf decay code running | ||||||
|  | -- at the same time, which will just waste CPU for no benefit. | ||||||
|  |  | ||||||
|  | moretrees.enable_default_leafdecay	= true | ||||||
|  |  | ||||||
|  | -- Enable this one for default *jungle* leaves | ||||||
|  |  | ||||||
|  | moretrees.enable_default_jungle_leafdecay	= true | ||||||
|  |  | ||||||
|  | -- Enable this if you want moretrees to redefine default apples so that they | ||||||
|  | -- fall when leaves decay/are dug. | ||||||
|  |  | ||||||
|  | moretrees.enable_redefine_apple		= true | ||||||
|  |  | ||||||
|  | -- various settings to configure default and default-jungle leaf decay. | ||||||
|  |  | ||||||
|  | moretrees.leafdecay_delay		= 2 | ||||||
|  | moretrees.leafdecay_chance		= 100 | ||||||
|  | moretrees.leafdecay_radius		= 5 | ||||||
|  |  | ||||||
|  | moretrees.default_jungle_leafdecay_delay = 2 | ||||||
|  | moretrees.default_jungle_leafdecay_chance = 100 | ||||||
|  | moretrees.default_jungle_leafdecay_radius = 5 | ||||||
|  |  | ||||||
|  | moretrees.palm_leafdecay_radius		= 15 | ||||||
|  |  | ||||||
|  | moretrees.default_leafdecay_delay	= 3 | ||||||
|  | moretrees.default_leafdecay_chance	= 50 | ||||||
|  | moretrees.default_leafdecay_radius	= 4 | ||||||
|  |  | ||||||
|  | -- Change these settings if you want default trees to be gradually cut down | ||||||
|  | -- above the elevation where firs normally generate. | ||||||
|  |  | ||||||
|  | moretrees.firs_remove_default_trees	= false | ||||||
|  | moretrees.firs_remove_interval		= 2 | ||||||
|  | moretrees.firs_remove_chance		= 150 | ||||||
|  |  | ||||||
|  | -- Sapling settings | ||||||
|  |  | ||||||
|  | moretrees.sapling_interval		= 500 | ||||||
|  | moretrees.sapling_chance		= 20 | ||||||
|  |  | ||||||
|  | -- If this variable is set to true, drop leaves out as entities during leaf | ||||||
|  | -- decay, rather than just disappearing them. | ||||||
|  |  | ||||||
|  | moretrees.decay_leaves_as_items = false | ||||||
							
								
								
									
										5
									
								
								depends.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | |||||||
|  | default | ||||||
|  | plants_lib | ||||||
|  | moreblocks? | ||||||
|  | intllib? | ||||||
|  |  | ||||||
							
								
								
									
										312
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						| @@ -8,83 +8,53 @@ | |||||||
| -- Brought together into one mod and made L-systems compatible by Vanessa | -- Brought together into one mod and made L-systems compatible by Vanessa | ||||||
| -- Ezekowitz. | -- Ezekowitz. | ||||||
| -- | -- | ||||||
| -- Firs and Jungle tree axioms/rules by Vanessa Dannenberg, with the | -- Firs and Jungle tree axioms/rules by Vanessa Ezekowitz, with the  | ||||||
| -- latter having been tweaked by RealBadAngel, most other axioms/rules written | -- latter having been tweaked by RealBadAngel, most other axioms/rules written | ||||||
| -- by RealBadAngel. | -- by RealBadAngel. | ||||||
| -- | -- | ||||||
|  | -- License: WTFPL for all parts (code and textures, including those copied | ||||||
|  | -- from the jungletree and conifers mods) except the default jungle tree trunk | ||||||
|  | -- texture, which is CC-By-SA. | ||||||
|  |  | ||||||
| moretrees = {} | moretrees = {} | ||||||
|  |  | ||||||
| local S = minetest.get_translator("moretrees") |  | ||||||
|  |  | ||||||
| if minetest.get_modpath("default") then |  | ||||||
| 	minetest.override_item("default:sapling", { |  | ||||||
| 		description = S("Sapling") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.override_item("default:tree", { |  | ||||||
| 		description = S("Tree") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.override_item("default:wood", { |  | ||||||
| 		description = S("Wooden Planks") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.override_item("default:leaves", { |  | ||||||
| 		description = S("Leaves") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.override_item("default:fence_wood", { |  | ||||||
| 		description = S("Wooden Fence") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.override_item("default:fence_rail_wood", { |  | ||||||
| 		description = S("Wooden Fence Rail") |  | ||||||
| 	}) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| if minetest.get_modpath("doors") then |  | ||||||
| 	minetest.override_item("doors:gate_wood_closed", { |  | ||||||
| 		description = S("Wooden Fence Gate") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	minetest.override_item("doors:gate_wood_open", { |  | ||||||
| 		description = S("Wooden Fence Gate") |  | ||||||
| 	}) |  | ||||||
| end |  | ||||||
|  |  | ||||||
|  |  | ||||||
| -- Read the default config file (and if necessary, copy it to the world folder). | -- Read the default config file (and if necessary, copy it to the world folder). | ||||||
|  |  | ||||||
| local worldpath=minetest.get_worldpath() | local worldpath=minetest.get_worldpath() | ||||||
| local modpath=minetest.get_modpath("moretrees") | local modpath=minetest.get_modpath("moretrees") | ||||||
|  |  | ||||||
| dofile(modpath.."/settings.lua") | dofile(modpath.."/default_settings.txt") | ||||||
|  |  | ||||||
| if io.open(worldpath.."/moretrees_settings.txt","r") then | if io.open(worldpath.."/moretrees_settings.txt","r") == nil then | ||||||
|  |  | ||||||
|  | 	io.input(modpath.."/default_settings.txt") | ||||||
|  | 	io.output(worldpath.."/moretrees_settings.txt") | ||||||
|  |  | ||||||
|  | 	local size = 2^13      -- good buffer size (8K) | ||||||
|  | 	while true do | ||||||
|  | 		local block = io.read(size) | ||||||
|  | 		if not block then | ||||||
| 			io.close() | 			io.close() | ||||||
|  | 			break | ||||||
|  | 		end | ||||||
|  | 		io.write(block) | ||||||
|  | 	end | ||||||
|  | else | ||||||
| 	dofile(worldpath.."/moretrees_settings.txt") | 	dofile(worldpath.."/moretrees_settings.txt") | ||||||
| end | end | ||||||
|  |  | ||||||
| -- Validate that if ethereal exists, that it's version is greater than 20220424. | -- Boilerplate to support localized strings if intllib mod is installed. | ||||||
| -- Lower versions of ethereal clear registered biomes and decorations during | local S | ||||||
| -- initialization which results in lost content from this mod (and others) | if minetest.get_modpath("intllib") then | ||||||
| -- depending on where they are in the mod load order. | 	S = intllib.Getter() | ||||||
| minetest.register_on_mods_loaded(function() | else | ||||||
| 	if minetest.global_exists("ethereal") then | 	S = function(s) return s end | ||||||
| 		local ethereal_ver = tonumber(ethereal.version) |  | ||||||
| 		if (ethereal_ver and ethereal_ver < 20220424) then |  | ||||||
| 			error("[moretrees] The version of ethereal detected can result " .. |  | ||||||
| 				  "in parts of this mod and others disappearing due to mod " .. |  | ||||||
| 				  "load order. Please update ethereal."); |  | ||||||
| end | end | ||||||
| 	end | moretrees.intllib = S | ||||||
| end) |  | ||||||
|  |  | ||||||
| -- infinite stacks checking | -- infinite stacks checking | ||||||
|  |  | ||||||
| if minetest.get_modpath("unified_inventory") or not | if minetest.get_modpath("unified_inventory") or not minetest.setting_getbool("creative_mode") then | ||||||
| 		minetest.settings:get_bool("creative_mode") then |  | ||||||
| 	moretrees.expect_infinite_stacks = false | 	moretrees.expect_infinite_stacks = false | ||||||
| else | else | ||||||
| 	moretrees.expect_infinite_stacks = true | 	moretrees.expect_infinite_stacks = true | ||||||
| @@ -93,10 +63,10 @@ end | |||||||
| -- tables, load other files | -- tables, load other files | ||||||
|  |  | ||||||
| moretrees.cutting_tools = { | moretrees.cutting_tools = { | ||||||
|  | 	"default:axe_bronze", | ||||||
|  | 	"default:axe_diamond", | ||||||
| 	"default:axe_mese", | 	"default:axe_mese", | ||||||
| 	xcompat.materials.axe_steel, | 	"default:axe_steel", | ||||||
| 	xcompat.materials.axe_diamond, |  | ||||||
| 	xcompat.materials.axe_bronze, |  | ||||||
| 	"glooptest:axe_alatro", | 	"glooptest:axe_alatro", | ||||||
| 	"glooptest:axe_arol", | 	"glooptest:axe_arol", | ||||||
| 	"moreores:axe_mithril", | 	"moreores:axe_mithril", | ||||||
| @@ -106,110 +76,105 @@ moretrees.cutting_tools = { | |||||||
|  |  | ||||||
| dofile(modpath.."/tree_models.lua") | dofile(modpath.."/tree_models.lua") | ||||||
| dofile(modpath.."/node_defs.lua") | dofile(modpath.."/node_defs.lua") | ||||||
| dofile(modpath.."/date_palm.lua") |  | ||||||
| dofile(modpath.."/cocos_palm.lua") |  | ||||||
| dofile(modpath.."/biome_defs.lua") | dofile(modpath.."/biome_defs.lua") | ||||||
| dofile(modpath.."/saplings.lua") | dofile(modpath.."/saplings.lua") | ||||||
| dofile(modpath.."/crafts.lua") | dofile(modpath.."/crafts.lua") | ||||||
|  | dofile(modpath.."/leafdecay.lua") | ||||||
|  |  | ||||||
| -- tree spawning setup | -- tree spawning setup | ||||||
|  |  | ||||||
|  | if moretrees.spawn_saplings then | ||||||
|  | 	moretrees.spawn_beech_object = "moretrees:beech_sapling_ongen" | ||||||
|  | 	moretrees.spawn_apple_tree_object = "moretrees:apple_tree_sapling_ongen" | ||||||
|  | 	moretrees.spawn_oak_object = "moretrees:oak_sapling_ongen" | ||||||
|  | 	moretrees.spawn_sequoia_object = "moretrees:sequoia_sapling_ongen" | ||||||
|  | 	moretrees.spawn_palm_object = "moretrees:palm_sapling_ongen" | ||||||
|  | 	moretrees.spawn_pine_object = "moretrees:pine_sapling_ongen" | ||||||
|  | 	moretrees.spawn_rubber_tree_object = "moretrees:rubber_tree_sapling_ongen" | ||||||
|  | 	moretrees.spawn_willow_object = "moretrees:willow_sapling_ongen" | ||||||
|  | 	moretrees.spawn_acacia_object = "moretrees:acacia_sapling_ongen" | ||||||
|  | 	moretrees.spawn_birch_object = "moretrees:birch_sapling_ongen" | ||||||
|  | 	moretrees.spawn_spruce_object = "moretrees:spruce_sapling_ongen" | ||||||
|  | 	moretrees.spawn_jungletree_object = "moretrees:jungletree_sapling_ongen" | ||||||
|  | 	moretrees.spawn_fir_object = "moretrees:fir_sapling_ongen" | ||||||
|  | 	moretrees.spawn_fir_snow_object = "snow:sapling_pine" | ||||||
|  | else | ||||||
| 	moretrees.spawn_beech_object = moretrees.beech_model | 	moretrees.spawn_beech_object = moretrees.beech_model | ||||||
| 	moretrees.spawn_apple_tree_object = moretrees.apple_tree_model | 	moretrees.spawn_apple_tree_object = moretrees.apple_tree_model | ||||||
| 	moretrees.spawn_oak_object = moretrees.oak_model | 	moretrees.spawn_oak_object = moretrees.oak_model | ||||||
| 	moretrees.spawn_sequoia_object = moretrees.sequoia_model | 	moretrees.spawn_sequoia_object = moretrees.sequoia_model | ||||||
| 	moretrees.spawn_palm_object = moretrees.palm_model | 	moretrees.spawn_palm_object = moretrees.palm_model | ||||||
| moretrees.spawn_date_palm_object = moretrees.date_palm_model | 	moretrees.spawn_pine_object = moretrees.pine_model | ||||||
| moretrees.spawn_cedar_object = moretrees.cedar_model |  | ||||||
| 	moretrees.spawn_rubber_tree_object = moretrees.rubber_tree_model | 	moretrees.spawn_rubber_tree_object = moretrees.rubber_tree_model | ||||||
| 	moretrees.spawn_willow_object = moretrees.willow_model | 	moretrees.spawn_willow_object = moretrees.willow_model | ||||||
| moretrees.spawn_birch_object = "moretrees.grow_birch" | 	moretrees.spawn_acacia_object = moretrees.acacia_model | ||||||
| moretrees.spawn_spruce_object = "moretrees.grow_spruce" | 	moretrees.spawn_birch_object = "moretrees:grow_birch" | ||||||
| moretrees.spawn_jungletree_object = "moretrees.grow_jungletree" | 	moretrees.spawn_spruce_object = "moretrees:grow_spruce" | ||||||
| moretrees.spawn_fir_object = "moretrees.grow_fir" | 	moretrees.spawn_jungletree_object = "moretrees:grow_jungletree" | ||||||
| moretrees.spawn_fir_snow_object = "moretrees.grow_fir_snow" | 	moretrees.spawn_fir_object = "moretrees:grow_fir" | ||||||
| moretrees.spawn_poplar_object = moretrees.poplar_model | 	moretrees.spawn_fir_snow_object = "moretrees:grow_fir_snow" | ||||||
| moretrees.spawn_poplar_small_object = moretrees.poplar_small_model |  | ||||||
|  |  | ||||||
| local deco_ids = {} |  | ||||||
|  |  | ||||||
| function translate_biome_defs(def, treename, index) |  | ||||||
| 	if not index then index = 1 end |  | ||||||
| 	local deco_def = { |  | ||||||
| 		name = treename .. "_" .. index, |  | ||||||
| 		deco_type = "simple", |  | ||||||
| 		place_on = def.place_on, |  | ||||||
| 		sidelen = 16, |  | ||||||
| 		fill_ratio = def.fill_ratio or 0.001, |  | ||||||
| 		--biomes eventually? |  | ||||||
| 		y_min = def.min_elevation, |  | ||||||
| 		y_max = def.max_elevation, |  | ||||||
| 		spawn_by = def.spawn_by, |  | ||||||
| 		num_spawn_by = def.num_spawn_by, |  | ||||||
| 		decoration = "moretrees:"..treename.."_sapling_ongen" |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	deco_ids[#deco_ids+1] = treename .. ("_" .. index or "_1") |  | ||||||
|  |  | ||||||
| 	return deco_def |  | ||||||
| end | end | ||||||
|  |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.beech_biome, "beech")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.apple_tree_biome, "apple_tree")) | if moretrees.enable_beech then | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.oak_biome, "oak")) | 	plantslib:register_generate_plant(moretrees.beech_biome, moretrees.spawn_beech_object) | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.sequoia_biome, "sequoia")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.palm_biome, "palm")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.date_palm_biome, "date_palm", 1)) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.date_palm_biome_2, "date_palm", 2)) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.cedar_biome, "cedar")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.rubber_tree_biome, "rubber_tree")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.willow_biome, "willow")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.birch_biome, "birch")) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.spruce_biome, "spruce")) |  | ||||||
| if minetest.get_modpath("default") then |  | ||||||
| 	minetest.register_decoration(translate_biome_defs(moretrees.jungletree_biome, "jungletree")) |  | ||||||
| end | end | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.fir_biome, "fir", 1)) |  | ||||||
|  | if moretrees.enable_apple_tree then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.apple_tree_biome, moretrees.spawn_apple_tree_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_oak then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.oak_biome, moretrees.spawn_oak_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_sequoia then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.sequoia_biome, moretrees.spawn_sequoia_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_palm then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.palm_biome, moretrees.spawn_palm_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_pine then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.pine_biome, moretrees.spawn_pine_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_rubber_tree then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.rubber_tree_biome, moretrees.spawn_rubber_tree_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_willow then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.willow_biome, moretrees.spawn_willow_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_acacia then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.acacia_biome, moretrees.spawn_acacia_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_birch then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.birch_biome, moretrees.spawn_birch_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_spruce then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.spruce_biome, moretrees.spawn_spruce_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_jungle_tree then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.jungletree_biome, moretrees.spawn_jungletree_object) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_fir then | ||||||
|  | 	plantslib:register_generate_plant(moretrees.fir_biome, moretrees.spawn_fir_object) | ||||||
| 	if minetest.get_modpath("snow") then | 	if minetest.get_modpath("snow") then | ||||||
| 	minetest.register_decoration(translate_biome_defs(moretrees.fir_biome_snow, "fir", 2)) | 		plantslib:register_generate_plant(moretrees.fir_biome_snow, moretrees.spawn_fir_snow_object) | ||||||
| end |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.poplar_biome, "poplar", 1)) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.poplar_biome_2, "poplar", 2)) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.poplar_biome_3, "poplar", 3)) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.poplar_small_biome, "poplar_small", 4)) |  | ||||||
| minetest.register_decoration(translate_biome_defs(moretrees.poplar_small_biome_2, "poplar_small", 5)) |  | ||||||
|  |  | ||||||
| --[[ |  | ||||||
| 	this is purposefully wrapped in a on mods loaded callback to that it gets the proper ids |  | ||||||
| 	if other mods clear the registered decorations |  | ||||||
| ]] |  | ||||||
| minetest.register_on_mods_loaded(function() |  | ||||||
| 	for k, v in pairs(deco_ids) do |  | ||||||
| 		deco_ids[k] = minetest.get_decoration_id(v) |  | ||||||
| 	end |  | ||||||
| 	minetest.set_gen_notify("decoration", deco_ids) |  | ||||||
| end) |  | ||||||
|  |  | ||||||
| minetest.register_on_generated(function(minp, maxp, blockseed) |  | ||||||
|     local g = minetest.get_mapgen_object("gennotify") |  | ||||||
|     local locations = {} |  | ||||||
| 	for _, id in pairs(deco_ids) do |  | ||||||
| 		local deco_locations = g["decoration#" .. id] or {} |  | ||||||
| 		for _, pos in pairs(deco_locations) do |  | ||||||
| 			locations[#locations+1] = pos |  | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
|     if #locations == 0 then return end |  | ||||||
|     for _, pos in ipairs(locations) do |  | ||||||
|         local timer = minetest.get_node_timer({x=pos.x, y=pos.y+1, z=pos.z}) |  | ||||||
|         timer:start(math.random(2,10)) |  | ||||||
|     end |  | ||||||
| end) |  | ||||||
|  |  | ||||||
| -- Code to spawn a birch tree | -- Code to spawn a birch tree | ||||||
|  |  | ||||||
| function moretrees.grow_birch(pos) | function moretrees:grow_birch(pos) | ||||||
| 	minetest.swap_node(pos, {name = "air"}) | 	minetest.remove_node(pos) | ||||||
| 	if math.random(1,2) == 1 then | 	if math.random(1,2) == 1 then | ||||||
| 		minetest.spawn_tree(pos, moretrees.birch_model1) | 		minetest.spawn_tree(pos, moretrees.birch_model1) | ||||||
| 	else | 	else | ||||||
| @@ -219,8 +184,8 @@ end | |||||||
|  |  | ||||||
| -- Code to spawn a spruce tree | -- Code to spawn a spruce tree | ||||||
|  |  | ||||||
| function moretrees.grow_spruce(pos) | function moretrees:grow_spruce(pos) | ||||||
| 	minetest.swap_node(pos, {name = "air"}) | 	minetest.remove_node(pos) | ||||||
| 	if math.random(1,2) == 1 then | 	if math.random(1,2) == 1 then | ||||||
| 		minetest.spawn_tree(pos, moretrees.spruce_model1) | 		minetest.spawn_tree(pos, moretrees.spruce_model1) | ||||||
| 	else | 	else | ||||||
| @@ -235,7 +200,6 @@ moretrees.jt_rules_a1 = "FFF[&&-FBf[&&&Ff]^^^Ff][&&+FBFf[&&&FFf]^^^Ff][&&---FBFf | |||||||
| moretrees.jt_rules_b1 = "[-Ff&f][+Ff&f]B" | moretrees.jt_rules_b1 = "[-Ff&f][+Ff&f]B" | ||||||
|  |  | ||||||
| moretrees.jt_axiom2 = "FFFFFA" | moretrees.jt_axiom2 = "FFFFFA" | ||||||
| -- luacheck: no max line length |  | ||||||
| moretrees.jt_rules_a2 = "FFFFF[&&-FFFBF[&&&FFff]^^^FFf][&&+FFFBFF[&&&FFff]^^^FFf][&&---FFFBFF[&&&FFff]^^^FFf][&&+++FFFBFF[&&&FFff]^^^FFf]FF/A" | moretrees.jt_rules_a2 = "FFFFF[&&-FFFBF[&&&FFff]^^^FFf][&&+FFFBFF[&&&FFff]^^^FFf][&&---FFFBFF[&&&FFff]^^^FFf][&&+++FFFBFF[&&&FFff]^^^FFf]FF/A" | ||||||
| moretrees.jt_rules_b2 = "[-FFf&ff][+FFf&ff]B" | moretrees.jt_rules_b2 = "[-FFf&ff][+FFf&ff]B" | ||||||
|  |  | ||||||
| @@ -245,7 +209,7 @@ moretrees.ct_rules_b1 = "[-FBf][+FBf]" | |||||||
| moretrees.ct_rules_a2 = "FF[FF][&&-FBF][&&+FBF][&&---FBF][&&+++FBF]F/A" | moretrees.ct_rules_a2 = "FF[FF][&&-FBF][&&+FBF][&&---FBF][&&+++FBF]F/A" | ||||||
| moretrees.ct_rules_b2 = "[-fB][+fB]" | moretrees.ct_rules_b2 = "[-fB][+fB]" | ||||||
|  |  | ||||||
| function moretrees.grow_jungletree(pos) | function moretrees:grow_jungletree(pos) | ||||||
| 	local r1 = math.random(2) | 	local r1 = math.random(2) | ||||||
| 	local r2 = math.random(3) | 	local r2 = math.random(3) | ||||||
| 	if r1 == 1 then | 	if r1 == 1 then | ||||||
| @@ -275,20 +239,19 @@ function moretrees.grow_jungletree(pos) | |||||||
| 		moretrees.jungletree_model.rules_b = moretrees.jt_rules_b2 | 		moretrees.jungletree_model.rules_b = moretrees.jt_rules_b2 | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	minetest.swap_node(pos, {name = "air"}) | 	moretrees.jungletree_model.enable_unique_ids = true | ||||||
| 	local leaves = minetest.find_nodes_in_area( |  | ||||||
| 		{x = pos.x-1, y = pos.y, z = pos.z-1}, {x = pos.x+1, y = pos.y+10, z = pos.z+1}, | 	minetest.remove_node(pos) | ||||||
| 		xcompat.materials.apple_leaves | 	local leaves = minetest.find_nodes_in_area({x = pos.x-1, y = pos.y, z = pos.z-1}, {x = pos.x+1, y = pos.y+10, z = pos.z+1}, "default:leaves") | ||||||
| 	) |  | ||||||
| 	for leaf in ipairs(leaves) do | 	for leaf in ipairs(leaves) do | ||||||
| 			minetest.swap_node(leaves[leaf], {name = "air"}) | 			minetest.remove_node(leaves[leaf]) | ||||||
| 	end | 	end | ||||||
| 	minetest.spawn_tree(pos, moretrees.jungletree_model) | 	minetest.spawn_tree(pos, moretrees.jungletree_model) | ||||||
| end | end | ||||||
|  |  | ||||||
| -- code to spawn fir trees | -- code to spawn fir trees | ||||||
|  |  | ||||||
| function moretrees.grow_fir(pos) | function moretrees:grow_fir(pos) | ||||||
| 	if math.random(2) == 1 then | 	if math.random(2) == 1 then | ||||||
| 		moretrees.fir_model.leaves="moretrees:fir_leaves" | 		moretrees.fir_model.leaves="moretrees:fir_leaves" | ||||||
| 	else | 	else | ||||||
| @@ -302,24 +265,21 @@ function moretrees.grow_fir(pos) | |||||||
| 		moretrees.fir_model.rules_b = moretrees.ct_rules_b2 | 		moretrees.fir_model.rules_b = moretrees.ct_rules_b2 | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
|  | 	moretrees.fir_model.enable_unique_ids = true | ||||||
| 	moretrees.fir_model.iterations = 7 | 	moretrees.fir_model.iterations = 7 | ||||||
| 	moretrees.fir_model.random_level = 5 | 	moretrees.fir_model.random_level = 5 | ||||||
|  |  | ||||||
| 	minetest.swap_node(pos, {name = "air"}) | 	minetest.remove_node(pos) | ||||||
| 	local leaves = minetest.find_nodes_in_area( | 	local leaves = minetest.find_nodes_in_area({x = pos.x, y = pos.y, z = pos.z}, {x = pos.x, y = pos.y+5, z = pos.z}, "default:leaves") | ||||||
| 		{x = pos.x, y = pos.y, z = pos.z}, |  | ||||||
| 		{x = pos.x, y = pos.y+5, z = pos.z}, |  | ||||||
| 		xcompat.materials.apple_leaves |  | ||||||
| 	) |  | ||||||
| 	for leaf in ipairs(leaves) do | 	for leaf in ipairs(leaves) do | ||||||
| 		minetest.swap_node(leaves[leaf], {name = "air"}) | 			minetest.remove_node(leaves[leaf]) | ||||||
| 	end | 	end | ||||||
| 	minetest.spawn_tree(pos,moretrees.fir_model) | 	minetest.spawn_tree(pos,moretrees.fir_model) | ||||||
| end | end | ||||||
|  |  | ||||||
| -- same thing, but a smaller version that grows only in snow biomes | -- same thing, but a smaller version that grows only in snow biomes | ||||||
|  |  | ||||||
| function moretrees.grow_fir_snow(pos) | function moretrees:grow_fir_snow(pos) | ||||||
| 	if math.random(2) == 1 then | 	if math.random(2) == 1 then | ||||||
| 		moretrees.fir_model.leaves="moretrees:fir_leaves" | 		moretrees.fir_model.leaves="moretrees:fir_leaves" | ||||||
| 	else | 	else | ||||||
| @@ -333,32 +293,20 @@ function moretrees.grow_fir_snow(pos) | |||||||
| 		moretrees.fir_model.rules_b = moretrees.ct_rules_b2 | 		moretrees.fir_model.rules_b = moretrees.ct_rules_b2 | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
|  | 	moretrees.fir_model.enable_unique_ids = true | ||||||
| 	moretrees.fir_model.iterations = 2 | 	moretrees.fir_model.iterations = 2 | ||||||
| 	moretrees.fir_model.random_level = 2 | 	moretrees.fir_model.random_level = 2 | ||||||
|  |  | ||||||
| 	minetest.swap_node(pos, {name = "air"}) | 	minetest.remove_node(pos) | ||||||
| 	local leaves = minetest.find_nodes_in_area( | 	local leaves = minetest.find_nodes_in_area({x = pos.x, y = pos.y, z = pos.z}, {x = pos.x, y = pos.y+5, z = pos.z}, "default:leaves") | ||||||
| 		{x = pos.x, y = pos.y, z = pos.z}, |  | ||||||
| 		{x = pos.x, y = pos.y+5, z = pos.z}, |  | ||||||
| 		xcompat.materials.apple_leaves |  | ||||||
| 	) |  | ||||||
| 	for leaf in ipairs(leaves) do | 	for leaf in ipairs(leaves) do | ||||||
| 			minetest.swap_node(leaves[leaf], {name = "air"}) | 			minetest.remove_node(leaves[leaf]) | ||||||
| 	end | 	end | ||||||
| 	minetest.spawn_tree(pos,moretrees.fir_model) | 	minetest.spawn_tree(pos,moretrees.fir_model) | ||||||
| end | end | ||||||
|  |  | ||||||
| if moretrees.grow_legacy_saplings then | minetest.register_on_punchnode(function(pos, node, puncher, pointed_thing) | ||||||
| 	minetest.register_lbm({ | 	print(dump(node.name)..": param1 = "..dump(node.param1)..", param2 = "..dump(node.param2)) | ||||||
| 		name = "moretrees:grow_ongen_saplings", | end) | ||||||
| 		label = "Grow legacy ongen saplings", |  | ||||||
| 		nodenames = {"group:moretrees_ongen"}, |  | ||||||
| 		run_at_every_load = true, |  | ||||||
| 		action = function(pos) |  | ||||||
| 			minetest.log("info", "[moretrees] Starting growth timer for legacy ongen sapling at "..minetest.pos_to_string(pos, 0)) |  | ||||||
| 			minetest.get_node_timer(pos):start(math.random(2, 10)) |  | ||||||
| 		end |  | ||||||
| 	}) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| minetest.log("info", "[moretrees] Loading done") | print(S("[Moretrees] Loaded (2013-02-11)")) | ||||||
|   | |||||||
							
								
								
									
										117
									
								
								leafdecay.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,117 @@ | |||||||
|  | -- leaf decay | ||||||
|  |  | ||||||
|  | -- this function is based on the default leafdecay code | ||||||
|  | local process_drops = function(pos, name) | ||||||
|  | 	local drops = minetest.get_node_drops(name) | ||||||
|  | 	for _,dropitem in ipairs(drops) do | ||||||
|  | 		if dropitem ~= name | ||||||
|  | 		  or (string.find(name, "leaves") and moretrees.decay_leaves_as_items) then | ||||||
|  | 			local newpos = { | ||||||
|  | 						x=pos.x + math.random() - 0.5, | ||||||
|  | 						y=pos.y + math.random() - 0.5, | ||||||
|  | 						z=pos.z + math.random() - 0.5 | ||||||
|  | 					} | ||||||
|  | 			minetest.add_item(newpos, dropitem) | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_leafdecay then | ||||||
|  | 	for i in ipairs(moretrees.treelist) do | ||||||
|  | 		local treename = moretrees.treelist[i][1] | ||||||
|  | 		if treename ~= "jungletree" and treename ~= "fir" and treename ~= "palm" then | ||||||
|  | 			minetest.register_abm({ | ||||||
|  | 				nodenames = "moretrees:"..treename.."_leaves", | ||||||
|  | 				interval = moretrees.leafdecay_delay, | ||||||
|  | 				chance = moretrees.leafdecay_chance, | ||||||
|  | 				action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 					if minetest.find_node_near(pos, moretrees.leafdecay_radius, { "ignore", "moretrees:"..treename.."_trunk" }) then return end | ||||||
|  | 					process_drops(pos, node.name) | ||||||
|  | 					minetest.remove_node(pos) | ||||||
|  | 					nodeupdate(pos) | ||||||
|  | 				end | ||||||
|  | 			}) | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  |  | ||||||
|  | 	minetest.register_abm({ | ||||||
|  | 		nodenames = {"moretrees:jungletree_leaves_red","moretrees:jungletree_leaves_green","moretrees:jungletree_leaves_yellow"}, | ||||||
|  | 		interval = moretrees.leafdecay_delay, | ||||||
|  | 		chance = moretrees.leafdecay_chance, | ||||||
|  | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 			if minetest.find_node_near(pos, moretrees.leafdecay_radius, {"ignore", "default:jungletree", "moretrees:jungletree_trunk"}) then return end | ||||||
|  | 			process_drops(pos, node.name) | ||||||
|  | 			minetest.remove_node(pos) | ||||||
|  | 			nodeupdate(pos) | ||||||
|  | 		end | ||||||
|  | 	}) | ||||||
|  |  | ||||||
|  | 	minetest.register_abm({ | ||||||
|  | 		nodenames = {"moretrees:fir_leaves", "moretrees:fir_leaves_bright"}, | ||||||
|  | 		interval = moretrees.leafdecay_delay, | ||||||
|  | 		chance = moretrees.leafdecay_chance, | ||||||
|  | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 			if minetest.find_node_near(pos, moretrees.leafdecay_radius, { "ignore", "moretrees:fir_trunk" }) then return end | ||||||
|  | 			process_drops(pos, node.name) | ||||||
|  | 			minetest.remove_node(pos) | ||||||
|  | 			nodeupdate(pos) | ||||||
|  | 		end | ||||||
|  | 	}) | ||||||
|  |  | ||||||
|  | 	minetest.register_abm({ | ||||||
|  | 		nodenames = "moretrees:palm_leaves", | ||||||
|  | 		interval = moretrees.leafdecay_delay, | ||||||
|  | 		chance = moretrees.leafdecay_chance, | ||||||
|  | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 			if minetest.find_node_near(pos, moretrees.palm_leafdecay_radius, { "ignore", "moretrees:palm_trunk" }) then return end | ||||||
|  | 			process_drops(pos, node.name) | ||||||
|  | 			minetest.remove_node(pos) | ||||||
|  | 			nodeupdate(pos) | ||||||
|  | 		end | ||||||
|  | 	}) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_default_leafdecay then | ||||||
|  |  | ||||||
|  | 	minetest.register_abm({ | ||||||
|  | 		nodenames = "default:leaves", | ||||||
|  | 		interval = moretrees.default_leafdecay_delay, | ||||||
|  | 		chance = moretrees.default_leafdecay_chance, | ||||||
|  | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 			if minetest.find_node_near(pos, moretrees.default_leafdecay_radius, { "ignore", "default:tree" }) then return end | ||||||
|  | 			process_drops(pos, node.name) | ||||||
|  | 			minetest.remove_node(pos) | ||||||
|  | 			nodeupdate(pos) | ||||||
|  | 		end | ||||||
|  | 	})	 | ||||||
|  | end | ||||||
|  |  | ||||||
|  | -- Decay apple tree blossoms from nature_classic mod  | ||||||
|  | if minetest.get_modpath("nature_classic") then | ||||||
|  | 	minetest.register_abm({ | ||||||
|  | 		nodenames = "moretrees:apple_blossoms", | ||||||
|  | 		interval = moretrees.default_leafdecay_delay, | ||||||
|  | 		chance = moretrees.default_leafdecay_chance, | ||||||
|  | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 		if minetest.find_node_near(pos, moretrees.leafdecay_radius, { "ignore", "moretrees:apple_tree_trunk" }) then return end | ||||||
|  | 			process_drops(pos, "moretrees:apple_tree_leaves") | ||||||
|  | 			minetest.remove_node(pos) | ||||||
|  | 			nodeupdate(pos) | ||||||
|  | 		end | ||||||
|  | 	}) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | if moretrees.enable_default_jungle_leafdecay then | ||||||
|  | 	minetest.register_abm({ | ||||||
|  | 		nodenames = "default:jungleleaves", | ||||||
|  | 		interval = moretrees.default_jungle_leafdecay_delay, | ||||||
|  | 		chance = moretrees.default_jungle_leafdecay_chance, | ||||||
|  | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
|  | 			if minetest.find_node_near(pos, moretrees.default_jungle_leafdecay_radius, { "ignore", "default:jungletree" }) then return end | ||||||
|  | 			process_drops(pos, node.name) | ||||||
|  | 			minetest.remove_node(pos) | ||||||
|  | 			nodeupdate(pos) | ||||||
|  | 		end | ||||||
|  | 	})	 | ||||||
|  | end | ||||||
|  |  | ||||||
							
								
								
									
										74
									
								
								locale/de.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,74 @@ | |||||||
|  | # Translation by Xanthin | ||||||
|  |  | ||||||
|  | ### crafts.lua ### | ||||||
|  | Coconut Milk = Kokosnussmilch | ||||||
|  | Raw Coconut = Kokosnussfleisch | ||||||
|  | Acorn Muffin batter = Eichelmuffinteig | ||||||
|  | Acorn Muffin = Eichelmuffin | ||||||
|  | Roasted Spruce Cone Nuts = Geroestete Fichtenzapfen | ||||||
|  | Roasted Pine Cone Nuts = Geroestete Kiefernzapfen | ||||||
|  | Roasted Fir Cone Nuts = Geroestete Tannenzapfen | ||||||
|  |  | ||||||
|  | ### node_defs.lua ### | ||||||
|  | Beech Tree Trunk = Buchenstamm | ||||||
|  | Apple Tree Trunk = Apfelbaumstamm | ||||||
|  | Oak Tree Trunk = Eichenstamm | ||||||
|  | Giant Sequoia Trunk = Riesenmammutbaumstamm | ||||||
|  | Birch Tree Trunk = Birkenstamm | ||||||
|  | Palm Tree Trunk = Palmenstamm | ||||||
|  | Spruce Tree Trunk = Fichtenstamm | ||||||
|  | Pine Tree Trunk = Kiefernstamm | ||||||
|  | Willow Tree Trunk = Weidenstamm | ||||||
|  | Rubber Tree Trunk = Gummibaumstamm | ||||||
|  | Jungle Tree Trunk = Tropenbaumstamm | ||||||
|  | Douglas Fir Trunk = Douglasienstamm | ||||||
|  | Beech Tree Planks = Buchebretter | ||||||
|  | Apple Tree Planks = Apfelbaumbretter | ||||||
|  | Oak Tree Planks = Eichenbretter | ||||||
|  | Giant Sequoia Planks = Riesenmammutbaumbretter | ||||||
|  | Birch Tree Planks = Birkebretter | ||||||
|  | Palm Tree Planks = Palmenbretter | ||||||
|  | Spruce Tree Planks = Fichtenbretter | ||||||
|  | Pine Tree Planks = Kiefernbretter | ||||||
|  | Willow Tree Planks = Weidenbretter | ||||||
|  | Rubber Tree Planks = Gummibaumbretter | ||||||
|  | Jungle Tree Planks = Tropenholzbretter | ||||||
|  | Douglas Fir Planks = Douglasienbretter | ||||||
|  | Beech Tree Sapling = Buchesetzling | ||||||
|  | Apple Tree Sapling = Apfelbaumsetzling | ||||||
|  | Oak Tree Sapling = Eichensetzling | ||||||
|  | Giant Sequoia Sapling = Riesenmammutbaumsetzling | ||||||
|  | Birch Tree Sapling = Birkensetzling | ||||||
|  | Palm Tree Sapling = Palmensetzling | ||||||
|  | Spruce Tree Sapling = Fichtensetzling | ||||||
|  | Pine Tree Sapling = Kiefernsetzling | ||||||
|  | Willow Tree Sapling = Weidensetzling | ||||||
|  | Rubber Tree Sapling = Gummibaumsetzling | ||||||
|  | Jungle Tree Sapling = Tropenbaumsetzling | ||||||
|  | Douglas Fir Sapling = Douglasiensetzling | ||||||
|  | Beech Tree Leaves = Buchenlaub | ||||||
|  | Apple Tree Leaves = Apfelbaumlaub | ||||||
|  | Oak Tree Leaves = Eichenlaub | ||||||
|  | Giant Sequoia Leaves = Riesenmammutbaumlaub | ||||||
|  | Birch Tree Leaves = Birkenlaub | ||||||
|  | Palm Tree Leaves = Palmenlaub | ||||||
|  | Spruce Tree Leaves = Fichtennadeln | ||||||
|  | Pine Tree Leaves = Kiefernnadeln | ||||||
|  | Willow Tree Leaves = Weidenlaub | ||||||
|  | Rubber Tree Leaves = Gummibaumlaub | ||||||
|  | Jungle Tree Leaves = Tropenbaumlaub | ||||||
|  | Douglas Fir Leaves = Douglasiennadeln | ||||||
|  |  | ||||||
|  | Acorn = Eichel | ||||||
|  | Coconut = Kokosnuss | ||||||
|  | Spruce Cone = Fichtenzapfen | ||||||
|  | Pine Cone = Kiefernzapfen | ||||||
|  | Fir Cone = Tannenzapfen | ||||||
|  | Jungle Sapling = Tropenbaumsetzling | ||||||
|  | Jungle Tree Leaves (Green) = Tropenbaumlaub (gruen) | ||||||
|  | Jungle Tree Leaves (Yellow) = Tropenbaumlaub (gelb) | ||||||
|  | Jungle Tree Leaves (Red) = Tropenbaumlaub (rot) | ||||||
|  | Douglas Fir Leaves (Bright) = Douglasiennadeln (breit) | ||||||
|  | Rubber Tree Trunk (Empty) = Gummibaumstamm (leer) | ||||||
|  |  | ||||||
|  | [Moretrees] Loaded (2013-02-11) = [Moretrees] geladen (2013-02-11) | ||||||
| @@ -1,220 +0,0 @@ | |||||||
| # textdomain: moretrees |  | ||||||
| # Translation by Xanthin and heavygale |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### cocos_palm.lua ### |  | ||||||
|  |  | ||||||
| Coconut=Kokosnuss |  | ||||||
| Coconut Flower=Kokosnussblüte |  | ||||||
|  |  | ||||||
| ### crafts.lua ### |  | ||||||
|  |  | ||||||
| Acorn Muffin=Eichelmuffin |  | ||||||
| Acorn Muffin batter=Eichelmuffinteig |  | ||||||
| Coconut Milk=Kokosnussmilch |  | ||||||
| Date=Dattel |  | ||||||
| Date & nut snack=Dattel & Nuss-Snack |  | ||||||
| Date-nut cake=Dattelnusskuchen |  | ||||||
| Date-nut cake batter=Dattelnuss-Kuchenteig |  | ||||||
| Date-nut energy bar=Dattelnuss-Energieriegel |  | ||||||
| Raw Coconut=Kokosnussfleisch |  | ||||||
| Roasted Cedar Cone Nuts=Geröstete Zedernzapfenkerne |  | ||||||
| Roasted Fir Cone Nuts=Geroestete Tannenzapfenkerne |  | ||||||
| Roasted Spruce Cone Nuts=Geroestete Fichtenzapfenkerne |  | ||||||
|  |  | ||||||
| ### date_palm.lua ### |  | ||||||
|  |  | ||||||
| Date Flowers=Dattelblüten |  | ||||||
| Date Stem=Dattelstamm |  | ||||||
| Dates=Datteln |  | ||||||
|  |  | ||||||
| ### node_defs.lua ### |  | ||||||
|  |  | ||||||
| @1 (fast growth)=@1 (schnelles Wachstum) |  | ||||||
| Acorn=Eichel |  | ||||||
| Apple Tree=Apfelbaum |  | ||||||
| Apple Tree Fence=Apfelbaum-Zaun |  | ||||||
| Apple Tree Fence Gate=Apfelbaum-Tor |  | ||||||
| Apple Tree Fence Rail=Apfelbaum-Schiene |  | ||||||
| Apple Tree Leaves=Apfelbaumlaub |  | ||||||
| Apple Tree Planks=Apfelbaumbretter |  | ||||||
| Apple Tree Planks Slab=Apfelbaumplatte |  | ||||||
| Apple Tree Planks Stair=Apfelbaumstufe |  | ||||||
| Apple Tree Sapling=Apfelbaumsetzling |  | ||||||
| Apple Tree Trunk=Apfelbaumstamm |  | ||||||
| Apple Tree Trunk Slab=Apfelbaumstammplatte |  | ||||||
| Apple Tree Trunk Stair=Apfelbaumstammstufe |  | ||||||
| Beech Tree=Buche |  | ||||||
| Beech Tree Fence=Buchenholz-Zaun |  | ||||||
| Beech Tree Fence Gate=Buchenholz-Tor |  | ||||||
| Beech Tree Fence Rail=Buchenholz-Schiene |  | ||||||
| Beech Tree Leaves=Buchenlaub |  | ||||||
| Beech Tree Planks=Buchenholzbretter |  | ||||||
| Beech Tree Planks Slab=Buchenholzplatte |  | ||||||
| Beech Tree Planks Stair=Buchenholzstufe  |  | ||||||
| Beech Tree Sapling=Buchesetzling |  | ||||||
| Beech Tree Trunk=Buchenstamm |  | ||||||
| Beech Tree Trunk Slab=Buchenstammplatte |  | ||||||
| Beech Tree Trunk Stair=Buchenstammstufe |  | ||||||
| Birch Tree=Birke |  | ||||||
| Birch Tree Fence=Birkenholz-Zaun |  | ||||||
| Birch Tree Fence Gate=Birkenholz-Tor |  | ||||||
| Birch Tree Fence Rail=Birkenholz-Schiene |  | ||||||
| Birch Tree Leaves=Birkenlaub |  | ||||||
| Birch Tree Planks=Birkenbretter |  | ||||||
| Birch Tree Planks Slab=Birkenholzplatte |  | ||||||
| Birch Tree Planks Stair=Birkeholzstufe |  | ||||||
| Birch Tree Sapling=Birkensetzling |  | ||||||
| Birch Tree Trunk=Birkenstamm |  | ||||||
| Birch Tree Trunk Slab=Birkenstammplatte |  | ||||||
| Birch Tree Trunk Stair=Birkenstammstufe |  | ||||||
| Cedar Cone=Zedernzapfen |  | ||||||
| Cedar Tree=Zeder |  | ||||||
| Cedar Tree Fence=Zedernholz-Zaun |  | ||||||
| Cedar Tree Fence Gate=Zedernholz-Tor |  | ||||||
| Cedar Tree Fence Rail=Zedernholz-Schiene |  | ||||||
| Cedar Tree Leaves=Zederblätter |  | ||||||
| Cedar Tree Planks=Zedernholzbretter |  | ||||||
| Cedar Tree Planks Slab=Zedernholzplatte |  | ||||||
| Cedar Tree Planks Stair=Zedernholzstufe |  | ||||||
| Cedar Tree Sapling=Zedersetzling |  | ||||||
| Cedar Tree Trunk=Zederstamm |  | ||||||
| Cedar Tree Trunk Slab=Zederstammplatte |  | ||||||
| Cedar Tree Trunk Stair=Zederstamm Stufe |  | ||||||
| Date Palm Tree=Dattelpalme |  | ||||||
| Date Palm Tree Fence=Dattelpalmen-Zaun |  | ||||||
| Date Palm Tree Fence Gate=Dattelpalmen-Tor |  | ||||||
| Date Palm Tree Fence Rail=Dattelpalmen-Schiene |  | ||||||
| Date Palm Tree Leaves=Dattelpalmenblätter |  | ||||||
| Date Palm Tree Planks=Dattelpalmenbretter |  | ||||||
| Date Palm Tree Planks Slab=Dattelpalmenplatte |  | ||||||
| Date Palm Tree Planks Stair=Dattelpalmenstufe |  | ||||||
| Date Palm Tree Sapling=Dattelpalmensetzling |  | ||||||
| Date Palm Tree Trunk=Dattelpalmenstamm |  | ||||||
| Date Palm Tree Trunk Slab=Dattelpalmenstammplatte |  | ||||||
| Date Palm Tree Trunk Stair=Dattelpalmenstammstufe |  | ||||||
| Douglas Fir=Douglasie |  | ||||||
| Douglas Fir Fence=Douglasien-Zaun |  | ||||||
| Douglas Fir Fence Gate=Douglasien-Tor |  | ||||||
| Douglas Fir Fence Rail=Douglasien-Schiene |  | ||||||
| Douglas Fir Leaves=Douglasiennadeln |  | ||||||
| Douglas Fir Leaves (Bright)=Douglasiennadeln (breit) |  | ||||||
| Douglas Fir Planks=Douglasienbretter |  | ||||||
| Douglas Fir Planks Slab=Douglasienplatte |  | ||||||
| Douglas Fir Planks Stair=Douglasienstufe |  | ||||||
| Douglas Fir Sapling=Douglasiensetzling |  | ||||||
| Douglas Fir Trunk=Douglasienstamm |  | ||||||
| Douglas Fir Trunk Slab=Douglasienstammplatte |  | ||||||
| Douglas Fir Trunk Stair=Douglasienstammstufe |  | ||||||
| Fir Cone=Tannenzapfen |  | ||||||
| Giant Sequoia=Riesenmammutbaum |  | ||||||
| Giant Sequoia Fence=Riesenmammutbaum-Zaun |  | ||||||
| Giant Sequoia Fence Gate=Riesenmammutbaum-Tor |  | ||||||
| Giant Sequoia Fence Rail=Riesenmammutbaum-Schiene |  | ||||||
| Giant Sequoia Leaves=Riesenmammutbaumlaub |  | ||||||
| Giant Sequoia Planks=Riesenmammutbaumbretter |  | ||||||
| Giant Sequoia Planks Slab=Riesenmammutbaumplatte |  | ||||||
| Giant Sequoia Planks Stair=Riesenmammutbaumstufe |  | ||||||
| Giant Sequoia Sapling=Riesenmammutbaumsetzling |  | ||||||
| Giant Sequoia Trunk=Riesenmammutbaumstamm |  | ||||||
| Giant Sequoia Trunk Slab=Riesenmammutbaumstammplatte |  | ||||||
| Giant Sequoia Trunk Stair=Riesenmammutbaumstammstufe |  | ||||||
| Jungle Tree=Tropenbaum |  | ||||||
| Jungle Tree Fence=Tropenbaum-Zaun |  | ||||||
| Jungle Tree Fence Gate=Tropenbaum-Tor |  | ||||||
| Jungle Tree Fence Rail=Tropenbaum-Schiene |  | ||||||
| Jungle Tree Leaves=Tropenbaumlaub |  | ||||||
| Jungle Tree Leaves (@1)=Tropenbaumlaub (@1) |  | ||||||
| Jungle Tree Planks=Tropenholzbretter |  | ||||||
| Jungle Tree Planks Slab=Tropenholzplatte |  | ||||||
| Jungle Tree Planks Stair=Tropenholzstufe |  | ||||||
| Jungle Tree Sapling=Tropenbaumsetzling |  | ||||||
| Jungle Tree Trunk=Tropenbaumstamm |  | ||||||
| Jungle Tree Trunk Slab=Tropenbaumstammplatte |  | ||||||
| Jungle Tree Trunk Stair=Tropenbaumstammstufe |  | ||||||
| Oak Tree=Eiche |  | ||||||
| Oak Tree Fence=Eichenholz-Zaun |  | ||||||
| Oak Tree Fence Gate=Eichenholz-Tor |  | ||||||
| Oak Tree Fence Rail=Eichenholz-Schiene |  | ||||||
| Oak Tree Leaves=Eichenlaub |  | ||||||
| Oak Tree Planks=Eichenbretter |  | ||||||
| Oak Tree Planks Slab=Eichenholzplatte |  | ||||||
| Oak Tree Planks Stair=Eichenholzstufe |  | ||||||
| Oak Tree Sapling=Eichensetzling |  | ||||||
| Oak Tree Trunk=Eichenstamm |  | ||||||
| Oak Tree Trunk Slab=Eichenstammplatte |  | ||||||
| Oak Tree Trunk Stair=Eichenstammstufe |  | ||||||
| Palm Tree=Palme |  | ||||||
| Palm Tree Fence=Plamenholz-Zaun |  | ||||||
| Palm Tree Fence Gate=Plamenholz-Tor |  | ||||||
| Palm Tree Fence Rail=Plamenholz-Schiene |  | ||||||
| Palm Tree Leaves=Palmenlaub |  | ||||||
| Palm Tree Planks=Palmenbretter |  | ||||||
| Palm Tree Planks Slab=Plamenholzplatte |  | ||||||
| Palm Tree Planks Stair=Plamenholzstufe |  | ||||||
| Palm Tree Sapling=Palmensetzling |  | ||||||
| Palm Tree Trunk=Palmenstamm |  | ||||||
| Palm Tree Trunk Slab=Palmenstammplatte |  | ||||||
| Palm Tree Trunk Stair=Palmenstammstufe |  | ||||||
| Poplar Tree=Pappel |  | ||||||
| Poplar Tree Fence=Pappelholz-Zaun |  | ||||||
| Poplar Tree Fence Gate=Pappelholz-Tor |  | ||||||
| Poplar Tree Fence Rail=Pappelholz-Schiene |  | ||||||
| Poplar Tree Leaves=Pappelblätter |  | ||||||
| Poplar Tree Planks=Pappelholzbretter |  | ||||||
| Poplar Tree Planks Slab=Pappelholzsplatte |  | ||||||
| Poplar Tree Planks Stair=Pappelholzstufe |  | ||||||
| Poplar Tree Sapling=Pappelsetzling |  | ||||||
| Poplar Tree Trunk=Pappelstamm |  | ||||||
| Poplar Tree Trunk Slab=Pappelstammplatte |  | ||||||
| Poplar Tree Trunk Stair=Pappelstammstufe |  | ||||||
| Red=rot |  | ||||||
| Rubber Tree=Gummibaum |  | ||||||
| Rubber Tree Fence=Gummibaum-Zaun |  | ||||||
| Rubber Tree Fence Gate=Gummibaum-Tor |  | ||||||
| Rubber Tree Fence Rail=Gummibaum-Schiene |  | ||||||
| Rubber Tree Leaves=Gummibaumlaub |  | ||||||
| Rubber Tree Planks=Gummibaumbretter |  | ||||||
| Rubber Tree Planks Slab=Gummibaumplatte |  | ||||||
| Rubber Tree Planks Stair=Gummibaumstufe |  | ||||||
| Rubber Tree Sapling=Gummibaumsetzling |  | ||||||
| Rubber Tree Trunk=Gummibaumstamm |  | ||||||
| Rubber Tree Trunk (Empty)=Gummibaumstamm (leer) |  | ||||||
| Rubber Tree Trunk Slab=Gummibaumstammplatte |  | ||||||
| Rubber Tree Trunk Stair=Gummibaumstammstufe |  | ||||||
| Small poplar Tree Sapling=Kleiner Pappelsetzling |  | ||||||
| Spruce Cone=Fichtenzapfen |  | ||||||
| Spruce Tree=Fichte |  | ||||||
| Spruce Tree Fence=Fichtenholz-Zaun |  | ||||||
| Spruce Tree Fence Gate=Fichtenholz-Zaun |  | ||||||
| Spruce Tree Fence Rail=Fichtenholz-Schiene |  | ||||||
| Spruce Tree Leaves=Fichtennadeln |  | ||||||
| Spruce Tree Planks=Fichtenbretter |  | ||||||
| Spruce Tree Planks Slab=Fichtenholzplatte |  | ||||||
| Spruce Tree Planks Stair=Fichtenholzstufe |  | ||||||
| Spruce Tree Sapling=Fichtensetzling |  | ||||||
| Spruce Tree Trunk=Fichtenstamm |  | ||||||
| Spruce Tree Trunk Slab=Fichtenstammplatte |  | ||||||
| Spruce Tree Trunk Stair=Fichtenstammstufe |  | ||||||
| Willow Tree=Weide |  | ||||||
| Willow Tree Fence=Weidenholz-Zaun |  | ||||||
| Willow Tree Fence Gate=Weidenholz-Tor |  | ||||||
| Willow Tree Fence Rail=Weidenholz-Schiene |  | ||||||
| Willow Tree Leaves=Weidenlaub |  | ||||||
| Willow Tree Planks=Weidenbretter |  | ||||||
| Willow Tree Planks Slab=Weidenholzplatte |  | ||||||
| Willow Tree Planks Stair=Weidenholzstufe |  | ||||||
| Willow Tree Sapling=Weidensetzling |  | ||||||
| Willow Tree Trunk=Weidenstamm |  | ||||||
| Willow Tree Trunk Slab=Weidenstammplatte |  | ||||||
| Willow Tree Trunk Stair=Weidenstammstufe |  | ||||||
| Yellow=gelb |  | ||||||
|  |  | ||||||
| # init.lua |  | ||||||
| Sapling=Setzling |  | ||||||
| Tree=Baum |  | ||||||
| Wooden Planks=Holzbretter |  | ||||||
| Leaves=Blätter |  | ||||||
| Wooden Fence=Holzzaun |  | ||||||
| Wooden Fence Rail=Holzschiene |  | ||||||
| Wooden Fence Gate=Holztor |  | ||||||
| @@ -1,220 +0,0 @@ | |||||||
| # textdomain: moretrees |  | ||||||
| # Translation by Carlos Barraza, improvements by David Leal. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### cocos_palm.lua ### |  | ||||||
|  |  | ||||||
| Coconut=Coco |  | ||||||
| Coconut Flower=Flor de Coco |  | ||||||
|  |  | ||||||
| ### crafts.lua ### |  | ||||||
|  |  | ||||||
| Acorn Muffin=Mollete de Bellota |  | ||||||
| Acorn Muffin batter= Masa de Mollete de Bellota |  | ||||||
| Coconut Milk=Leche de Coco |  | ||||||
| Date=Datilera |  | ||||||
| Date & nut snack=Datilera y Nueces |  | ||||||
| Date-nut cake=Pastel de Datilera |  | ||||||
| Date-nut cake batter=Pasta de torta de Datilera |  | ||||||
| Date-nut energy bar=Barra energetica de Datilera |  | ||||||
| Raw Coconut=Coco Crudo |  | ||||||
| Roasted Cedar Cone Nuts=Coco de Álamo Tostado |  | ||||||
| Roasted Fir Cone Nuts=Cono de Abeto Tostado |  | ||||||
| Roasted Spruce Cone Nuts=Cono de Picea Tostado |  | ||||||
|  |  | ||||||
| ### date_palm.lua ### |  | ||||||
|  |  | ||||||
| Date Flowers=Flores de Datilera |  | ||||||
| Date Stem=Tallo de Datilera |  | ||||||
| Dates=Datilera |  | ||||||
|  |  | ||||||
| ### node_defs.lua ### |  | ||||||
|  |  | ||||||
| @1 (fast growth)=@1 (crecimiento rápido) |  | ||||||
| Acorn=Bellota |  | ||||||
| Apple Tree=Árbol de manzana |  | ||||||
| Apple Tree Fence=Valla de manzano |  | ||||||
| Apple Tree Fence Gate=Puerta de Valla de Manzano |  | ||||||
| Apple Tree Fence Rail=Riel de Valla de Manzano |  | ||||||
| Apple Tree Leaves=Hojas de Árbol de Manzana |  | ||||||
| Apple Tree Planks=Madera de Árbol de Manzana |  | ||||||
| Apple Tree Planks Slab=Losa de Tablones de Manzano |  | ||||||
| Apple Tree Planks Stair=Escalera de Tablones de Manzano |  | ||||||
| Apple Tree Sapling=Retoño de Árbol de Manzana |  | ||||||
| Apple Tree Trunk=Tronco de Árbol de Manzana |  | ||||||
| Apple Tree Trunk Slab=Losa de Tronco de Manzano |  | ||||||
| Apple Tree Trunk Stair=Escalera de Tronco de Manzano |  | ||||||
| Beech Tree=Haya |  | ||||||
| Beech Tree Fence=Valla de Haya |  | ||||||
| Beech Tree Fence Gate=Puerta de Valla de Haya |  | ||||||
| Beech Tree Fence Rail=Riel de Valla de Haya |  | ||||||
| Beech Tree Leaves=Hojas de Arbol de Haya |  | ||||||
| Beech Tree Planks=Madera de Arbol de Haya |  | ||||||
| Beech Tree Planks Slab=Losa de Tablones de Haya |  | ||||||
| Beech Tree Planks Stair=Escalera de Tablones de Haya |  | ||||||
| Beech Tree Sapling=Retoño de Árbol de Haya |  | ||||||
| Beech Tree Trunk=Tronco de Árbol de Haya |  | ||||||
| Beech Tree Trunk Slab=Losa de Tronco de Haya |  | ||||||
| Beech Tree Trunk Stair=Escalera de Tronco de Haya |  | ||||||
| Birch Tree=Abedul |  | ||||||
| Birch Tree Fence=Valla de Abedul |  | ||||||
| Birch Tree Fence Gate=Puerta de Valla de Abedul |  | ||||||
| Birch Tree Fence Rail=Riel de Valla de Abedul |  | ||||||
| Birch Tree Leaves=Hojas de Arbol de Abedul |  | ||||||
| Birch Tree Planks=Madera de Arbol de Abedul |  | ||||||
| Birch Tree Planks Slab=Losa de Tablones de Abedul |  | ||||||
| Birch Tree Planks Stair=Escalera de Tablones de Abedul |  | ||||||
| Birch Tree Sapling=Retoño de Árbol de Abedul |  | ||||||
| Birch Tree Trunk=Tronco de Árbol de Abedul |  | ||||||
| Birch Tree Trunk Slab=Losa de Tronco de Abedul |  | ||||||
| Birch Tree Trunk Stair=Escalera de Tronco de Abedul |  | ||||||
| Cedar Cone=Coco de Álamo |  | ||||||
| Cedar Tree=Árbol de Cedro |  | ||||||
| Cedar Tree Fence=Valla de Árbol de Cedro |  | ||||||
| Cedar Tree Fence Gate=Puerta de Valla de Árbol de Cedro |  | ||||||
| Cedar Tree Fence Rail=Riel de Valla de Árbol de Cedro |  | ||||||
| Cedar Tree Leaves=Hojas de Árbol de Cedro |  | ||||||
| Cedar Tree Planks=Madera de Árbol de Cedro |  | ||||||
| Cedar Tree Planks Slab=Losa de Tablones de Árbol de Cedro |  | ||||||
| Cedar Tree Planks Stair=Escalera de Tablones de Árbol de Cedro |  | ||||||
| Cedar Tree Sapling=Retoño de Árbol de Cedro |  | ||||||
| Cedar Tree Trunk=Tronco de Árbol de Cedro |  | ||||||
| Cedar Tree Trunk Slab=Losa de Tronco de Árbol de Cedro |  | ||||||
| Cedar Tree Trunk Stair=Escalera de Tronco de Árbol de Cedro |  | ||||||
| Date Palm Tree=Palmera Datilera |  | ||||||
| Date Palm Tree Fence=Valla de Palmera Datilera |  | ||||||
| Date Palm Tree Fence Gate=Puerta de Valla de Palmera Datilera |  | ||||||
| Date Palm Tree Fence Rail=Riel de Valla de Palmera Datilera |  | ||||||
| Date Palm Tree Leaves=Hojas de Palmera Datilera |  | ||||||
| Date Palm Tree Planks=Madera de Palmera Datilera |  | ||||||
| Date Palm Tree Planks Slab=Losa de Tablones de Palmera Datilera |  | ||||||
| Date Palm Tree Planks Stair=Escalera de Tablones de Palmera Datilera |  | ||||||
| Date Palm Tree Sapling=Retoño de Palmera Datilera |  | ||||||
| Date Palm Tree Trunk=Tronco de Palmera Datilera |  | ||||||
| Date Palm Tree Trunk Slab=Losa de Tronco de Palmera Datilera |  | ||||||
| Date Palm Tree Trunk Stair=Escalera de Tronco de Palmera Datilera |  | ||||||
| Douglas Fir=Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Fence=Valla de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Fence Gate=Puerta de Valla de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Fence Rail=Riel de Valla de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Leaves=Hojas de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Leaves (Bright)=Hojas de Árbol de Abeto de Douglas (Brillante) |  | ||||||
| Douglas Fir Planks=Madera de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Planks Slab=Losa de Tablones de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Planks Stair=Escalera de Tablones de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Sapling=Retoño de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Trunk=Tronco de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Trunk Slab=Losa de Tronco de Árbol de Abeto de Douglas |  | ||||||
| Douglas Fir Trunk Stair=Escalera de Tronco de Árbol de Abeto de Douglas |  | ||||||
| Fir Cone=Coco de Abeto |  | ||||||
| Giant Sequoia=Secuoya Gigante |  | ||||||
| Giant Sequoia Fence=Valla de Secuoya Gigante |  | ||||||
| Giant Sequoia Fence Gate=Puerta de Valla de Secuoya Gigante |  | ||||||
| Giant Sequoia Fence Rail=Riel de Valla de Secuoya Gigante |  | ||||||
| Giant Sequoia Leaves=Hojas de Secuoya Gigante |  | ||||||
| Giant Sequoia Planks=Madera de Secuoya Gigante |  | ||||||
| Giant Sequoia Planks Slab=Losa de Tablones de Secuoya Gigante |  | ||||||
| Giant Sequoia Planks Stair=Escalera de Tablones de Secuoya Gigante |  | ||||||
| Giant Sequoia Sapling=Retoño de Árbol de Secuoya Gigante |  | ||||||
| Giant Sequoia Trunk=Tronco de Secuoya Gigante |  | ||||||
| Giant Sequoia Trunk Slab=Losa de Tronco de Secuoya Gigante |  | ||||||
| Giant Sequoia Trunk Stair=Escalera de Tronco de Secuoya Gigante |  | ||||||
| Jungle Tree=Árbol de la Selva |  | ||||||
| Jungle Tree Fence=Valla de Árbol de la Selva |  | ||||||
| Jungle Tree Fence Gate=Puerta de Valla de Árbol de la Selva |  | ||||||
| Jungle Tree Fence Rail=Riel de Valla de Árbol de la Selva |  | ||||||
| Jungle Tree Leaves=Hojas de Árbol de la Selva |  | ||||||
| Jungle Tree Leaves (@1)=Hojas de Árbol de la Selva (@1) |  | ||||||
| Jungle Tree Planks=Madera de Árbol de la Selva |  | ||||||
| Jungle Tree Planks Slab=Losa de Tablones de Árbol de la Selva |  | ||||||
| Jungle Tree Planks Stair=Escalera de Tablones de Árbol de la Selva |  | ||||||
| Jungle Tree Sapling=Retoño de Árbol de la Selva |  | ||||||
| Jungle Tree Trunk=Tronco de Árbol de Árbol de la Selva |  | ||||||
| Jungle Tree Trunk Slab=Losa de Tronco de Árbol de la Selva |  | ||||||
| Jungle Tree Trunk Stair=Escalera de Tronco de Árbol de la Selva |  | ||||||
| Oak Tree=Árbol de Roble |  | ||||||
| Oak Tree Fence=Valla de Árbol de Roble |  | ||||||
| Oak Tree Fence Gate=Puerta de Valla de Árbol de Roble |  | ||||||
| Oak Tree Fence Rail=Riel de Valla de Árbol de Roble |  | ||||||
| Oak Tree Leaves=Hojas de Árbol de Roble |  | ||||||
| Oak Tree Planks=Madera de Árbol de Roble |  | ||||||
| Oak Tree Planks Slab=Losa de Tablones de Árbol de Roble |  | ||||||
| Oak Tree Planks Stair=Escalera de Tablones de Árbol de Roble |  | ||||||
| Oak Tree Sapling=Retoño de Árbol de Roble |  | ||||||
| Oak Tree Trunk=Tronco de Árbol de Roble |  | ||||||
| Oak Tree Trunk Slab=Losa de Tronco de Árbol de Roble |  | ||||||
| Oak Tree Trunk Stair=Escalera de Tronco de Árbol de Roble |  | ||||||
| Palm Tree=Palmera |  | ||||||
| Palm Tree Fence=Valla de Palmera |  | ||||||
| Palm Tree Fence Gate=Puerta de Valla de Palmera |  | ||||||
| Palm Tree Fence Rail=Riel de Valla de Palmera |  | ||||||
| Palm Tree Leaves=Hojas de Palmera |  | ||||||
| Palm Tree Planks=Madera de Palmera |  | ||||||
| Palm Tree Planks Slab=Losa de Tablones de Palmera |  | ||||||
| Palm Tree Planks Stair=Escalera de Tablones de Palmera |  | ||||||
| Palm Tree Sapling=Retoño de Palmera |  | ||||||
| Palm Tree Trunk=Tronco de Palmera |  | ||||||
| Palm Tree Trunk Slab=Losa de Troncos de Palmera |  | ||||||
| Palm Tree Trunk Stair=Escalera de Troncos de Palmera |  | ||||||
| Poplar Tree=Árbol de Alamo |  | ||||||
| Poplar Tree Fence=Valla de Árbol de Alamo |  | ||||||
| Poplar Tree Fence Gate=Puerta de Valla de Árbol de Alamo |  | ||||||
| Poplar Tree Fence Rail=Riel de Valla de Árbol de Alamo |  | ||||||
| Poplar Tree Leaves=Hojas de Arbol de Alamo |  | ||||||
| Poplar Tree Planks=Madera de Árbol de Alamo |  | ||||||
| Poplar Tree Planks Slab=Losa de Tablones de Árbol de Alamo |  | ||||||
| Poplar Tree Planks Stair=Escalera de Tablones de Árbol de Alamo |  | ||||||
| Poplar Tree Sapling=Retoño de Árbol de Alamo |  | ||||||
| Poplar Tree Trunk=Tronco de Árbol de Alamo |  | ||||||
| Poplar Tree Trunk Slab=Losa de Tronco de Árbol de Alamo |  | ||||||
| Poplar Tree Trunk Stair=Escalera de Tronco de Árbol de Alamo |  | ||||||
| Red=Rojo |  | ||||||
| Rubber Tree=Árbol del Caucho |  | ||||||
| Rubber Tree Fence=Valla de Árbol del Caucho |  | ||||||
| Rubber Tree Fence Gate=Puerta de Valla de Árbol del Caucho |  | ||||||
| Rubber Tree Fence Rail=Riel de Valla de Árbol del Caucho |  | ||||||
| Rubber Tree Leaves=Hojas de Árbol de Árbol del Caucho |  | ||||||
| Rubber Tree Planks=Madera de Árbol de Árbol del Caucho |  | ||||||
| Rubber Tree Planks Slab=Losa de Tablones de Árbol del Caucho |  | ||||||
| Rubber Tree Planks Stair=Escalera de Tablones de Árbol del Caucho |  | ||||||
| Rubber Tree Sapling=Retoño de Árbol de Árbol del Caucho |  | ||||||
| Rubber Tree Trunk=Tronco de Árbol de Árbol del Caucho |  | ||||||
| Rubber Tree Trunk (Empty)=Tronco de Árbol del Caucho (Vacío) |  | ||||||
| Rubber Tree Trunk Slab=Losa de Tronco de Árbol del Caucho |  | ||||||
| Rubber Tree Trunk Stair=Escalera de Tronco de Árbol del Caucho |  | ||||||
| Small poplar Tree Sapling=Pequeño Retoño de Álamo |  | ||||||
| Spruce Cone=Coco de Picea |  | ||||||
| Spruce Tree=Árbol de Abeto |  | ||||||
| Spruce Tree Fence=Valla de Árbol de Abeto |  | ||||||
| Spruce Tree Fence Gate=Puerta de Valla de Árbol de Abeto |  | ||||||
| Spruce Tree Fence Rail=Riel de Valla de Árbol de Abeto |  | ||||||
| Spruce Tree Leaves=Hojas de Árbol de Abeto |  | ||||||
| Spruce Tree Planks=Madera de Árbol de Abeto |  | ||||||
| Spruce Tree Planks Slab=Losa de Tablones de Árbol de Abeto |  | ||||||
| Spruce Tree Planks Stair=Escalera de Tablones de Árbol de Abeto |  | ||||||
| Spruce Tree Sapling=Retoño de Árbol de Abeto |  | ||||||
| Spruce Tree Trunk=Tronco de Árbol de Abeto |  | ||||||
| Spruce Tree Trunk Slab=Losa de Tronco de Árbol de Abeto |  | ||||||
| Spruce Tree Trunk Stair=Escalera de Tronco de Árbol de Abeto |  | ||||||
| Willow Tree=Árbol de Sauce |  | ||||||
| Willow Tree Fence=Valla de Árbol de Sauce |  | ||||||
| Willow Tree Fence Gate=Puerta de Valla de Árbol de Sauce |  | ||||||
| Willow Tree Fence Rail=Riel de Valla de Árbol de Sauce |  | ||||||
| Willow Tree Leaves=Hojas de Árbol de Sauce |  | ||||||
| Willow Tree Planks=Madera de Árbol de Sauce |  | ||||||
| Willow Tree Planks Slab=Losa de Tablones de Árbol de Sauce |  | ||||||
| Willow Tree Planks Stair=Escalera de Tablones de Árbol de Sauce |  | ||||||
| Willow Tree Sapling=Retoño de Árbol de Sauce |  | ||||||
| Willow Tree Trunk=Tronco de Árbol de Sauce |  | ||||||
| Willow Tree Trunk Slab=Losa de Tronco de Árbol de Sauce |  | ||||||
| Willow Tree Trunk Stair=Escalera de Tronco de Árbol de Sauce |  | ||||||
| Yellow=Amarillo |  | ||||||
|  |  | ||||||
| # init.lua |  | ||||||
| Sapling=Retoño |  | ||||||
| Tree=Árbol |  | ||||||
| Wooden Planks=Tablones |  | ||||||
| Leaves=Hojas |  | ||||||
| Wooden Fence=Valla |  | ||||||
| Wooden Fence Rail=Riel de Valla |  | ||||||
| Wooden Fence Gate=Puerta de Valla |  | ||||||
| @@ -1,220 +0,0 @@ | |||||||
| # textdomain: moretrees |  | ||||||
| # Translation by Yoan31 and Louis Royer |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### cocos_palm.lua ### |  | ||||||
|  |  | ||||||
| Coconut=Noix de coco |  | ||||||
| Coconut Flower=Fleur de coco |  | ||||||
|  |  | ||||||
| ### crafts.lua ### |  | ||||||
|  |  | ||||||
| Acorn Muffin=Muffins au gland |  | ||||||
| Acorn Muffin batter=Pate à muffins au Gland |  | ||||||
| Coconut Milk=Lait de coco |  | ||||||
| Date=Datte |  | ||||||
| Date & nut snack=Collation aux dattes et aux noix |  | ||||||
| Date-nut cake=Gâteau datte-noix |  | ||||||
| Date-nut cake batter=Pâte à gâteau datte-noix |  | ||||||
| Date-nut energy bar=Barre énergétique datte-noix |  | ||||||
| Raw Coconut=Noix de coco crue |  | ||||||
| Roasted Cedar Cone Nuts=Noix de pomme de pin roties |  | ||||||
| Roasted Fir Cone Nuts=Noix de cône de sapin roties |  | ||||||
| Roasted Spruce Cone Nuts=Noix de cône de sapin roties |  | ||||||
|  |  | ||||||
| ### date_palm.lua ### |  | ||||||
|  |  | ||||||
| Date Flowers=Fleurs de datte |  | ||||||
| Date Stem=Tige de datte |  | ||||||
| Dates=Dattes |  | ||||||
|  |  | ||||||
| ### node_defs.lua ### |  | ||||||
|  |  | ||||||
| @1 (fast growth)=@1 (croissance rapide) |  | ||||||
| Acorn=Gland |  | ||||||
| Apple Tree=Pommier |  | ||||||
| Apple Tree Fence=Barrière en bois de pommier |  | ||||||
| Apple Tree Fence Gate=Porte de clôture en bois de pommier |  | ||||||
| Apple Tree Fence Rail=Clôture en bois de pommier |  | ||||||
| Apple Tree Leaves=Feuilles de pommier |  | ||||||
| Apple Tree Planks=Planches de pommier |  | ||||||
| Apple Tree Planks Slab=Dalle en bois de pommier |  | ||||||
| Apple Tree Planks Stair=Escaliers en bois de pommier |  | ||||||
| Apple Tree Sapling=Pousse d'arbre de pommier |  | ||||||
| Apple Tree Trunk=Tronc d'arbre de pommier |  | ||||||
| Apple Tree Trunk Slab=Dalle en tronc de pommier |  | ||||||
| Apple Tree Trunk Stair=Escalier en tronc de pommier |  | ||||||
| Beech Tree=Hêtre |  | ||||||
| Beech Tree Fence=Barrière en bois de hêtre |  | ||||||
| Beech Tree Fence Gate=Porte de clôture en bois de hêtre |  | ||||||
| Beech Tree Fence Rail=Clôture en bois de hêtre |  | ||||||
| Beech Tree Leaves=Feuilles de hêtre |  | ||||||
| Beech Tree Planks=Planches de hêtre |  | ||||||
| Beech Tree Planks Slab=Dalle en bois de hêtre |  | ||||||
| Beech Tree Planks Stair=Escalier en bois de hêtre |  | ||||||
| Beech Tree Sapling=Pousse d'arbre de hêtre |  | ||||||
| Beech Tree Trunk=Tronc d'arbre de hêtre |  | ||||||
| Beech Tree Trunk Slab=Dalle en tronc de hêtre |  | ||||||
| Beech Tree Trunk Stair=Escalier en tronc de hêtre |  | ||||||
| Birch Tree=Bouleau |  | ||||||
| Birch Tree Fence=Barrière en bois de bouleau |  | ||||||
| Birch Tree Fence Gate=Porte de clôture en bois de bouleau |  | ||||||
| Birch Tree Fence Rail=Clôture en bois de bouleau |  | ||||||
| Birch Tree Leaves=Feuilles de bouleau |  | ||||||
| Birch Tree Planks=Planches d'arbre de bouleau |  | ||||||
| Birch Tree Planks Slab=Dalle en bois de bouleau |  | ||||||
| Birch Tree Planks Stair=Escalier en bois de bouleau |  | ||||||
| Birch Tree Sapling=Pousse d'arbre de bouleau |  | ||||||
| Birch Tree Trunk=Tronc d'arbre de bouleau |  | ||||||
| Birch Tree Trunk Slab=Dalle en tronc de bouleau |  | ||||||
| Birch Tree Trunk Stair=Escalier en tronc de bouleau |  | ||||||
| Cedar Cone=Pomme de pin |  | ||||||
| Cedar Tree=Pin |  | ||||||
| Cedar Tree Fence=Barrière en bois de pin |  | ||||||
| Cedar Tree Fence Gate=Porte de clôture en bois de pin |  | ||||||
| Cedar Tree Fence Rail=Clôture en bois de pin |  | ||||||
| Cedar Tree Leaves=Feuilles de pin |  | ||||||
| Cedar Tree Planks=Planches d'arbre de pin |  | ||||||
| Cedar Tree Planks Slab=Dalle en bois de pin |  | ||||||
| Cedar Tree Planks Stair=Escalier en bois de pin |  | ||||||
| Cedar Tree Sapling=Pousse d'arbre de pin |  | ||||||
| Cedar Tree Trunk=Tronc d'arbre de pin |  | ||||||
| Cedar Tree Trunk Slab=Dalle en tronc de pin |  | ||||||
| Cedar Tree Trunk Stair=Escalier en tronc de pin |  | ||||||
| Date Palm Tree=Dattier |  | ||||||
| Date Palm Tree Fence=Barrière en bois de dattier |  | ||||||
| Date Palm Tree Fence Gate=Porte de clôture en bois de dattier |  | ||||||
| Date Palm Tree Fence Rail=Clôture en bois de dattier |  | ||||||
| Date Palm Tree Leaves=Feuille de dattier |  | ||||||
| Date Palm Tree Planks=Planches de dattier |  | ||||||
| Date Palm Tree Planks Slab=Dalle en bois de dattier |  | ||||||
| Date Palm Tree Planks Stair=Escalier en bois de dattier |  | ||||||
| Date Palm Tree Sapling=Pousse de dattier |  | ||||||
| Date Palm Tree Trunk=Tronc de dattier |  | ||||||
| Date Palm Tree Trunk Slab=Dalle en tronc de dattier |  | ||||||
| Date Palm Tree Trunk Stair=Escalier en tronc de dattier |  | ||||||
| Douglas Fir=Sapin de Douglas |  | ||||||
| Douglas Fir Fence=Barrière en bois de sapin de Douglas |  | ||||||
| Douglas Fir Fence Gate=Porte de clôture en bois de sapin de Douglas |  | ||||||
| Douglas Fir Fence Rail=Clôture en bois de sapin de Douglas |  | ||||||
| Douglas Fir Leaves=Feuilles de sapin de Douglas |  | ||||||
| Douglas Fir Leaves (Bright)=Feuille de sapin de Douglas (brillant) |  | ||||||
| Douglas Fir Planks=Planches de sapin de Douglas |  | ||||||
| Douglas Fir Planks Slab=Dalle en bois de sapin de Douglas |  | ||||||
| Douglas Fir Planks Stair=Escalier en bois de sapin de Douglas |  | ||||||
| Douglas Fir Sapling=Pousse de sapin de Douglas |  | ||||||
| Douglas Fir Trunk=Tronc de sapin de Douglas |  | ||||||
| Douglas Fir Trunk Slab=Dalle en tronc de sapin de Douglas |  | ||||||
| Douglas Fir Trunk Stair=Escalier en tronc de sapin de Douglas |  | ||||||
| Fir Cone=Pomme de sapin |  | ||||||
| Giant Sequoia=Séquoia géant |  | ||||||
| Giant Sequoia Fence=Barrière en bois de séquoia géant |  | ||||||
| Giant Sequoia Fence Gate=Porte de clôture en bois de séquoia géant |  | ||||||
| Giant Sequoia Fence Rail=Clôture en bois de séquoia géant |  | ||||||
| Giant Sequoia Leaves=Feuilles de séquoia géant |  | ||||||
| Giant Sequoia Planks=Planches de séquoia géant |  | ||||||
| Giant Sequoia Planks Slab=Dalle en bois de séquoia géant |  | ||||||
| Giant Sequoia Planks Stair=Escalier en bois de séquoia géant |  | ||||||
| Giant Sequoia Sapling=Pousse de séquoia géant |  | ||||||
| Giant Sequoia Trunk=Tronc de séquoia géant |  | ||||||
| Giant Sequoia Trunk Slab=Dalle en tronc de séquoia géant |  | ||||||
| Giant Sequoia Trunk Stair=Escalier en tronc de séquoia géant |  | ||||||
| Jungle Tree=Arbre de la jungle |  | ||||||
| Jungle Tree Fence=Barrière en bois d'arbre de la jungle |  | ||||||
| Jungle Tree Fence Gate=Porte de clôture en bois d'arbre de la jungle |  | ||||||
| Jungle Tree Fence Rail=Clôture en bois d'arbre de la jungle |  | ||||||
| Jungle Tree Leaves=Feuilles d'arbre de la jungle |  | ||||||
| Jungle Tree Leaves (@1)=Feuilles d'arbre de la jungle (@1) |  | ||||||
| Jungle Tree Planks=Planches d'arbre de la jungle |  | ||||||
| Jungle Tree Planks Slab=Dalle en bois d'arbre de la jungle |  | ||||||
| Jungle Tree Planks Stair=Escalier en bois d'arbre de la jungle |  | ||||||
| Jungle Tree Sapling=Pousse d'arbre de la jungle |  | ||||||
| Jungle Tree Trunk=Tronc d'arbre de la jungle |  | ||||||
| Jungle Tree Trunk Slab=Dalle en tronc d'arbre de la jungle |  | ||||||
| Jungle Tree Trunk Stair=Escalier en tronc d'arbre de la jungle |  | ||||||
| Oak Tree=Chêne |  | ||||||
| Oak Tree Fence=Barrière en bois de chêne |  | ||||||
| Oak Tree Fence Gate=Porte de clôture en bois de chêne |  | ||||||
| Oak Tree Fence Rail=Clôture en bois de chêne |  | ||||||
| Oak Tree Leaves=Feuilles de chêne |  | ||||||
| Oak Tree Planks=Planches de chêne |  | ||||||
| Oak Tree Planks Slab=Dalle en bois de chêne |  | ||||||
| Oak Tree Planks Stair=Escalier en bois de chêne |  | ||||||
| Oak Tree Sapling=Pousse d'arbre de chêne |  | ||||||
| Oak Tree Trunk=Tronc d'arbre de chêne |  | ||||||
| Oak Tree Trunk Slab=Dalle en tronc de chêne |  | ||||||
| Oak Tree Trunk Stair=Escalier en tronc de chêne |  | ||||||
| Palm Tree=Palmier |  | ||||||
| Palm Tree Fence=Barrière en bois de palmier |  | ||||||
| Palm Tree Fence Gate=Porte de clôture en bois de palmier |  | ||||||
| Palm Tree Fence Rail=Clôture en bois de palmier |  | ||||||
| Palm Tree Leaves=Feuilles de palmier |  | ||||||
| Palm Tree Planks=Planches de palmier |  | ||||||
| Palm Tree Planks Slab=Dalle en bois de palmier |  | ||||||
| Palm Tree Planks Stair=Escalier en bois de palmier |  | ||||||
| Palm Tree Sapling=Pousse d'arbre de palmier |  | ||||||
| Palm Tree Trunk=Tronc d'arbre de palmier |  | ||||||
| Palm Tree Trunk Slab=Dalle en tronc de palmier |  | ||||||
| Palm Tree Trunk Stair=Escalier en tronc de palmier |  | ||||||
| Poplar Tree=Peuplier |  | ||||||
| Poplar Tree Fence=Barrière en bois de peuplier |  | ||||||
| Poplar Tree Fence Gate=Porte de clôture en bois de peuplier |  | ||||||
| Poplar Tree Fence Rail=Clôture en bois de peuplier |  | ||||||
| Poplar Tree Leaves=Feuilles de peuplier |  | ||||||
| Poplar Tree Planks=Plances de peuplier |  | ||||||
| Poplar Tree Planks Slab=Dalle en bois de peuplier |  | ||||||
| Poplar Tree Planks Stair=Escalier en bois de peuplier |  | ||||||
| Poplar Tree Sapling=Pousse de peuplier |  | ||||||
| Poplar Tree Trunk=Tronc de peuplier |  | ||||||
| Poplar Tree Trunk Slab=Dalle en tronc de peuplier |  | ||||||
| Poplar Tree Trunk Stair=Escalier en tronc de peuplier |  | ||||||
| Red=rouge |  | ||||||
| Rubber Tree=Arbre à caoutchouc |  | ||||||
| Rubber Tree Fence=Barrière en bois d'arbre à caoutchouc |  | ||||||
| Rubber Tree Fence Gate=Porte de clôture en bois d'arbre à caoutchouc |  | ||||||
| Rubber Tree Fence Rail=Clôture en bois d'arbre à caoutchouc |  | ||||||
| Rubber Tree Leaves=Feuilles d'arbre à caoutchouc |  | ||||||
| Rubber Tree Planks=Planches d'arbre à caoutchouc |  | ||||||
| Rubber Tree Planks Slab=Dalle en bois d'arbre à caoutchouc |  | ||||||
| Rubber Tree Planks Stair=Escalier en bois d'arbre à caoutchouc |  | ||||||
| Rubber Tree Sapling=Pousse d'arbre à caoutchouc |  | ||||||
| Rubber Tree Trunk=Tronc d'arbre a caoutchouc |  | ||||||
| Rubber Tree Trunk (Empty)=Tronc d'arbre à caoutchouc (vide) |  | ||||||
| Rubber Tree Trunk Slab=Dalle en tronc d'arbre à caoutchouc |  | ||||||
| Rubber Tree Trunk Stair=Escalier en tronc d'arbre à caoutchouc |  | ||||||
| Small poplar Tree Sapling=Pousse de petit peuplier |  | ||||||
| Spruce Cone=Cône de sapin |  | ||||||
| Spruce Tree=Épicéa |  | ||||||
| Spruce Tree Fence=Barrière en bois d'épicéa |  | ||||||
| Spruce Tree Fence Gate=Porte de clôture en bois d'épicéa |  | ||||||
| Spruce Tree Fence Rail=Clôture en bois d'épicéa |  | ||||||
| Spruce Tree Leaves=Feuilles d'épicéa |  | ||||||
| Spruce Tree Planks=Planches d'arbre d'épicéa |  | ||||||
| Spruce Tree Planks Slab=Dalle en bois d'épicéa |  | ||||||
| Spruce Tree Planks Stair=Escalier en bois d'épicéa |  | ||||||
| Spruce Tree Sapling=Pousse d'arbre d'épicéa |  | ||||||
| Spruce Tree Trunk=Tronc d'arbre d'épicéa |  | ||||||
| Spruce Tree Trunk Slab=Dalle en tronc d'épicéa |  | ||||||
| Spruce Tree Trunk Stair=Escalier en tronc d'épicéa |  | ||||||
| Willow Tree=Saule |  | ||||||
| Willow Tree Fence=Barrière en bois de saule |  | ||||||
| Willow Tree Fence Gate=Porte de clôture en bois de saule |  | ||||||
| Willow Tree Fence Rail=Clôture en bois de saule |  | ||||||
| Willow Tree Leaves=Feuilles de saule |  | ||||||
| Willow Tree Planks=Planches de saule |  | ||||||
| Willow Tree Planks Slab=Dalle en bois de saule |  | ||||||
| Willow Tree Planks Stair=Escalier en bois de saule |  | ||||||
| Willow Tree Sapling=Pousse de saule |  | ||||||
| Willow Tree Trunk=Tronc d'arbre de saule |  | ||||||
| Willow Tree Trunk Slab=Dalle en tronc de saule |  | ||||||
| Willow Tree Trunk Stair=Escalier en tronc de saule |  | ||||||
| Yellow=jaune |  | ||||||
|  |  | ||||||
| # init.lua |  | ||||||
| Sapling=Jeune Arbre |  | ||||||
| Tree=Arbre |  | ||||||
| Wooden Planks=Planches |  | ||||||
| Leaves=Feuilles |  | ||||||
| Wooden Fence=Barrière en bois |  | ||||||
| Wooden Fence Rail=Rail de clôture en bois |  | ||||||
| Wooden Fence Gate=Porte de clôture en bois |  | ||||||
| @@ -1,219 +0,0 @@ | |||||||
| # textdomain: moretrees |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ### cocos_palm.lua ### |  | ||||||
|  |  | ||||||
| Coconut=Кокос |  | ||||||
| Coconut Flower=Цветок кокоса |  | ||||||
|  |  | ||||||
| ### crafts.lua ### |  | ||||||
|  |  | ||||||
| Acorn Muffin=Маффин с желудями |  | ||||||
| Acorn Muffin batter=Тесто для маффина с желудями |  | ||||||
| Coconut Milk=Кокосовое молоко |  | ||||||
| Date=Финик |  | ||||||
| Date & nut snack=Закуска из фиников и орехов |  | ||||||
| Date-nut cake=Финиково-ореховый пирог |  | ||||||
| Date-nut cake batter=Тесто для финиково-орехового пирога |  | ||||||
| Date-nut energy bar=Финиково-ореховый батончик |  | ||||||
| Raw Coconut=Сырой кокос |  | ||||||
| Roasted Cedar Cone Nuts=Жареные кедровые орешки |  | ||||||
| Roasted Fir Cone Nuts=Жареные орешки пихты |  | ||||||
| Roasted Spruce Cone Nuts=Жареные еловые орешки |  | ||||||
|  |  | ||||||
| ### date_palm.lua ### |  | ||||||
|  |  | ||||||
| Date Flowers=Цветки фиников |  | ||||||
| Date Stem=Стебель финика |  | ||||||
| Dates=Финики |  | ||||||
|  |  | ||||||
| ### node_defs.lua ### |  | ||||||
|  |  | ||||||
| @1 (fast growth)=@1 (бестрый рост) |  | ||||||
| Acorn=Желудь |  | ||||||
| Apple Tree=Яблоня |  | ||||||
| Apple Tree Fence=Яблоневый забор |  | ||||||
| Apple Tree Fence Gate=Яблоневые ворота |  | ||||||
| Apple Tree Fence Rail=Яблоневые перила |  | ||||||
| Apple Tree Leaves=Листья яблони |  | ||||||
| Apple Tree Planks=Яблоневые доски |  | ||||||
| Apple Tree Planks Slab=Яблоневые доски (плита) |  | ||||||
| Apple Tree Planks Stair=Яблоневые доски (ступени) |  | ||||||
| Apple Tree Sapling=Саженец яблони |  | ||||||
| Apple Tree Trunk=Ствол яблони |  | ||||||
| Apple Tree Trunk Slab=Ствол яблони (плита) |  | ||||||
| Apple Tree Trunk Stair=Ствол яблони (ступени) |  | ||||||
| Beech Tree=Бук |  | ||||||
| Beech Tree Fence=Забор из бука |  | ||||||
| Beech Tree Fence Gate=Ворота из бука |  | ||||||
| Beech Tree Fence Rail=Перила из бука |  | ||||||
| Beech Tree Leaves=Листья бука |  | ||||||
| Beech Tree Planks=Доски из бука |  | ||||||
| Beech Tree Planks Slab=Доски из бука (плита) |  | ||||||
| Beech Tree Planks Stair=Доски из бука (ступени) |  | ||||||
| Beech Tree Sapling=Саженец бука |  | ||||||
| Beech Tree Trunk=Ствол бука |  | ||||||
| Beech Tree Trunk Slab=Ствол бука (плита) |  | ||||||
| Beech Tree Trunk Stair=Ствол бука (ступени) |  | ||||||
| Birch Tree=Береза |  | ||||||
| Birch Tree Fence=Березовый забор |  | ||||||
| Birch Tree Fence Gate=Березовые ворота |  | ||||||
| Birch Tree Fence Rail=Березовые перила |  | ||||||
| Birch Tree Leaves=Березовые листья |  | ||||||
| Birch Tree Planks=Березовые доски |  | ||||||
| Birch Tree Planks Slab=Березовые доски (плита) |  | ||||||
| Birch Tree Planks Stair=Березовые доски (ступени) |  | ||||||
| Birch Tree Sapling=Саженец березы |  | ||||||
| Birch Tree Trunk=Ствол березы |  | ||||||
| Birch Tree Trunk Slab=Ствол березы (плита) |  | ||||||
| Birch Tree Trunk Stair=Ствол березы (ступени) |  | ||||||
| Cedar Cone=Кедровая шишка |  | ||||||
| Cedar Tree=Кедр |  | ||||||
| Cedar Tree Fence=Забор из кедра |  | ||||||
| Cedar Tree Fence Gate=Ворота из кедра |  | ||||||
| Cedar Tree Fence Rail=Перила из кедра |  | ||||||
| Cedar Tree Leaves=Кедровая хвоя |  | ||||||
| Cedar Tree Planks=Доски из кедра |  | ||||||
| Cedar Tree Planks Slab=Доски из кедра (плита) |  | ||||||
| Cedar Tree Planks Stair=Доски из кедра (ступени) |  | ||||||
| Cedar Tree Sapling=Саженец кедра |  | ||||||
| Cedar Tree Trunk=Ствол кедра |  | ||||||
| Cedar Tree Trunk Slab=Ствол кедра (плита) |  | ||||||
| Cedar Tree Trunk Stair=Ствол кедра (ступени) |  | ||||||
| Date Palm Tree=Финиковая пальма |  | ||||||
| Date Palm Tree Fence=Забор из финиковой пальмы |  | ||||||
| Date Palm Tree Fence Gate=Ворота из финиковой пальмы |  | ||||||
| Date Palm Tree Fence Rail=Перила из финиковой пальмы |  | ||||||
| Date Palm Tree Leaves=Листья финиковой пальмы |  | ||||||
| Date Palm Tree Planks=Доски из финиковой пальмы |  | ||||||
| Date Palm Tree Planks Slab=Доски из финиковой пальмы (плита) |  | ||||||
| Date Palm Tree Planks Stair=Доски из финиковой пальмы (ступени) |  | ||||||
| Date Palm Tree Sapling=Саженец финиковой пальмы |  | ||||||
| Date Palm Tree Trunk=Ствол финиковой пальмы |  | ||||||
| Date Palm Tree Trunk Slab=Ствол финиковой пальмы (плита) |  | ||||||
| Date Palm Tree Trunk Stair=Ствол финиковой пальмы (ступени) |  | ||||||
| Douglas Fir=Дугласова пихта |  | ||||||
| Douglas Fir Fence=Забор из дугласовой пихты |  | ||||||
| Douglas Fir Fence Gate=Ворота из дугласовой пихты |  | ||||||
| Douglas Fir Fence Rail=Перила из дугласовой пихты |  | ||||||
| Douglas Fir Leaves=Хвоя дугласовой пихты |  | ||||||
| Douglas Fir Leaves (Bright)=Листья дугласовой пихты (яркие) |  | ||||||
| Douglas Fir Planks=Доски из дугласовой пихты |  | ||||||
| Douglas Fir Planks Slab=Доски из дугласовой пихты (плита) |  | ||||||
| Douglas Fir Planks Stair=Доски из дугласовой пихты (ступени) |  | ||||||
| Douglas Fir Sapling=Саженец дугласовой пихты |  | ||||||
| Douglas Fir Trunk=Ствол дугласовой пихты |  | ||||||
| Douglas Fir Trunk Slab=Ствол дугласовой пихты (плита) |  | ||||||
| Douglas Fir Trunk Stair=Ствол дугласовой пихты (ступени) |  | ||||||
| Fir Cone=Пихтовая шишка |  | ||||||
| Giant Sequoia=Гигантская секвойя |  | ||||||
| Giant Sequoia Fence=Забор из гигантской секвойи |  | ||||||
| Giant Sequoia Fence Gate=Ворота из гигантской секвойи |  | ||||||
| Giant Sequoia Fence Rail=Перила из гигантской секвойи |  | ||||||
| Giant Sequoia Leaves=Хвоя гигантской секвойи |  | ||||||
| Giant Sequoia Planks=Доски из гигантской секвойи |  | ||||||
| Giant Sequoia Planks Slab=Доски из гигантской секвойи (плита) |  | ||||||
| Giant Sequoia Planks Stair=Доски из гигантской секвойи (ступени) |  | ||||||
| Giant Sequoia Sapling=Саженец гигантской секвойи |  | ||||||
| Giant Sequoia Trunk=Ствол гигантской секвойи |  | ||||||
| Giant Sequoia Trunk Slab=Ствол гигантской секвойи (плита) |  | ||||||
| Giant Sequoia Trunk Stair=Ствол гигантской секвойи (ступени) |  | ||||||
| Jungle Tree=Тропическое дерево |  | ||||||
| Jungle Tree Fence=Забор из тропического дерева |  | ||||||
| Jungle Tree Fence Gate=Ворота из тропического дерева |  | ||||||
| Jungle Tree Fence Rail=Перила из тропического дерева |  | ||||||
| Jungle Tree Leaves=Листья тропического дерева |  | ||||||
| Jungle Tree Leaves (@1)=Листья тропического дерева (@1) |  | ||||||
| Jungle Tree Planks=Доски из тропического дерева |  | ||||||
| Jungle Tree Planks Slab=Доски из тропического дерева (плита) |  | ||||||
| Jungle Tree Planks Stair=Доски из тропического дерева (ступени) |  | ||||||
| Jungle Tree Sapling=Саженец тропического дерева |  | ||||||
| Jungle Tree Trunk=Ствол тропического дерева |  | ||||||
| Jungle Tree Trunk Slab=Ствол тропического дерева (плита) |  | ||||||
| Jungle Tree Trunk Stair=Ствол тропического дерева (ступени) |  | ||||||
| Oak Tree=Дуб |  | ||||||
| Oak Tree Fence=Дубовый забор |  | ||||||
| Oak Tree Fence Gate=Дубовые ворота |  | ||||||
| Oak Tree Fence Rail=Дубовые перила |  | ||||||
| Oak Tree Leaves=Листья дуба |  | ||||||
| Oak Tree Planks=Дубовые доски |  | ||||||
| Oak Tree Planks Slab=Дубовые доски (плита) |  | ||||||
| Oak Tree Planks Stair=Дубовые доски (ступени) |  | ||||||
| Oak Tree Sapling=Саженец дуба |  | ||||||
| Oak Tree Trunk=Ствол дуба |  | ||||||
| Oak Tree Trunk Slab=Ствол дуба (плита) |  | ||||||
| Oak Tree Trunk Stair=Ствол дуба (ступени) |  | ||||||
| Palm Tree=Пальма |  | ||||||
| Palm Tree Fence=Пальмовый забор |  | ||||||
| Palm Tree Fence Gate=Пальмовые ворота |  | ||||||
| Palm Tree Fence Rail=Пальмовые перила |  | ||||||
| Palm Tree Leaves=Листья пальмы |  | ||||||
| Palm Tree Planks=Пальмовые доски |  | ||||||
| Palm Tree Planks Slab=Пальмовые доски (плита) |  | ||||||
| Palm Tree Planks Stair=Пальмовые доски (ступени) |  | ||||||
| Palm Tree Sapling=Саженец пальмы |  | ||||||
| Palm Tree Trunk=Ствол пальмы |  | ||||||
| Palm Tree Trunk Slab=Ствол пальмы (плита) |  | ||||||
| Palm Tree Trunk Stair=Ствол пальмы (ступени) |  | ||||||
| Poplar Tree=Тополь |  | ||||||
| Poplar Tree Fence=Забор из тополя |  | ||||||
| Poplar Tree Fence Gate=Ворота из тополя |  | ||||||
| Poplar Tree Fence Rail=Перила из тополя |  | ||||||
| Poplar Tree Leaves=Листья тополя |  | ||||||
| Poplar Tree Planks=Доски из тополя |  | ||||||
| Poplar Tree Planks Slab=Доски из тополя (плита) |  | ||||||
| Poplar Tree Planks Stair=Доски из тополя (ступени) |  | ||||||
| Poplar Tree Sapling=Саженец тополя |  | ||||||
| Poplar Tree Trunk=Ствол тополя |  | ||||||
| Poplar Tree Trunk Slab=Ствол тополя (плита) |  | ||||||
| Poplar Tree Trunk Stair=Ствол тополя (ступени) |  | ||||||
| Red=красные |  | ||||||
| Rubber Tree=Каучуковое дерево |  | ||||||
| Rubber Tree Fence=Забор из каучукового дерева |  | ||||||
| Rubber Tree Fence Gate=Ворота из каучукового дерева |  | ||||||
| Rubber Tree Fence Rail=Перила из каучукового дерева |  | ||||||
| Rubber Tree Leaves=Листья каучукового дерева |  | ||||||
| Rubber Tree Planks=Доски из каучукового дерева |  | ||||||
| Rubber Tree Planks Slab=Доски из каучукового дерева (плита) |  | ||||||
| Rubber Tree Planks Stair=Доски из каучукового дерева (ступени) |  | ||||||
| Rubber Tree Sapling=Саженец каучукового дерева |  | ||||||
| Rubber Tree Trunk=Ствол каучукового дерева |  | ||||||
| Rubber Tree Trunk (Empty)=Ствол каучукового дерева (пусто) |  | ||||||
| Rubber Tree Trunk Slab=Ствол каучукового дерева (плита) |  | ||||||
| Rubber Tree Trunk Stair=Ствол каучукового дерева (ступени) |  | ||||||
| Small poplar Tree Sapling=Малы саженец тополя |  | ||||||
| Spruce Cone=Еловая шишка |  | ||||||
| Spruce Tree=Ель |  | ||||||
| Spruce Tree Fence=Еловый забор |  | ||||||
| Spruce Tree Fence Gate=Еловые ворота |  | ||||||
| Spruce Tree Fence Rail=Еловые перила |  | ||||||
| Spruce Tree Leaves=Еловая хвоя |  | ||||||
| Spruce Tree Planks=Еловые доски |  | ||||||
| Spruce Tree Planks Slab=Еловые доски (плита) |  | ||||||
| Spruce Tree Planks Stair=Еловые доски (ступени) |  | ||||||
| Spruce Tree Sapling=Саженец ели |  | ||||||
| Spruce Tree Trunk=Ствол ели |  | ||||||
| Spruce Tree Trunk Slab=Ствол ели (плита) |  | ||||||
| Spruce Tree Trunk Stair=Ствол ели (ступени) |  | ||||||
| Willow Tree=Ива |  | ||||||
| Willow Tree Fence=Ивовый забор |  | ||||||
| Willow Tree Fence Gate=Ивовые ворота |  | ||||||
| Willow Tree Fence Rail=Ивовые перила |  | ||||||
| Willow Tree Leaves=Листья ивы |  | ||||||
| Willow Tree Planks=Ивовые доски |  | ||||||
| Willow Tree Planks Slab=Ивовые доски (плита) |  | ||||||
| Willow Tree Planks Stair=Ивовые доски (ступени) |  | ||||||
| Willow Tree Sapling=Саженец ивы |  | ||||||
| Willow Tree Trunk=Ствол ивы |  | ||||||
| Willow Tree Trunk Slab=Ствол ивы (плита) |  | ||||||
| Willow Tree Trunk Stair=Ствол ивы (ступени) |  | ||||||
| Yellow=желтые |  | ||||||
|  |  | ||||||
| # init.lua |  | ||||||
| Sapling=Саженец |  | ||||||
| Tree=Дерево |  | ||||||
| Wooden Planks=Деревянные доски |  | ||||||
| Leaves=Листья |  | ||||||
| Wooden Fence=Деревянный забор |  | ||||||
| Wooden Fence Rail=Деревянные перила |  | ||||||
| Wooden Fence Gate=Деревянные ворота |  | ||||||
| @@ -1,219 +1,74 @@ | |||||||
| # textdomain: moretrees | # Template | ||||||
|  |  | ||||||
|  |  | ||||||
| ### cocos_palm.lua ### |  | ||||||
|  |  | ||||||
| Coconut= |  | ||||||
| Coconut Flower= |  | ||||||
|  |  | ||||||
| ### crafts.lua ### | ### crafts.lua ### | ||||||
|  |  | ||||||
| Acorn Muffin= |  | ||||||
| Acorn Muffin batter= |  | ||||||
| Coconut Milk =  | Coconut Milk =  | ||||||
| Date= |  | ||||||
| Date & nut snack= |  | ||||||
| Date-nut cake= |  | ||||||
| Date-nut cake batter= |  | ||||||
| Date-nut energy bar= |  | ||||||
| Raw Coconut =  | Raw Coconut =  | ||||||
| Roasted Cedar Cone Nuts= | Acorn Muffin batter =  | ||||||
| Roasted Fir Cone Nuts= | Acorn Muffin =  | ||||||
| Roasted Spruce Cone Nuts =  | Roasted Spruce Cone Nuts =  | ||||||
|  | Roasted Pine Cone Nuts =  | ||||||
| ### date_palm.lua ### | Roasted Fir Cone Nuts =  | ||||||
|  |  | ||||||
| Date Flowers= |  | ||||||
| Date Stem= |  | ||||||
| Dates= |  | ||||||
|  |  | ||||||
| ### node_defs.lua ### | ### node_defs.lua ### | ||||||
|  |  | ||||||
| @1 (fast growth)= |  | ||||||
| Acorn= |  | ||||||
| Apple Tree= |  | ||||||
| Apple Tree Fence= |  | ||||||
| Apple Tree Fence Gate= |  | ||||||
| Apple Tree Fence Rail= |  | ||||||
| Apple Tree Leaves= |  | ||||||
| Apple Tree Planks= |  | ||||||
| Apple Tree Planks Slab= |  | ||||||
| Apple Tree Planks Stair= |  | ||||||
| Apple Tree Sapling= |  | ||||||
| Apple Tree Trunk= |  | ||||||
| Apple Tree Trunk Slab= |  | ||||||
| Apple Tree Trunk Stair= |  | ||||||
| Beech Tree= |  | ||||||
| Beech Tree Fence= |  | ||||||
| Beech Tree Fence Gate= |  | ||||||
| Beech Tree Fence Rail= |  | ||||||
| Beech Tree Leaves= |  | ||||||
| Beech Tree Planks= |  | ||||||
| Beech Tree Planks Slab= |  | ||||||
| Beech Tree Planks Stair= |  | ||||||
| Beech Tree Sapling= |  | ||||||
| Beech Tree Trunk =  | Beech Tree Trunk =  | ||||||
| Beech Tree Trunk Slab= | Apple Tree Trunk =  | ||||||
| Beech Tree Trunk Stair= |  | ||||||
| Birch Tree= |  | ||||||
| Birch Tree Fence= |  | ||||||
| Birch Tree Fence Gate= |  | ||||||
| Birch Tree Fence Rail= |  | ||||||
| Birch Tree Leaves= |  | ||||||
| Birch Tree Planks= |  | ||||||
| Birch Tree Planks Slab= |  | ||||||
| Birch Tree Planks Stair= |  | ||||||
| Birch Tree Sapling= |  | ||||||
| Birch Tree Trunk= |  | ||||||
| Birch Tree Trunk Slab= |  | ||||||
| Birch Tree Trunk Stair= |  | ||||||
| Cedar Cone= |  | ||||||
| Cedar Tree= |  | ||||||
| Cedar Tree Fence= |  | ||||||
| Cedar Tree Fence Gate= |  | ||||||
| Cedar Tree Fence Rail= |  | ||||||
| Cedar Tree Leaves= |  | ||||||
| Cedar Tree Planks= |  | ||||||
| Cedar Tree Planks Slab= |  | ||||||
| Cedar Tree Planks Stair= |  | ||||||
| Cedar Tree Sapling= |  | ||||||
| Cedar Tree Trunk= |  | ||||||
| Cedar Tree Trunk Slab= |  | ||||||
| Cedar Tree Trunk Stair= |  | ||||||
| Date Palm Tree= |  | ||||||
| Date Palm Tree Fence= |  | ||||||
| Date Palm Tree Fence Gate= |  | ||||||
| Date Palm Tree Fence Rail= |  | ||||||
| Date Palm Tree Leaves= |  | ||||||
| Date Palm Tree Planks= |  | ||||||
| Date Palm Tree Planks Slab= |  | ||||||
| Date Palm Tree Planks Stair= |  | ||||||
| Date Palm Tree Sapling= |  | ||||||
| Date Palm Tree Trunk= |  | ||||||
| Date Palm Tree Trunk Slab= |  | ||||||
| Date Palm Tree Trunk Stair= |  | ||||||
| Douglas Fir= |  | ||||||
| Douglas Fir Fence= |  | ||||||
| Douglas Fir Fence Gate= |  | ||||||
| Douglas Fir Fence Rail= |  | ||||||
| Douglas Fir Leaves= |  | ||||||
| Douglas Fir Leaves (Bright)= |  | ||||||
| Douglas Fir Planks= |  | ||||||
| Douglas Fir Planks Slab= |  | ||||||
| Douglas Fir Planks Stair= |  | ||||||
| Douglas Fir Sapling= |  | ||||||
| Douglas Fir Trunk= |  | ||||||
| Douglas Fir Trunk Slab= |  | ||||||
| Douglas Fir Trunk Stair= |  | ||||||
| Fir Cone= |  | ||||||
| Giant Sequoia= |  | ||||||
| Giant Sequoia Fence= |  | ||||||
| Giant Sequoia Fence Gate= |  | ||||||
| Giant Sequoia Fence Rail= |  | ||||||
| Giant Sequoia Leaves= |  | ||||||
| Giant Sequoia Planks= |  | ||||||
| Giant Sequoia Planks Slab= |  | ||||||
| Giant Sequoia Planks Stair= |  | ||||||
| Giant Sequoia Sapling= |  | ||||||
| Giant Sequoia Trunk= |  | ||||||
| Giant Sequoia Trunk Slab= |  | ||||||
| Giant Sequoia Trunk Stair= |  | ||||||
| Jungle Tree= |  | ||||||
| Jungle Tree Fence= |  | ||||||
| Jungle Tree Fence Gate= |  | ||||||
| Jungle Tree Fence Rail= |  | ||||||
| Jungle Tree Leaves= |  | ||||||
| Jungle Tree Leaves (@1)= |  | ||||||
| Jungle Tree Planks= |  | ||||||
| Jungle Tree Planks Slab= |  | ||||||
| Jungle Tree Planks Stair= |  | ||||||
| Jungle Tree Sapling= |  | ||||||
| Jungle Tree Trunk= |  | ||||||
| Jungle Tree Trunk Slab= |  | ||||||
| Jungle Tree Trunk Stair= |  | ||||||
| Oak Tree= |  | ||||||
| Oak Tree Fence= |  | ||||||
| Oak Tree Fence Gate= |  | ||||||
| Oak Tree Fence Rail= |  | ||||||
| Oak Tree Leaves= |  | ||||||
| Oak Tree Planks= |  | ||||||
| Oak Tree Planks Slab= |  | ||||||
| Oak Tree Planks Stair= |  | ||||||
| Oak Tree Sapling= |  | ||||||
| Oak Tree Trunk =  | Oak Tree Trunk =  | ||||||
| Oak Tree Trunk Slab= | Giant Sequoia Trunk =  | ||||||
| Oak Tree Trunk Stair= | Birch Tree Trunk =  | ||||||
| Palm Tree= |  | ||||||
| Palm Tree Fence= |  | ||||||
| Palm Tree Fence Gate= |  | ||||||
| Palm Tree Fence Rail= |  | ||||||
| Palm Tree Leaves= |  | ||||||
| Palm Tree Planks= |  | ||||||
| Palm Tree Planks Slab= |  | ||||||
| Palm Tree Planks Stair= |  | ||||||
| Palm Tree Sapling= |  | ||||||
| Palm Tree Trunk =  | Palm Tree Trunk =  | ||||||
| Palm Tree Trunk Slab= |  | ||||||
| Palm Tree Trunk Stair= |  | ||||||
| Poplar Tree= |  | ||||||
| Poplar Tree Fence= |  | ||||||
| Poplar Tree Fence Gate= |  | ||||||
| Poplar Tree Fence Rail= |  | ||||||
| Poplar Tree Leaves= |  | ||||||
| Poplar Tree Planks= |  | ||||||
| Poplar Tree Planks Slab= |  | ||||||
| Poplar Tree Planks Stair= |  | ||||||
| Poplar Tree Sapling= |  | ||||||
| Poplar Tree Trunk= |  | ||||||
| Poplar Tree Trunk Slab= |  | ||||||
| Poplar Tree Trunk Stair= |  | ||||||
| Red= |  | ||||||
| Rubber Tree= |  | ||||||
| Rubber Tree Fence= |  | ||||||
| Rubber Tree Fence Gate= |  | ||||||
| Rubber Tree Fence Rail= |  | ||||||
| Rubber Tree Leaves= |  | ||||||
| Rubber Tree Planks= |  | ||||||
| Rubber Tree Planks Slab= |  | ||||||
| Rubber Tree Planks Stair= |  | ||||||
| Rubber Tree Sapling= |  | ||||||
| Rubber Tree Trunk= |  | ||||||
| Rubber Tree Trunk (Empty)= |  | ||||||
| Rubber Tree Trunk Slab= |  | ||||||
| Rubber Tree Trunk Stair= |  | ||||||
| Small poplar Tree Sapling= |  | ||||||
| Spruce Cone= |  | ||||||
| Spruce Tree= |  | ||||||
| Spruce Tree Fence= |  | ||||||
| Spruce Tree Fence Gate= |  | ||||||
| Spruce Tree Fence Rail= |  | ||||||
| Spruce Tree Leaves= |  | ||||||
| Spruce Tree Planks= |  | ||||||
| Spruce Tree Planks Slab= |  | ||||||
| Spruce Tree Planks Stair= |  | ||||||
| Spruce Tree Sapling= |  | ||||||
| Spruce Tree Trunk =  | Spruce Tree Trunk =  | ||||||
| Spruce Tree Trunk Slab= | Pine Tree Trunk =  | ||||||
| Spruce Tree Trunk Stair= |  | ||||||
| Willow Tree= |  | ||||||
| Willow Tree Fence= |  | ||||||
| Willow Tree Fence Gate= |  | ||||||
| Willow Tree Fence Rail= |  | ||||||
| Willow Tree Leaves= |  | ||||||
| Willow Tree Planks= |  | ||||||
| Willow Tree Planks Slab= |  | ||||||
| Willow Tree Planks Stair= |  | ||||||
| Willow Tree Sapling= |  | ||||||
| Willow Tree Trunk =  | Willow Tree Trunk =  | ||||||
| Willow Tree Trunk Slab= | Rubber Tree Trunk =  | ||||||
| Willow Tree Trunk Stair= | Jungle Tree Trunk =  | ||||||
| Yellow= | Douglas Fir Trunk =  | ||||||
|  | Beech Tree Planks =  | ||||||
|  | Apple Tree Planks =  | ||||||
|  | Oak Tree Planks =  | ||||||
|  | Giant Sequoia Planks =  | ||||||
|  | Birch Tree Planks =  | ||||||
|  | Palm Tree Planks =  | ||||||
|  | Spruce Tree Planks =  | ||||||
|  | Pine Tree Planks =  | ||||||
|  | Willow Tree Planks =  | ||||||
|  | Rubber Tree Planks =  | ||||||
|  | Jungle Tree Planks =  | ||||||
|  | Douglas Fir Planks =  | ||||||
|  | Beech Tree Sapling =  | ||||||
|  | Apple Tree Sapling =  | ||||||
|  | Oak Tree Sapling =  | ||||||
|  | Giant Sequoia Sapling =  | ||||||
|  | Birch Tree Sapling =  | ||||||
|  | Palm Tree Sapling =  | ||||||
|  | Spruce Tree Sapling =  | ||||||
|  | Pine Tree Sapling =  | ||||||
|  | Willow Tree Sapling =  | ||||||
|  | Rubber Tree Sapling =  | ||||||
|  | Jungle Tree Sapling =  | ||||||
|  | Douglas Fir Sapling =  | ||||||
|  | Beech Tree Leaves =  | ||||||
|  | Apple Tree Leaves =  | ||||||
|  | Oak Tree Leaves =  | ||||||
|  | Giant Sequoia Leaves =  | ||||||
|  | Birch Tree Leaves =  | ||||||
|  | Palm Tree Leaves =  | ||||||
|  | Spruce Tree Leaves =  | ||||||
|  | Pine Tree Leaves =  | ||||||
|  | Willow Tree Leaves =  | ||||||
|  | Rubber Tree Leaves =  | ||||||
|  | Jungle Tree Leaves =  | ||||||
|  | Douglas Fir Leaves =  | ||||||
|  |  | ||||||
| # init.lua | Acorn =  | ||||||
| Sapling= | Coconut =  | ||||||
| Tree= | Spruce Cone =  | ||||||
| Wooden Planks= | Pine Cone =  | ||||||
| Leaves= | Fir Cone =  | ||||||
| Wooden Fence= | Jungle Sapling =  | ||||||
| Wooden Fence Rail= | Jungle Tree Leaves (Green) =  | ||||||
| Wooden Fence Gate= | Jungle Tree Leaves (Yellow) =  | ||||||
|  | Jungle Tree Leaves (Red) =  | ||||||
|  | Douglas Fir Leaves (Bright) =  | ||||||
|  | Rubber Tree Trunk (Empty) =  | ||||||
|  |  | ||||||
|  | [Moretrees] Loaded (2013-02-11) =  | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								mod.conf
									
									
									
									
									
								
							
							
						
						| @@ -1,4 +0,0 @@ | |||||||
| name = moretrees |  | ||||||
| depends = xcompat |  | ||||||
| optional_depends = doors, stairs, moreblocks, farming, default, vessels |  | ||||||
| min_minetest_version = 5.2.0 |  | ||||||
							
								
								
									
										700
									
								
								node_defs.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,300 +1,145 @@ | |||||||
| local S = minetest.get_translator("moretrees") | local S = moretrees.intllib | ||||||
|  |  | ||||||
| moretrees.avoidnodes = {} | moretrees.avoidnodes = {} | ||||||
| 	 | 	 | ||||||
| local jungle_sapling_texture = minetest.get_modpath("default") and "default_junglesapling.png" |  | ||||||
| 	or "moretrees_cedar_sapling.png" |  | ||||||
|  |  | ||||||
| moretrees.treelist = { | moretrees.treelist = { | ||||||
| 	{"beech",        S("Beech Tree")}, | 	{"beech",		"Beech Tree"}, | ||||||
| 	{"apple_tree",   S("Apple Tree")}, | 	{"apple_tree",	"Apple Tree"}, | ||||||
| 	{"oak",          S("Oak Tree"),       "acorn",                S("Acorn"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | 	{"oak",			"Oak Tree",			"acorn",		"Acorn",		{-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | ||||||
| 	{"sequoia",      S("Giant Sequoia")}, | 	{"sequoia",		"Giant Sequoia"}, | ||||||
| 	{"birch",        S("Birch Tree")}, | 	{"birch",		"Birch Tree"}, | ||||||
| 	{"palm",         S("Palm Tree"),      "palm_fruit_trunk_gen", S("Palm Tree"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 1.0 }, | 	{"palm",		"Palm Tree",		"coconut",		"Coconut",		{-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 1.0 }, | ||||||
| 	{"date_palm",    S("Date Palm Tree"), "date_palm_fruit_trunk",S("Date Palm Tree"), {0, 0, 0, 0, 0, 0}, 0.0 }, | 	{"spruce",		"Spruce Tree",		"spruce_cone",	"Spruce Cone",	{-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | ||||||
| 	{"spruce",       S("Spruce Tree"),    "spruce_cone",          S("Spruce Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | 	{"pine",		"Pine Tree",		"pine_cone",	"Pine Cone",	{-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | ||||||
| 	{"cedar",        S("Cedar Tree"),     "cedar_cone",           S("Cedar Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | 	{"willow",		"Willow Tree"}, | ||||||
| 	{"poplar",       S("Poplar Tree")}, | 	{"acacia",		"Acacia Tree"}, | ||||||
| 	{"poplar_small", S("Poplar Tree")}, | 	{"rubber_tree",	"Rubber Tree"}, | ||||||
| 	{"willow",       S("Willow Tree")}, | 	{"jungletree",	"Jungle Tree"}, | ||||||
| 	{"rubber_tree",  S("Rubber Tree")}, | 	{"fir",			"Douglas Fir",		"fir_cone",		"Fir Cone",		{-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, | ||||||
| 	{"fir",          S("Douglas Fir"),    "fir_cone",             S("Fir Cone"), {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 }, |  | ||||||
| 	{"jungletree",   S("Jungle Tree"),     nil,                   nil, nil, nil, jungle_sapling_texture  }, |  | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.treedesc = { | local dirs1 = { 21, 20, 23, 22, 21 } | ||||||
| 	beech = { |  | ||||||
| 		trunk = S("Beech Tree Trunk"), |  | ||||||
| 		planks = S("Beech Tree Planks"), |  | ||||||
| 		sapling = S("Beech Tree Sapling"), |  | ||||||
| 		leaves = S("Beech Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Beech Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Beech Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Beech Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Beech Tree Planks Slab"), |  | ||||||
| 		fence = S("Beech Tree Fence"), |  | ||||||
| 		fence_rail = S("Beech Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Beech Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	apple_tree = { |  | ||||||
| 		trunk = S("Apple Tree Trunk"), |  | ||||||
| 		planks = S("Apple Tree Planks"), |  | ||||||
| 		sapling = S("Apple Tree Sapling"), |  | ||||||
| 		leaves = S("Apple Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Apple Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Apple Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Apple Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Apple Tree Planks Slab"), |  | ||||||
| 		fence = S("Apple Tree Fence"), |  | ||||||
| 		fence_rail = S("Apple Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Apple Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	oak = { |  | ||||||
| 		trunk = S("Oak Tree Trunk"), |  | ||||||
| 		planks = S("Oak Tree Planks"), |  | ||||||
| 		sapling = S("Oak Tree Sapling"), |  | ||||||
| 		leaves = S("Oak Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Oak Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Oak Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Oak Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Oak Tree Planks Slab"), |  | ||||||
| 		fence = S("Oak Tree Fence"), |  | ||||||
| 		fence_rail = S("Oak Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Oak Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	sequoia = { |  | ||||||
| 		trunk = S("Giant Sequoia Trunk"), |  | ||||||
| 		planks = S("Giant Sequoia Planks"), |  | ||||||
| 		sapling = S("Giant Sequoia Sapling"), |  | ||||||
| 		leaves = S("Giant Sequoia Leaves"), |  | ||||||
| 		trunk_stair = S("Giant Sequoia Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Giant Sequoia Trunk Slab"), |  | ||||||
| 		planks_stair = S("Giant Sequoia Planks Stair"), |  | ||||||
| 		planks_slab = S("Giant Sequoia Planks Slab"), |  | ||||||
| 		fence = S("Giant Sequoia Fence"), |  | ||||||
| 		fence_rail = S("Giant Sequoia Fence Rail"), |  | ||||||
| 		fence_gate = S("Giant Sequoia Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	birch = { |  | ||||||
| 		trunk = S("Birch Tree Trunk"), |  | ||||||
| 		planks = S("Birch Tree Planks"), |  | ||||||
| 		sapling = S("Birch Tree Sapling"), |  | ||||||
| 		leaves = S("Birch Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Birch Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Birch Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Birch Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Birch Tree Planks Slab"), |  | ||||||
| 		fence = S("Birch Tree Fence"), |  | ||||||
| 		fence_rail = S("Birch Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Birch Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	palm = { |  | ||||||
| 		trunk = S("Palm Tree Trunk"), |  | ||||||
| 		planks = S("Palm Tree Planks"), |  | ||||||
| 		sapling = S("Palm Tree Sapling"), |  | ||||||
| 		leaves = S("Palm Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Palm Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Palm Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Palm Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Palm Tree Planks Slab"), |  | ||||||
| 		fence = S("Palm Tree Fence"), |  | ||||||
| 		fence_rail = S("Palm Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Palm Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	date_palm = { |  | ||||||
| 		trunk = S("Date Palm Tree Trunk"), |  | ||||||
| 		planks = S("Date Palm Tree Planks"), |  | ||||||
| 		sapling = S("Date Palm Tree Sapling"), |  | ||||||
| 		leaves = S("Date Palm Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Date Palm Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Date Palm Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Date Palm Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Date Palm Tree Planks Slab"), |  | ||||||
| 		fence = S("Date Palm Tree Fence"), |  | ||||||
| 		fence_rail = S("Date Palm Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Date Palm Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	spruce = { |  | ||||||
| 		trunk = S("Spruce Tree Trunk"), |  | ||||||
| 		planks = S("Spruce Tree Planks"), |  | ||||||
| 		sapling = S("Spruce Tree Sapling"), |  | ||||||
| 		leaves = S("Spruce Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Spruce Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Spruce Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Spruce Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Spruce Tree Planks Slab"), |  | ||||||
| 		fence = S("Spruce Tree Fence"), |  | ||||||
| 		fence_rail = S("Spruce Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Spruce Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	cedar =  { |  | ||||||
| 		trunk = S("Cedar Tree Trunk"), |  | ||||||
| 		planks = S("Cedar Tree Planks"), |  | ||||||
| 		sapling = S("Cedar Tree Sapling"), |  | ||||||
| 		leaves = S("Cedar Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Cedar Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Cedar Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Cedar Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Cedar Tree Planks Slab"), |  | ||||||
| 		fence = S("Cedar Tree Fence"), |  | ||||||
| 		fence_rail = S("Cedar Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Cedar Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	poplar = { |  | ||||||
| 		trunk = S("Poplar Tree Trunk"), |  | ||||||
| 		planks = S("Poplar Tree Planks"), |  | ||||||
| 		sapling = S("Poplar Tree Sapling"), |  | ||||||
| 		leaves = S("Poplar Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Poplar Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Poplar Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Poplar Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Poplar Tree Planks Slab"), |  | ||||||
| 		fence = S("Poplar Tree Fence"), |  | ||||||
| 		fence_rail = S("Poplar Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Poplar Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	poplar_small = { |  | ||||||
| 		sapling = S("Small poplar Tree Sapling"), |  | ||||||
| 	}, |  | ||||||
| 	willow = { |  | ||||||
| 		trunk = S("Willow Tree Trunk"), |  | ||||||
| 		planks = S("Willow Tree Planks"), |  | ||||||
| 		sapling = S("Willow Tree Sapling"), |  | ||||||
| 		leaves = S("Willow Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Willow Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Willow Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Willow Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Willow Tree Planks Slab"), |  | ||||||
| 		fence = S("Willow Tree Fence"), |  | ||||||
| 		fence_rail = S("Willow Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Willow Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	rubber_tree = { |  | ||||||
| 		trunk = S("Rubber Tree Trunk"), |  | ||||||
| 		planks = S("Rubber Tree Planks"), |  | ||||||
| 		sapling = S("Rubber Tree Sapling"), |  | ||||||
| 		leaves = S("Rubber Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Rubber Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Rubber Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Rubber Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Rubber Tree Planks Slab"), |  | ||||||
| 		fence = S("Rubber Tree Fence"), |  | ||||||
| 		fence_rail = S("Rubber Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Rubber Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	fir = { |  | ||||||
| 		trunk = S("Douglas Fir Trunk"), |  | ||||||
| 		planks = S("Douglas Fir Planks"), |  | ||||||
| 		sapling = S("Douglas Fir Sapling"), |  | ||||||
| 		leaves = S("Douglas Fir Leaves"), |  | ||||||
| 		trunk_stair = S("Douglas Fir Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Douglas Fir Trunk Slab"), |  | ||||||
| 		planks_stair = S("Douglas Fir Planks Stair"), |  | ||||||
| 		planks_slab = S("Douglas Fir Planks Slab"), |  | ||||||
| 		fence = S("Douglas Fir Fence"), |  | ||||||
| 		fence_rail = S("Douglas Fir Fence Rail"), |  | ||||||
| 		fence_gate = S("Douglas Fir Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| 	jungletree = { |  | ||||||
| 		trunk = S("Jungle Tree Trunk"), |  | ||||||
| 		planks = S("Jungle Tree Planks"), |  | ||||||
| 		sapling = S("Jungle Tree Sapling"), |  | ||||||
| 		leaves = S("Jungle Tree Leaves"), |  | ||||||
| 		trunk_stair = S("Jungle Tree Trunk Stair"), |  | ||||||
| 		trunk_slab = S("Jungle Tree Trunk Slab"), |  | ||||||
| 		planks_stair = S("Jungle Tree Planks Stair"), |  | ||||||
| 		planks_slab = S("Jungle Tree Planks Slab"), |  | ||||||
| 		fence = S("Jungle Tree Fence"), |  | ||||||
| 		fence_rail = S("Jungle Tree Fence Rail"), |  | ||||||
| 		fence_gate = S("Jungle Tree Fence Gate"), |  | ||||||
| 	}, |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| -- local dirs1 = { 21, 20, 23, 22, 21 } |  | ||||||
| local dirs2 = { 12, 9, 18, 7, 12 } | local dirs2 = { 12, 9, 18, 7, 12 } | ||||||
| -- local dirs3 = { 14, 11, 16, 5, 14 } | local dirs3 = { 14, 11, 16, 5, 14 } | ||||||
|  |  | ||||||
| local moretrees_new_leaves_drawtype = "allfaces_optional" | local moretrees_new_leaves_drawtype = "allfaces_optional" | ||||||
| local moretrees_plantlike_leaves_visual_scale = 1 | local moretrees_plantlike_leaves_visual_scale = 1 | ||||||
|  |  | ||||||
| if moretrees.plantlike_leaves then  | if moretrees.plantlike_leaves then  | ||||||
| 	moretrees_new_leaves_drawtype = "plantlike" | 	moretrees_new_leaves_drawtype = "plantlike" | ||||||
| 	moretrees_plantlike_leaves_visual_scale = math.sqrt(2) | 	moretrees_plantlike_leaves_visual_scale = 1.189 | ||||||
| end | end | ||||||
|  |  | ||||||
| -- redefine default leaves to handle plantlike and/or leaf decay options | -- redefine default leaves to handle plantlike and/or leaf decay options | ||||||
|  |  | ||||||
| if minetest.get_modpath("default") and moretrees.plantlike_leaves then | if moretrees.enable_default_leafdecay then | ||||||
| 	minetest.override_item(xcompat.materials.apple_leaves, { | 	minetest.override_item("default:leaves", { | ||||||
|  | 		groups = { snappy = 3, flammable = 2, leaves = 1 } | ||||||
|  | 	}) | ||||||
|  | end | ||||||
|  | if moretrees.plantlike_leaves then | ||||||
|  | 	minetest.override_item("default:leaves", { | ||||||
| 		inventory_image = minetest.inventorycube("default_leaves.png"), | 		inventory_image = minetest.inventorycube("default_leaves.png"), | ||||||
| 		drawtype = "plantlike", | 		drawtype = "plantlike", | ||||||
| 		visual_scale = math.sqrt(2) | 		visual_scale = 1.189 | ||||||
|  | 	}) | ||||||
|  | else | ||||||
|  | 	minetest.override_item("default:leaves", { | ||||||
|  | 		waving = 1 | ||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| -- redefine default jungle leaves for same | -- redefine default jungle leaves for same | ||||||
|  |  | ||||||
| if minetest.get_modpath("default") and moretrees.plantlike_leaves then | if moretrees.enable_default_leafdecay then | ||||||
| 	minetest.override_item(xcompat.materials.jungle_leaves, { | 	minetest.override_item("default:jungleleaves", { | ||||||
|  | 		groups = { snappy = 3, flammable = 2, leaves = 1 } | ||||||
|  | 	}) | ||||||
|  | end | ||||||
|  | if moretrees.plantlike_leaves then | ||||||
|  | 	minetest.override_item("default:jungleleaves", { | ||||||
| 		inventory_image = minetest.inventorycube("default_jungleleaves.png"), | 		inventory_image = minetest.inventorycube("default_jungleleaves.png"), | ||||||
| 		drawtype = "plantlike", | 		drawtype = "plantlike", | ||||||
| 		visual_scale = math.sqrt(2) | 		visual_scale = 1.189 | ||||||
|  | 	}) | ||||||
|  | else | ||||||
|  | 	minetest.override_item("default:jungleleaves", { | ||||||
|  | 		waving = 1 | ||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| for i in ipairs(moretrees.treelist) do | for i in ipairs(moretrees.treelist) do | ||||||
| 	local treename = moretrees.treelist[i][1] | 	local treename = moretrees.treelist[i][1] | ||||||
|  | 	local treedesc = moretrees.treelist[i][2] | ||||||
| 	local fruit = moretrees.treelist[i][3] | 	local fruit = moretrees.treelist[i][3] | ||||||
| 	local fruitdesc = moretrees.treelist[i][4] | 	local fruitdesc = moretrees.treelist[i][4] | ||||||
| 	local selbox = moretrees.treelist[i][5] | 	local selbox = moretrees.treelist[i][5] | ||||||
| 	local vscale = moretrees.treelist[i][6] | 	local vscale = moretrees.treelist[i][6] | ||||||
|  |  | ||||||
| 	local saptex = moretrees.treelist[i][7] | 	if treename ~= "jungletree" then -- the default game provides jungle tree trunk/planks nodes. | ||||||
|  |  | ||||||
| 	-- player will get a sapling with 1/100 chance |  | ||||||
| 	-- player will get leaves only if he/she gets no saplings, |  | ||||||
| 	-- this is because max_items is 1 |  | ||||||
|  |  | ||||||
| 	local droprarity = 100 |  | ||||||
| 	local decay = moretrees.leafdecay_radius |  | ||||||
|  |  | ||||||
| 	if treename == "palm" then |  | ||||||
| 		droprarity = 20 |  | ||||||
| 		decay = moretrees.palm_leafdecay_radius |  | ||||||
| 	elseif treename == "date_palm" then |  | ||||||
| 		decay = moretrees.date_palm_leafdecay_radius |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- dont register planks/nodes for trees from default and small varients for trees |  | ||||||
| 	local split_tn = treename:split("_") |  | ||||||
| 	if treename ~= "jungletree" and treename ~= "pine" and split_tn[2]~="small" then |  | ||||||
|  |  | ||||||
| 		saptex = "moretrees_"..treename.."_sapling.png" |  | ||||||
|  |  | ||||||
| 		minetest.register_node("moretrees:"..treename.."_trunk", { | 		minetest.register_node("moretrees:"..treename.."_trunk", { | ||||||
| 			description = moretrees.treedesc[treename].trunk, | 			description = S(treedesc.." Trunk"), | ||||||
| 			tiles = { | 			tiles = { | ||||||
| 				"moretrees_"..treename.."_trunk_top.png", | 				"moretrees_"..treename.."_trunk_top.png", | ||||||
| 				"moretrees_"..treename.."_trunk_top.png", | 				"moretrees_"..treename.."_trunk_top.png", | ||||||
| 				"moretrees_"..treename.."_trunk.png" | 				"moretrees_"..treename.."_trunk.png" | ||||||
| 			}, | 			}, | ||||||
| 			paramtype2 = "facedir", | 			paramtype2 = "facedir", | ||||||
| 			is_ground_content = false, | 			is_ground_content = true, | ||||||
| 			groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | 			groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | ||||||
| 			sounds = xcompat.sounds.node_sound_wood_defaults(), | 			sounds = default.node_sound_wood_defaults(), | ||||||
| 			on_place = minetest.rotate_node, | 			on_place = minetest.rotate_node, | ||||||
| 		}) | 		}) | ||||||
|  |  | ||||||
| 		if moretrees.enable_planks then |  | ||||||
| 		minetest.register_node("moretrees:"..treename.."_planks", { | 		minetest.register_node("moretrees:"..treename.."_planks", { | ||||||
| 				description = moretrees.treedesc[treename].planks, | 			description = S(treedesc.." Planks"), | ||||||
| 			tiles = {"moretrees_"..treename.."_wood.png"}, | 			tiles = {"moretrees_"..treename.."_wood.png"}, | ||||||
| 				is_ground_content = false, | 			is_ground_content = true, | ||||||
| 			groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1}, | 			groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1}, | ||||||
| 				sounds = xcompat.sounds.node_sound_wood_defaults(), | 			sounds = default.node_sound_wood_defaults(), | ||||||
| 		}) | 		}) | ||||||
|  |  | ||||||
|  | 		minetest.register_node("moretrees:"..treename.."_sapling", { | ||||||
|  | 			description = S(treedesc.." Sapling"), | ||||||
|  | 			drawtype = "plantlike", | ||||||
|  | 			tiles = {"moretrees_"..treename.."_sapling.png"}, | ||||||
|  | 			inventory_image = "moretrees_"..treename.."_sapling.png", | ||||||
|  | 			paramtype = "light", | ||||||
|  | 			walkable = false, | ||||||
|  | 			selection_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3} | ||||||
|  | 			}, | ||||||
|  | 			groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,sapling=1}, | ||||||
|  | 			sounds = default.node_sound_defaults(), | ||||||
|  | 		}) | ||||||
|  | 	 | ||||||
|  | 		minetest.register_node("moretrees:"..treename.."_sapling_ongen", { | ||||||
|  | 			description = S(treedesc.." Sapling"), | ||||||
|  | 			drawtype = "plantlike", | ||||||
|  | 			tiles = {"moretrees_"..treename.."_sapling.png"}, | ||||||
|  | 			inventory_image = "moretrees_"..treename.."_sapling.png", | ||||||
|  | 			paramtype = "light", | ||||||
|  | 			walkable = false, | ||||||
|  | 			selection_box = { | ||||||
|  | 				type = "fixed", | ||||||
|  | 				fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3} | ||||||
|  | 			}, | ||||||
|  | 			groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,not_in_creative_inventory=1,sapling=1}, | ||||||
|  | 			sounds = default.node_sound_defaults(), | ||||||
|  | 			drop = "moretrees:"..treename.."_sapling" | ||||||
|  | 		}) | ||||||
|  |  | ||||||
|  | 		-- player will get a sapling with 1/100 chance | ||||||
|  | 		-- player will get leaves only if he/she gets no saplings, | ||||||
|  | 		-- this is because max_items is 1 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 		local droprarity = 100 | ||||||
|  |  | ||||||
|  | 		if treename == "palm" then | ||||||
|  | 			droprarity = 20 | ||||||
| 		end | 		end | ||||||
|  |  | ||||||
| 		local moretrees_leaves_inventory_image = nil | 		local moretrees_leaves_inventory_image = nil | ||||||
| @@ -307,16 +152,15 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 		end | 		end | ||||||
|  |  | ||||||
| 		minetest.register_node("moretrees:"..treename.."_leaves", { | 		minetest.register_node("moretrees:"..treename.."_leaves", { | ||||||
| 			description = moretrees.treedesc[treename].leaves, | 			description = S(treedesc.." Leaves"), | ||||||
| 			drawtype = moretrees_new_leaves_drawtype, | 			drawtype = moretrees_new_leaves_drawtype, | ||||||
| 			waving = moretrees_new_leaves_waving, | 			waving = moretrees_new_leaves_waving, | ||||||
| 			visual_scale = moretrees_plantlike_leaves_visual_scale, | 			visual_scale = moretrees_plantlike_leaves_visual_scale, | ||||||
| 			tiles = { "moretrees_"..treename.."_leaves.png" }, | 			tiles = { "moretrees_"..treename.."_leaves.png" }, | ||||||
| 			inventory_image = moretrees_leaves_inventory_image, | 			inventory_image = moretrees_leaves_inventory_image, | ||||||
| 			paramtype = "light", | 			paramtype = "light", | ||||||
| 			is_ground_content = false, | 			groups = {snappy=3, flammable=2, leaves=1, moretrees_leaves=1}, | ||||||
| 			groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 1}, | 			sounds = default.node_sound_leaves_defaults(), | ||||||
| 			sounds = xcompat.sounds.node_sound_leaves_defaults(), |  | ||||||
|  |  | ||||||
| 			drop = { | 			drop = { | ||||||
| 				max_items = 1, | 				max_items = 1, | ||||||
| @@ -327,7 +171,9 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 			}, | 			}, | ||||||
| 		}) | 		}) | ||||||
|  |  | ||||||
| 		if minetest.get_modpath("moreblocks") then | 		if minetest.get_modpath("moreblocks") and moretrees.enable_stairsplus then | ||||||
|  |  | ||||||
|  | --			stairsplus:register_all(modname, subname, recipeitem, {fields}) | ||||||
|  |  | ||||||
| 			stairsplus:register_all( | 			stairsplus:register_all( | ||||||
| 				"moretrees", | 				"moretrees", | ||||||
| @@ -340,12 +186,11 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 						"moretrees_"..treename.."_trunk_top.png", | 						"moretrees_"..treename.."_trunk_top.png", | ||||||
| 						"moretrees_"..treename.."_trunk.png" | 						"moretrees_"..treename.."_trunk.png" | ||||||
| 					}, | 					}, | ||||||
| 					description = moretrees.treedesc[treename].trunk, | 					description = S(treedesc.." Trunk"), | ||||||
| 					drop = treename.."_trunk", | 					drop = treename.."_trunk", | ||||||
| 				} | 				} | ||||||
| 			) | 			) | ||||||
|  |  | ||||||
| 			if moretrees.enable_planks then |  | ||||||
| 			stairsplus:register_all( | 			stairsplus:register_all( | ||||||
| 				"moretrees", | 				"moretrees", | ||||||
| 				treename.."_planks", | 				treename.."_planks", | ||||||
| @@ -353,222 +198,29 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 				{ | 				{ | ||||||
|  					groups = { snappy=1, choppy=2, oddly_breakable_by_hand=2, flammable=3, not_in_creative_inventory=1 }, |  					groups = { snappy=1, choppy=2, oddly_breakable_by_hand=2, flammable=3, not_in_creative_inventory=1 }, | ||||||
| 					tiles = { "moretrees_"..treename.."_wood.png" }, | 					tiles = { "moretrees_"..treename.."_wood.png" }, | ||||||
| 						description = moretrees.treedesc[treename].planks, | 					description = S(treedesc.." Planks"), | ||||||
| 					drop = treename.."_planks", | 					drop = treename.."_planks", | ||||||
| 				} | 				} | ||||||
| 			) | 			) | ||||||
| 		end | 		end | ||||||
| 		elseif minetest.get_modpath("stairs") then |  | ||||||
| 			stairs.register_stair_and_slab( |  | ||||||
| 				"moretrees_"..treename.."_trunk", |  | ||||||
| 				"moretrees:"..treename.."_trunk", |  | ||||||
| 				{ snappy=1, choppy=2, oddly_breakable_by_hand=1, flammable=2 }, |  | ||||||
| 				{	"moretrees_"..treename.."_trunk_top.png", |  | ||||||
| 					"moretrees_"..treename.."_trunk_top.png", |  | ||||||
| 					"moretrees_"..treename.."_trunk.png" |  | ||||||
| 				}, |  | ||||||
| 				moretrees.treedesc[treename].trunk_stair, |  | ||||||
| 				moretrees.treedesc[treename].trunk_slab, |  | ||||||
| 				xcompat.sounds.node_sound_wood_defaults() |  | ||||||
| 			) |  | ||||||
|  |  | ||||||
| 			if moretrees.enable_planks then |  | ||||||
| 				stairs.register_stair_and_slab( |  | ||||||
| 					"moretrees_"..treename.."_planks", |  | ||||||
| 					"moretrees:"..treename.."_planks", |  | ||||||
| 					{ snappy=1, choppy=2, oddly_breakable_by_hand=2, flammable=3 }, |  | ||||||
| 					{ "moretrees_"..treename.."_wood.png" }, |  | ||||||
| 					moretrees.treedesc[treename].planks_stair, |  | ||||||
| 					moretrees.treedesc[treename].planks_slab, |  | ||||||
| 					xcompat.sounds.node_sound_wood_defaults() |  | ||||||
| 				) |  | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		if minetest.get_modpath("default") and moretrees.enable_planks then |  | ||||||
| 			local planks_name = "moretrees:" .. treename .. "_planks" |  | ||||||
| 			local planks_tile = "moretrees_" .. treename .. "_wood.png" |  | ||||||
| 			default.register_fence("moretrees:" .. treename .. "_fence", { |  | ||||||
| 				description = moretrees.treedesc[treename].fence, |  | ||||||
| 				texture = planks_tile, |  | ||||||
| 				inventory_image = "default_fence_overlay.png^" .. planks_tile .. |  | ||||||
| 										"^default_fence_overlay.png^[makealpha:255,126,126", |  | ||||||
| 				wield_image = "default_fence_overlay.png^" .. planks_tile .. |  | ||||||
| 										"^default_fence_overlay.png^[makealpha:255,126,126", |  | ||||||
| 				material = planks_name, |  | ||||||
| 				groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2}, |  | ||||||
| 				sounds = xcompat.sounds.node_sound_wood_defaults() |  | ||||||
| 			}) |  | ||||||
| 			default.register_fence_rail("moretrees:" .. treename .. "_fence_rail", { |  | ||||||
| 				description = moretrees.treedesc[treename].fence_rail, |  | ||||||
| 				texture = planks_tile, |  | ||||||
| 				inventory_image = "default_fence_rail_overlay.png^" .. planks_tile .. |  | ||||||
| 										"^default_fence_rail_overlay.png^[makealpha:255,126,126", |  | ||||||
| 				wield_image = "default_fence_rail_overlay.png^" .. planks_tile .. |  | ||||||
| 										"^default_fence_rail_overlay.png^[makealpha:255,126,126", |  | ||||||
| 				material = planks_name, |  | ||||||
| 				groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2}, |  | ||||||
| 				sounds = xcompat.sounds.node_sound_wood_defaults() |  | ||||||
| 			}) |  | ||||||
| 			if minetest.global_exists("doors") then |  | ||||||
| 				doors.register_fencegate("moretrees:" .. treename .. "_gate", { |  | ||||||
| 					description = moretrees.treedesc[treename].fence_gate, |  | ||||||
| 					texture = planks_tile, |  | ||||||
| 					material = planks_name, |  | ||||||
| 					groups = {choppy = 2, oddly_breakable_by_hand = 2, flammable = 2} |  | ||||||
| 				}) |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	-- the default game provides jungle tree and pine saplings. |  | ||||||
| 	if treename~="jungletree" and treename ~= "pine" then |  | ||||||
| 		local regular_groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,sapling=1} |  | ||||||
| 		if minetest.settings:get_bool("creative_mode", false) then |  | ||||||
| 			regular_groups["not_in_creative_inventory"]=1 |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		minetest.register_node("moretrees:"..treename.."_sapling", { |  | ||||||
| 			description = moretrees.treedesc[treename].sapling, |  | ||||||
| 			drawtype = "plantlike", |  | ||||||
| 			tiles = {split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex}, |  | ||||||
| 			inventory_image = split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex, |  | ||||||
| 			paramtype = "light", |  | ||||||
| 			walkable = false, |  | ||||||
| 			is_ground_content = true, |  | ||||||
| 			selection_box = { |  | ||||||
| 				type = "fixed", |  | ||||||
| 				fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3} |  | ||||||
| 			}, |  | ||||||
| 			groups = regular_groups, |  | ||||||
| 			sounds = xcompat.sounds.node_sound_default(), |  | ||||||
| 			on_place = function(itemstack, placer, pointed_thing) |  | ||||||
| 				itemstack = xcompat.functions.sapling_on_place(itemstack, placer, pointed_thing, |  | ||||||
| 					"moretrees:" ..treename.. "_sapling", |  | ||||||
| 					-- minp, maxp to be checked, relative to sapling pos |  | ||||||
| 					-- minp_relative.y = 1 because sapling pos has been checked |  | ||||||
| 					{x = -3, y = 1, z = -3}, |  | ||||||
| 					{x = 3, y = 6, z = 3}, |  | ||||||
| 					-- maximum interval of interior volume check |  | ||||||
| 					4) |  | ||||||
|  |  | ||||||
| 				return itemstack |  | ||||||
| 			end, |  | ||||||
| 			on_construct = function(pos) |  | ||||||
| 				minetest.get_node_timer(pos):start(300) |  | ||||||
| 			end, |  | ||||||
| 			on_timer = function(pos, elapsed) |  | ||||||
| 				if moretrees.can_grow(pos, treename) then |  | ||||||
| 					--moretrees["grow_" .. treename](pos) |  | ||||||
| 					minetest.set_node(pos, {name="air"}) |  | ||||||
| 					if type(moretrees["spawn_" .. treename .. "_object"])=="string" then |  | ||||||
| 						local split = moretrees["spawn_" .. treename .. "_object"]:split(".") |  | ||||||
| 						moretrees[split[2]](pos) |  | ||||||
| 					else |  | ||||||
| 						minetest.spawn_tree(pos, moretrees["spawn_" .. treename .. "_object"]) |  | ||||||
| 					end |  | ||||||
| 				else |  | ||||||
| 					minetest.get_node_timer(pos):start(300) |  | ||||||
| 				end |  | ||||||
| 			end, |  | ||||||
| 		}) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	local ongen_groups = { |  | ||||||
| 		snappy = 2, |  | ||||||
| 		dig_immediate = 3, |  | ||||||
| 		flammable = 2, |  | ||||||
| 		attached_node = 1, |  | ||||||
| 		sapling = 1, |  | ||||||
| 		moretrees_ongen = 1, |  | ||||||
| 		not_in_creative_inventory = 1 |  | ||||||
| 	} |  | ||||||
| 	if minetest.settings:get_bool("creative_mode", false) then |  | ||||||
| 		ongen_groups["not_in_creative_inventory"]=nil |  | ||||||
| 	end |  | ||||||
| 	minetest.register_node("moretrees:"..treename.."_sapling_ongen", { |  | ||||||
| 		description = S("@1 (fast growth)", moretrees.treedesc[treename].sapling), |  | ||||||
| 		drawtype = "plantlike", |  | ||||||
| 		tiles = {split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex,}, |  | ||||||
| 		inventory_image = split_tn[2] and split_tn[2]=="small" and "moretrees_" .. treename .. "_sapling.png" or saptex, |  | ||||||
| 		paramtype = "light", |  | ||||||
| 		walkable = false, |  | ||||||
| 		is_ground_content = true, |  | ||||||
| 		selection_box = { |  | ||||||
| 			type = "fixed", |  | ||||||
| 			fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3} |  | ||||||
| 		}, |  | ||||||
| 		groups = ongen_groups, |  | ||||||
| 		sounds = xcompat.sounds.node_sound_default(), |  | ||||||
| 		drop = "moretrees:"..treename.."_sapling", |  | ||||||
| 		on_place = function(itemstack, placer, pointed_thing) |  | ||||||
| 			itemstack = xcompat.functions.sapling_on_place(itemstack, placer, pointed_thing, |  | ||||||
| 				"moretrees:" ..treename.. "_sapling_ongen", |  | ||||||
| 				-- minp, maxp to be checked, relative to sapling pos |  | ||||||
| 				-- minp_relative.y = 1 because sapling pos has been checked |  | ||||||
| 				{x = -3, y = 1, z = -3}, |  | ||||||
| 				{x = 3, y = 6, z = 3}, |  | ||||||
| 				-- maximum interval of interior volume check |  | ||||||
| 				4) |  | ||||||
|  |  | ||||||
| 			return itemstack |  | ||||||
| 		end, |  | ||||||
| 		on_construct = function(pos) |  | ||||||
| 			minetest.get_node_timer(pos):start(2) |  | ||||||
| 		end, |  | ||||||
| 		on_timer = function(pos, elapsed) |  | ||||||
| 			if moretrees.can_grow(pos, treename) then |  | ||||||
| 				--moretrees["grow_" .. treename](pos) |  | ||||||
| 				minetest.set_node(pos, {name="air"}) |  | ||||||
| 				if type(moretrees["spawn_" .. treename .. "_object"])=="string" then |  | ||||||
| 					local split = moretrees["spawn_" .. treename .. "_object"]:split(".") |  | ||||||
| 					moretrees[split[2]](pos) |  | ||||||
| 				else |  | ||||||
| 					minetest.spawn_tree(pos, moretrees["spawn_" .. treename .. "_object"]) |  | ||||||
| 				end |  | ||||||
| 			else |  | ||||||
| 				minetest.get_node_timer(pos):start(300) |  | ||||||
| 			end |  | ||||||
| 		end, |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	local fruitname = nil |  | ||||||
| 	if fruit then | 	if fruit then | ||||||
| 		fruitname = "moretrees:"..fruit | 		minetest.register_node("moretrees:"..fruit, { | ||||||
| 		minetest.register_node(fruitname, { | 			description = S(fruitdesc), | ||||||
| 			description = fruitdesc, |  | ||||||
| 			drawtype = "plantlike", | 			drawtype = "plantlike", | ||||||
| 			tiles = { "moretrees_"..fruit..".png" }, | 			tiles = { "moretrees_"..fruit..".png" }, | ||||||
| 			inventory_image = "moretrees_"..fruit..".png^[transformR180", | 			inventory_image = "moretrees_"..fruit..".png^[transformR180", | ||||||
| 			wield_image = "moretrees_"..fruit..".png^[transformR180", | 			wield_image = "moretrees_"..fruit..".png^[transformR180", | ||||||
| 			visual_scale = vscale, | 			visual_scale = vscale, | ||||||
| 			paramtype = "light", |  | ||||||
| 			sunlight_propagates = true, |  | ||||||
| 			is_ground_content = false, |  | ||||||
| 			walkable = false, | 			walkable = false, | ||||||
|  | 			paramtype = "light", | ||||||
| 			selection_box = { | 			selection_box = { | ||||||
| 				type = "fixed", | 				type = "fixed", | ||||||
| 					fixed = selbox | 					fixed = selbox | ||||||
| 				}, | 				}, | ||||||
| 			groups = {fleshy=3,dig_immediate=3,flammable=2, attached_node=1, leafdecay = 1, leafdecay_drop = 1}, | 			groups = {fleshy=3,dig_immediate=3,flammable=2, attached_node=1}, | ||||||
| 			sounds = xcompat.sounds.node_sound_default(), | 			sounds = default.node_sound_defaults(), | ||||||
| 			after_place_node = function(pos, placer) |  | ||||||
| 				if placer:is_player() then |  | ||||||
| 					minetest.set_node(pos, {name = "moretrees:"..fruit, param2 = 1}) |  | ||||||
| 				end |  | ||||||
| 			end |  | ||||||
| 		}) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	if treename ~= "jungletree" |  | ||||||
| 		and treename ~= "poplar_small" |  | ||||||
| 		and treename ~= "pine" |  | ||||||
| 		and minetest.get_modpath("default") then |  | ||||||
| 			default.register_leafdecay({ |  | ||||||
| 				trunks = { "moretrees:"..treename.."_trunk" }, |  | ||||||
| 				leaves = { "moretrees:"..treename.."_leaves", fruitname }, |  | ||||||
| 				radius = decay, |  | ||||||
| 		}) | 		}) | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| @@ -578,7 +230,7 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 		chance = 1, | 		chance = 1, | ||||||
| 		action = function(pos, node, active_object_count, active_object_count_wider) | 		action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
| 			local fdir = node.param2 or 0 | 			local fdir = node.param2 or 0 | ||||||
| 				local nfdir = dirs2[fdir+1] | 				nfdir = dirs2[fdir+1] | ||||||
| 			minetest.add_node(pos, {name = "moretrees:"..treename.."_trunk", param2 = nfdir}) | 			minetest.add_node(pos, {name = "moretrees:"..treename.."_trunk", param2 = nfdir}) | ||||||
| 		end, | 		end, | ||||||
| 	}) | 	}) | ||||||
| @@ -591,24 +243,46 @@ for i in ipairs(moretrees.treelist) do | |||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| -- poplar saplings leaves |  | ||||||
| local poplar_leaves_drop = minetest.registered_nodes["moretrees:poplar_leaves"].drop |  | ||||||
| minetest.override_item("moretrees:poplar_leaves", { |  | ||||||
| 	drop = { |  | ||||||
| 		max_items = poplar_leaves_drop.max_items, |  | ||||||
| 		items = { |  | ||||||
| 			{items = {"moretrees:poplar_sapling"}, rarity = 1.33 * poplar_leaves_drop.items[1].rarity }, |  | ||||||
| 			{items = {"moretrees:poplar_small_sapling"}, rarity = 1.33 * poplar_leaves_drop.items[1].rarity }, |  | ||||||
| 			{items = {"moretrees:poplar_leaves"} } |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| -- Extra nodes for jungle trees: | -- Extra nodes for jungle trees: | ||||||
|  |  | ||||||
| local jungleleaves = {"yellow","red"} | minetest.register_node("moretrees:jungletree_sapling", { | ||||||
| local jungleleavesnames = {S("Yellow"), S("Red")} | 	description = S("Jungle Sapling"), | ||||||
| for color = 1, #jungleleaves do | 	drawtype = "plantlike", | ||||||
|  | 	visual_scale = 1.0, | ||||||
|  | 	tiles = {"default_junglesapling.png"}, | ||||||
|  | 	inventory_image = "default_junglesapling.png", | ||||||
|  | 	wield_image = "default_junglesapling.png", | ||||||
|  | 	paramtype = "light", | ||||||
|  | 	walkable = false, | ||||||
|  | 	selection_box = { | ||||||
|  | 		type = "fixed", | ||||||
|  | 		fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3} | ||||||
|  | 	}, | ||||||
|  | 	groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,sapling=1}, | ||||||
|  | 	sounds = default.node_sound_leaves_defaults(), | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | minetest.register_node("moretrees:jungletree_sapling_ongen", { | ||||||
|  | 	description = S("Jungle Sapling"), | ||||||
|  | 	drawtype = "plantlike", | ||||||
|  | 	visual_scale = 1.0, | ||||||
|  | 	tiles = {"default_junglesapling.png"}, | ||||||
|  | 	inventory_image = "default_junglesapling.png", | ||||||
|  | 	wield_image = "default_junglesapling.png", | ||||||
|  | 	paramtype = "light", | ||||||
|  | 	walkable = false, | ||||||
|  | 	selection_box = { | ||||||
|  | 		type = "fixed", | ||||||
|  | 		fixed = {-0.3, -0.5, -0.3, 0.3, 0.35, 0.3} | ||||||
|  | 	}, | ||||||
|  | 	groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1,not_in_creative_inventory=1,sapling=1}, | ||||||
|  | 	sounds = default.node_sound_leaves_defaults(), | ||||||
|  | 	drop = "moretrees:jungletree_sapling" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | local jungleleaves = {"green","yellow","red"} | ||||||
|  | local jungleleavesnames = {"Green", "Yellow", "Red"} | ||||||
|  | for color = 1, 3 do | ||||||
| 	local leave_name = "moretrees:jungletree_leaves_"..jungleleaves[color] | 	local leave_name = "moretrees:jungletree_leaves_"..jungleleaves[color] | ||||||
|  |  | ||||||
| 	local moretrees_leaves_inventory_image = nil | 	local moretrees_leaves_inventory_image = nil | ||||||
| @@ -620,38 +294,22 @@ for color = 1, #jungleleaves do | |||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	minetest.register_node(leave_name, { | 	minetest.register_node(leave_name, { | ||||||
| 		description = S("Jungle Tree Leaves (@1)", jungleleavesnames[color]), | 		description = S("Jungle Tree Leaves ("..jungleleavesnames[color]..")"), | ||||||
| 		drawtype = moretrees_new_leaves_drawtype, | 		drawtype = moretrees_new_leaves_drawtype, | ||||||
| 		waving = moretrees_new_leaves_waving, | 		waving = moretrees_new_leaves_waving, | ||||||
| 		visual_scale = moretrees_plantlike_leaves_visual_scale, | 		visual_scale = moretrees_plantlike_leaves_visual_scale, | ||||||
| 		tiles = {"moretrees_jungletree_leaves_"..jungleleaves[color]..".png"}, | 		tiles = {"moretrees_jungletree_leaves_"..jungleleaves[color]..".png"}, | ||||||
| 		inventory_image = moretrees_leaves_inventory_image, | 		inventory_image = moretrees_leaves_inventory_image, | ||||||
| 		paramtype = "light", | 		paramtype = "light", | ||||||
| 		is_ground_content = false, | 		groups = {snappy=3, flammable=2, leaves=1, moretrees_leaves=1}, | ||||||
| 		groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 3 }, | 		drop = { | ||||||
| 		drop = minetest.get_modpath("default") and { |  | ||||||
| 			max_items = 1, | 			max_items = 1, | ||||||
| 			items = { | 			items = { | ||||||
| 				{items = {"default:junglesapling"}, rarity = 100 }, | 				{items = {'moretrees:jungletree_sapling'}, rarity = 100 }, | ||||||
| 				{items = {"moretrees:jungletree_leaves_"..jungleleaves[color]} } | 				{items = {"moretrees:jungletree_leaves_"..jungleleaves[color]} } | ||||||
| 			} | 			} | ||||||
| 		} or nil, | 		}, | ||||||
| 		sounds = xcompat.sounds.node_sound_leaves_defaults(), | 		sounds = default.node_sound_leaves_defaults(), | ||||||
| 	}) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- To get Moretrees to generate its own jungle trees among the default mapgen |  | ||||||
| -- we need our own copy of that node, which moretrees will match against. |  | ||||||
|  |  | ||||||
| if minetest.get_modpath("default") then |  | ||||||
| 	local jungle_tree = table.copy(minetest.registered_nodes["default:jungletree"]) |  | ||||||
| 	jungle_tree.drop = "default:jungletree" |  | ||||||
| 	minetest.register_node("moretrees:jungletree_trunk", jungle_tree) |  | ||||||
|  |  | ||||||
| 	default.register_leafdecay({ |  | ||||||
| 		trunks = { "default:jungletree", "moretrees:jungletree_trunk" }, |  | ||||||
| 		leaves = { xcompat.materials.jungle_leaves, "moretrees:jungletree_leaves_yellow", "moretrees:jungletree_leaves_red" }, |  | ||||||
| 		radius = moretrees.leafdecay_radius, |  | ||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
| @@ -671,8 +329,7 @@ minetest.register_node("moretrees:fir_leaves_bright", { | |||||||
| 	tiles = { "moretrees_fir_leaves_bright.png" }, | 	tiles = { "moretrees_fir_leaves_bright.png" }, | ||||||
| 	inventory_image = moretrees_leaves_inventory_image, | 	inventory_image = moretrees_leaves_inventory_image, | ||||||
| 	paramtype = "light", | 	paramtype = "light", | ||||||
| 	is_ground_content = false, | 	groups = {snappy=3, flammable=2, leaves=1, moretrees_leaves=1 }, | ||||||
| 	groups = {snappy = 3, flammable = 2, leaves = 1, moretrees_leaves = 1, leafdecay = 3 }, |  | ||||||
| 	drop = { | 	drop = { | ||||||
| 		max_items = 1, | 		max_items = 1, | ||||||
| 		items = { | 		items = { | ||||||
| @@ -680,34 +337,25 @@ minetest.register_node("moretrees:fir_leaves_bright", { | |||||||
| 			{items = {'moretrees:fir_leaves_bright'} } | 			{items = {'moretrees:fir_leaves_bright'} } | ||||||
| 		} | 		} | ||||||
| 	}, | 	}, | ||||||
| 	sounds = xcompat.sounds.node_sound_leaves_defaults() | 	sounds = default.node_sound_leaves_defaults() | ||||||
| }) | }) | ||||||
|  |  | ||||||
| if minetest.get_modpath("default") then | if moretrees.enable_redefine_apple then | ||||||
| 	default.register_leafdecay({ | 	minetest.override_item("default:apple", | ||||||
| 		trunks = { "moretrees:fir_trunk" }, | 		{groups = { fleshy=3, dig_immediate=3, flammable=2, leafdecay=3, leafdecay_drop=1, attached_node = 1} | ||||||
| 		leaves = { "moretrees:fir_leaves", "moretrees:fir_leaves_bright" }, |  | ||||||
| 		radius = moretrees.leafdecay_radius, |  | ||||||
| 	}) | 	}) | ||||||
| end | end | ||||||
|  |  | ||||||
|  |  | ||||||
| if minetest.get_modpath("default") and moretrees.enable_redefine_apple then |  | ||||||
| 	local appledef = table.copy(minetest.registered_nodes["default:apple"]) |  | ||||||
| 	appledef.groups.attached_node = 1 |  | ||||||
| 	minetest.register_node(":default:apple", appledef) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| table.insert(moretrees.avoidnodes, "default:jungletree") | table.insert(moretrees.avoidnodes, "default:jungletree") | ||||||
| table.insert(moretrees.avoidnodes, "default:pine_tree") | table.insert(moretrees.avoidnodes, "moretrees:jungletree_trunk") | ||||||
| table.insert(moretrees.avoidnodes, "default:acacia_tree") |  | ||||||
| table.insert(moretrees.avoidnodes, "moretrees:fir_trunk") | table.insert(moretrees.avoidnodes, "moretrees:fir_trunk") | ||||||
| table.insert(moretrees.avoidnodes, "default:tree") | table.insert(moretrees.avoidnodes, "default:tree") | ||||||
|  |  | ||||||
| if moretrees.spawn_saplings then | if moretrees.spawn_saplings then | ||||||
| 	table.insert(moretrees.avoidnodes, "snow:sapling_pine") | 	table.insert(moretrees.avoidnodes, "snow:sapling_pine") | ||||||
| 	table.insert(moretrees.avoidnodes, "default:junglesapling") | 	table.insert(moretrees.avoidnodes, "default:junglesapling") | ||||||
| 	table.insert(moretrees.avoidnodes, "default:pine_sapling") | 	table.insert(moretrees.avoidnodes, "moretrees:jungle_tree_sapling") | ||||||
|  | 	table.insert(moretrees.avoidnodes, "moretrees:jungle_tree_sapling_ongen") | ||||||
| end | end | ||||||
|  |  | ||||||
| -- "empty" (tapped) rubber tree nodes | -- "empty" (tapped) rubber tree nodes | ||||||
| @@ -719,10 +367,10 @@ minetest.register_node("moretrees:rubber_tree_trunk_empty", { | |||||||
| 		"moretrees_rubber_tree_trunk_top.png", | 		"moretrees_rubber_tree_trunk_top.png", | ||||||
| 		"moretrees_rubber_tree_trunk_empty.png" | 		"moretrees_rubber_tree_trunk_empty.png" | ||||||
| 	}, | 	}, | ||||||
|  | 	is_ground_content = true, | ||||||
| 	groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | 	groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2}, | ||||||
| 	sounds = xcompat.sounds.node_sound_wood_defaults(), | 	sounds = default.node_sound_wood_defaults(), | ||||||
| 	paramtype2 = "facedir", | 	paramtype2 = "facedir", | ||||||
| 	is_ground_content = false, |  | ||||||
| 	on_place = minetest.rotate_node, | 	on_place = minetest.rotate_node, | ||||||
| }) | }) | ||||||
|  |  | ||||||
| @@ -732,12 +380,12 @@ minetest.register_abm({ | |||||||
| 	chance = 1, | 	chance = 1, | ||||||
| 	action = function(pos, node, active_object_count, active_object_count_wider) | 	action = function(pos, node, active_object_count, active_object_count_wider) | ||||||
| 		local fdir = node.param2 or 0 | 		local fdir = node.param2 or 0 | ||||||
| 			local nfdir = dirs2[fdir+1] | 			nfdir = dirs2[fdir+1] | ||||||
| 		minetest.add_node(pos, {name = "moretrees:rubber_tree_trunk_empty", param2 = nfdir}) | 		minetest.add_node(pos, {name = "moretrees:rubber_tree_trunk_empty", param2 = nfdir}) | ||||||
| 	end, | 	end, | ||||||
| }) | }) | ||||||
|  |  | ||||||
| -- For compatibility with old nodes, recently-changed nodes, and default nodes | -- For compatibility with old nodes and recently-changed nodes. | ||||||
|  |  | ||||||
| minetest.register_alias("technic:rubber_tree_full",      "moretrees:rubber_tree_trunk") | minetest.register_alias("technic:rubber_tree_full",      "moretrees:rubber_tree_trunk") | ||||||
| minetest.register_alias("farming_plus:rubber_tree_full", "moretrees:rubber_tree_trunk") | minetest.register_alias("farming_plus:rubber_tree_full", "moretrees:rubber_tree_trunk") | ||||||
| @@ -751,6 +399,15 @@ minetest.register_alias("technic:rubber_tree_sapling",			"moretrees:rubber_tree_ | |||||||
| minetest.register_alias("farming_plus:rubber_sapling", "moretrees:rubber_tree_sapling") | minetest.register_alias("farming_plus:rubber_sapling", "moretrees:rubber_tree_sapling") | ||||||
| minetest.register_alias("farming:rubber_sapling", "moretrees:rubber_tree_sapling") | minetest.register_alias("farming:rubber_sapling", "moretrees:rubber_tree_sapling") | ||||||
|  |  | ||||||
|  | minetest.register_alias("default:junglesapling","moretrees:jungletree_sapling") | ||||||
|  | minetest.register_alias("moretrees:jungletree_trunk_sideways", "moreblocks:horizontal_jungle_tree") | ||||||
|  | minetest.register_alias("moretrees:jungletree_trunk", "default:jungletree") | ||||||
|  | minetest.register_alias("moretrees:jungletree_planks", "default:junglewood") | ||||||
|  |  | ||||||
|  | minetest.register_alias("jungletree:leaves_green", "moretrees:jungletree_leaves_green") | ||||||
|  | minetest.register_alias("jungletree:leaves_red", "moretrees:jungletree_leaves_red") | ||||||
|  | minetest.register_alias("jungletree:leaves_yellow", "moretrees:jungletree_leaves_yellow") | ||||||
|  |  | ||||||
| minetest.register_alias("moretrees:conifer_trunk", "moretrees:fir_trunk") | minetest.register_alias("moretrees:conifer_trunk", "moretrees:fir_trunk") | ||||||
| minetest.register_alias("moretrees:conifer_trunk_sideways", "moretrees:fir_trunk_sideways") | minetest.register_alias("moretrees:conifer_trunk_sideways", "moretrees:fir_trunk_sideways") | ||||||
| minetest.register_alias("moretrees:conifer_leaves", "moretrees:fir_leaves") | minetest.register_alias("moretrees:conifer_leaves", "moretrees:fir_leaves") | ||||||
| @@ -763,22 +420,3 @@ minetest.register_alias("conifers:leaves",						"moretrees:fir_leaves") | |||||||
| minetest.register_alias("conifers:leaves_special", "moretrees:fir_leaves_bright") | minetest.register_alias("conifers:leaves_special", "moretrees:fir_leaves_bright") | ||||||
| minetest.register_alias("conifers:sapling", "moretrees:fir_sapling") | minetest.register_alias("conifers:sapling", "moretrees:fir_sapling") | ||||||
|  |  | ||||||
| minetest.register_alias("moretrees:jungletree_sapling",			"default:junglesapling") |  | ||||||
| minetest.register_alias("moretrees:jungletree_trunk_sideways",	"moreblocks:horizontal_jungle_tree") |  | ||||||
| minetest.register_alias("moretrees:jungletree_planks",			"default:junglewood") |  | ||||||
| minetest.register_alias("moretrees:jungletree_leaves_green",	xcompat.materials.jungle_leaves) |  | ||||||
|  |  | ||||||
| minetest.register_alias("moretrees:acacia_trunk",				"default:acacia_tree") |  | ||||||
| minetest.register_alias("moretrees:acacia_planks",				"default:acacia_wood") |  | ||||||
| minetest.register_alias("moretrees:acacia_sapling",				"default:acacia_sapling") |  | ||||||
| minetest.register_alias("moretrees:acacia_leaves",				"default:acacia_leaves") |  | ||||||
|  |  | ||||||
| minetest.register_alias("moretrees:pine_trunk",					"moretrees:cedar_trunk") |  | ||||||
| minetest.register_alias("moretrees:pine_planks",				"moretrees:cedar_planks") |  | ||||||
| minetest.register_alias("moretrees:pine_sapling",				"moretrees:cedar_sapling") |  | ||||||
| minetest.register_alias("moretrees:pine_leaves",				"moretrees:cedar_leaves") |  | ||||||
| minetest.register_alias("moretrees:pine_cone",					"moretrees:cedar_cone") |  | ||||||
| minetest.register_alias("moretrees:pine_nuts",					"moretrees:cedar_nuts") |  | ||||||
| minetest.register_alias("moretrees:pine_sapling_ongen",			"moretrees:cedar_sapling_ongen") |  | ||||||
|  |  | ||||||
| minetest.register_alias("moretrees:dates",					"moretrees:dates_f4") |  | ||||||
|   | |||||||
							
								
								
									
										168
									
								
								saplings.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,105 +1,93 @@ | |||||||
| -- sapling growth | -- sapling growth | ||||||
| -- these tables only affect hand-placed saplings |  | ||||||
| -- mapgen-placed always use their biome def settings, which are much more |  | ||||||
| -- limited, in the interest of speed. |  | ||||||
|  |  | ||||||
| local dirt_surfaces = { | for i in ipairs(moretrees.treelist) do | ||||||
| 	set = true, |  | ||||||
| 	[xcompat.materials.dirt] = true, |  | ||||||
| 	[xcompat.materials.dirt_with_grass] = true, |  | ||||||
| 	["default:dirt_with_dry_grass"] = true, |  | ||||||
| 	["default:dirt_with_coniferous_litter"] = true, |  | ||||||
| 	["default:dirt_with_rainforest_litter"] = true, |  | ||||||
| 	["woodsoils:dirt_with_leaves_1"] = true, |  | ||||||
| 	["woodsoils:dirt_with_leaves_2"] = true, |  | ||||||
| 	["woodsoils:grass_with_leaves_1"] = true, |  | ||||||
| 	["woodsoils:grass_with_leaves_2"] = true |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local conifer_surfaces =  { |  | ||||||
| 	set = true, |  | ||||||
| 	[xcompat.materials.dirt] = true, |  | ||||||
| 	[xcompat.materials.dirt_with_grass] = true, |  | ||||||
| 	["default:dirt_with_dry_grass"] = true, |  | ||||||
| 	["default:dirt_with_coniferous_litter"] = true, |  | ||||||
| 	["default:dirt_with_rainforest_litter"] = true, |  | ||||||
| 	["woodsoils:dirt_with_leaves_1"] = true, |  | ||||||
| 	["woodsoils:dirt_with_leaves_2"] = true, |  | ||||||
| 	["woodsoils:grass_with_leaves_1"] = true, |  | ||||||
| 	["woodsoils:grass_with_leaves_2"] = true, |  | ||||||
| 	["default:dirt_with_snow"] = true |  | ||||||
| } |  | ||||||
|  |  | ||||||
| local sand_surfaces = { |  | ||||||
| 	set = true, |  | ||||||
| 	[xcompat.materials.sand] = true, |  | ||||||
| 	[xcompat.materials.desert_sand] = true, |  | ||||||
| 	["cottages:loam"] = true, |  | ||||||
| 	-- note, no silver sand here. |  | ||||||
| 	-- too cold for a palm, too... well... sandy for anything else. |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function moretrees.can_grow(pos, treename) |  | ||||||
| 	local surfaces |  | ||||||
|  |  | ||||||
| 	if treename == "spruce" |  | ||||||
| 	  or treename == "fir" |  | ||||||
| 	  or treename == "cedar" |  | ||||||
| 	  or treename == "pine" then |  | ||||||
| 		surfaces = conifer_surfaces |  | ||||||
| 	elseif string.find(treename, "palm") then |  | ||||||
| 		surfaces = sand_surfaces |  | ||||||
| 	else |  | ||||||
| 		surfaces = dirt_surfaces |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	if surfaces[minetest.get_node(vector.new(pos.x, pos.y-1, pos.z)).name] then |  | ||||||
| 		return true |  | ||||||
| 	else |  | ||||||
| 		return false |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| --[[ for i in ipairs(moretrees.treelist) do |  | ||||||
| 	local treename = moretrees.treelist[i][1] | 	local treename = moretrees.treelist[i][1] | ||||||
| 	local tree_model = treename.."_model" | 	local tree_model = treename.."_model" | ||||||
| 	local tree_biome = treename.."_biome" | 	local tree_biome = treename.."_biome" | ||||||
| 	local surfaces |  | ||||||
| 	local grow_function = moretrees[tree_model] |  | ||||||
|  |  | ||||||
| 	if treename == "spruce" | 	if treename ~= "birch" and treename ~= "spruce" and treename ~= "fir" and treename ~= "jungletree" then | ||||||
| 	  or treename == "fir" |  | ||||||
| 	  or treename == "cedar" |  | ||||||
| 	  or treename == "pine" then |  | ||||||
| 		surfaces = conifer_surfaces |  | ||||||
| 	elseif string.find(treename, "palm") then |  | ||||||
| 		surfaces = sand_surfaces |  | ||||||
| 	else |  | ||||||
| 		surfaces = dirt_surfaces |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	if treename == "spruce" | 		plantslib:dbg(dump(moretrees[tree_biome].surface)) | ||||||
| 	  or treename == "fir" | 		plantslib:grow_plants({ | ||||||
| 	  or treename == "birch" |  | ||||||
| 	  or treename == "jungletree" then |  | ||||||
| 		grow_function = "moretrees.grow_"..treename |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	biome_lib.dbg(dump(moretrees[tree_biome].surface), 4) |  | ||||||
|  |  | ||||||
| 	biome_lib:grow_plants({ |  | ||||||
| 			grow_delay = moretrees.sapling_interval, | 			grow_delay = moretrees.sapling_interval, | ||||||
| 			grow_chance = moretrees.sapling_chance, | 			grow_chance = moretrees.sapling_chance, | ||||||
| 			grow_plant = "moretrees:"..treename.."_sapling", | 			grow_plant = "moretrees:"..treename.."_sapling", | ||||||
| 		grow_nodes = surfaces, | 			grow_nodes = moretrees[tree_biome].surface, | ||||||
| 		grow_function = grow_function, | 			grow_function = moretrees[tree_model], | ||||||
| 		}) | 		}) | ||||||
|  |  | ||||||
| 	biome_lib:grow_plants({ | 		plantslib:grow_plants({ | ||||||
| 			grow_delay = 2, | 			grow_delay = 2, | ||||||
| 		grow_chance = 1, | 			grow_chance = 30, | ||||||
| 			grow_plant = "moretrees:"..treename.."_sapling_ongen", | 			grow_plant = "moretrees:"..treename.."_sapling_ongen", | ||||||
| 		grow_nodes = surfaces, | 			grow_nodes = moretrees[tree_biome].surface, | ||||||
| 		grow_function = grow_function, | 			grow_function = moretrees[tree_model], | ||||||
| 		}) | 		}) | ||||||
| end ]] |  | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = moretrees.sapling_interval, | ||||||
|  | 	grow_chance = moretrees.sapling_chance, | ||||||
|  | 	grow_plant = "moretrees:birch_sapling", | ||||||
|  | 	grow_nodes = moretrees.birch_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_birch" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = 2, | ||||||
|  | 	grow_chance = 30, | ||||||
|  | 	grow_plant = "moretrees:birch_sapling_ongen", | ||||||
|  | 	grow_nodes = moretrees.birch_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_birch" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = moretrees.sapling_interval, | ||||||
|  | 	grow_chance = moretrees.sapling_chance, | ||||||
|  | 	grow_plant = "moretrees:spruce_sapling", | ||||||
|  | 	grow_nodes = moretrees.spruce_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_spruce" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = 2, | ||||||
|  | 	grow_chance = 30, | ||||||
|  | 	grow_plant = "moretrees:spruce_sapling_ongen", | ||||||
|  | 	grow_nodes = moretrees.spruce_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_spruce" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = moretrees.sapling_interval, | ||||||
|  | 	grow_chance = moretrees.sapling_chance, | ||||||
|  | 	grow_plant = "moretrees:fir_sapling", | ||||||
|  | 	grow_nodes = moretrees.fir_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_fir" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = 2, | ||||||
|  | 	grow_chance = 30, | ||||||
|  | 	grow_plant = "moretrees:fir_sapling_ongen", | ||||||
|  | 	grow_nodes = moretrees.fir_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_fir" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = moretrees.sapling_interval, | ||||||
|  | 	grow_chance = moretrees.sapling_chance, | ||||||
|  | 	grow_plant = "moretrees:jungletree_sapling", | ||||||
|  | 	grow_nodes = moretrees.jungletree_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_jungletree" | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | plantslib:grow_plants({ | ||||||
|  | 	grow_delay = 2, | ||||||
|  | 	grow_chance = 30, | ||||||
|  | 	grow_plant = "moretrees:jungletree_sapling_ongen", | ||||||
|  | 	grow_nodes = moretrees.jungletree_biome.surface, | ||||||
|  | 	grow_function = "moretrees:grow_jungletree" | ||||||
|  | }) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										169
									
								
								screenshot.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,169 +0,0 @@ | |||||||
| -- Usage: |  | ||||||
| -- - Create a new world |  | ||||||
| -- - Set world mapgen: v6 |  | ||||||
| -- - Set world seed: 2625051331357512570 |  | ||||||
| -- - Enable the moretrees mod |  | ||||||
| -- - Edit the moretrees source |  | ||||||
| --   - Disable all trees in default_settings.lua |  | ||||||
| --   - Recommended: make saplings grow fast in default_settings.lua: |  | ||||||
| --     sapling_interval = 5 |  | ||||||
| --     sapling_chance = 1 |  | ||||||
| --   - Apply the patch below to moretrees |  | ||||||
| --     (so that jungle trees are always large, and differently-colored): |  | ||||||
| --     use 'git apply --ignore-space-change' |  | ||||||
| --   - Make sure this file (you are reading) will be loaded when minetest starts ! |  | ||||||
| --     (e.g. add 'dofile(modpath.."/screenshot.lua")' to init.lua) |  | ||||||
| -- - Start minetest |  | ||||||
| -- - Goto 700,y,-280 (approximately) |  | ||||||
| -- - Make sure the world is loaded between x = 650 .. 780 and z = -350 .. -180 |  | ||||||
| -- - Give the chat command '/make-scene' |  | ||||||
| -- - Wait & walk/fly around until all trees have grown |  | ||||||
| -- - goto the platform at 780, 30, -277 |  | ||||||
| -- - Set the viewing range to 300, with fog enabled |  | ||||||
| -- - Take a screenshot. |  | ||||||
|  |  | ||||||
| -- Patch to apply to moretrees |  | ||||||
| --[[ |  | ||||||
| diff --git a/init.lua b/init.lua |  | ||||||
| index 8189ffd..afd4644 100644 |  | ||||||
| --- a/init.lua |  | ||||||
| +++ b/init.lua |  | ||||||
| @@ -225,9 +225,12 @@ moretrees.ct_rules_b1 = "[-FBf][+FBf]" |  | ||||||
|  moretrees.ct_rules_a2 = "FF[FF][&&-FBF][&&+FBF][&&---FBF][&&+++FBF]F/A" |  | ||||||
|  moretrees.ct_rules_b2 = "[-fB][+fB]" |  | ||||||
|  |  | ||||||
| +local jleaves = 1 |  | ||||||
|  function moretrees.grow_jungletree(pos) |  | ||||||
|         local r1 = math.random(2) |  | ||||||
|         local r2 = math.random(3) |  | ||||||
| +       r1 = jleaves |  | ||||||
| +       jleaves = jleaves % 2 + 1 |  | ||||||
|         if r1 == 1 then |  | ||||||
|                 moretrees.jungletree_model.leaves2 = "moretrees:jungletree_leaves_red" |  | ||||||
|         else |  | ||||||
| @@ -235,6 +238,7 @@ function moretrees.grow_jungletree(pos) |  | ||||||
|         end |  | ||||||
|         moretrees.jungletree_model.leaves2_chance = math.random(25, 75) |  | ||||||
|  |  | ||||||
| +       r2=3 |  | ||||||
|         if r2 == 1 then |  | ||||||
|                 moretrees.jungletree_model.trunk_type = "single" |  | ||||||
|                 moretrees.jungletree_model.iterations = 2 |  | ||||||
| ]] |  | ||||||
|  |  | ||||||
|  |  | ||||||
| minetest.register_chatcommand("make-scene", { |  | ||||||
| 	func = function() |  | ||||||
| 		minetest.place_node({x=780, y=30, z=-277}, {name="default:obsidian"}) |  | ||||||
| 		minetest.place_node({x=780, y=30, z=-278}, {name="default:obsidian"}) |  | ||||||
| 		minetest.place_node({x=781, y=30, z=-277}, {name="default:obsidian"}) |  | ||||||
| 		minetest.place_node({x=781, y=30, z=-278}, {name="default:obsidian"}) |  | ||||||
| 		minetest.place_node({x=781, y=30, z=-276}, {name="default:obsidian"}) |  | ||||||
| 		minetest.place_node({x=780, y=30, z=-276}, {name="default:obsidian"}) |  | ||||||
|  |  | ||||||
| 		for z = -360, -300 do |  | ||||||
| 			local dy=2 |  | ||||||
| 			for x = 630 + (-z - 360)/3, 660 + (-z - 300)/3 do |  | ||||||
| 				for y = 5, 22 do |  | ||||||
| 					minetest.place_node({x=x, y=y, z=z}, {name="default:desert_stone"}) |  | ||||||
| 				end |  | ||||||
| 				for y = 23, 25 + dy do |  | ||||||
| 					minetest.place_node({x=x, y=y, z=z}, {name="default:desert_sand"}) |  | ||||||
| 				end |  | ||||||
| 				dy = 0 |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=717, y=2, z=-298}, {name = "moretrees:palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=713, y=2, z=-302}, {name = "moretrees:palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=713, y=2, z=-307}, {name = "moretrees:palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=717, y=2, z=-318}, {name = "moretrees:palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=723, y=2, z=-320}, {name = "moretrees:palm_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=645, y=26, z=-314}, {name="moretrees:date_palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=653, y=26, z=-322}, {name="moretrees:date_palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=649, y=26, z=-334}, {name="moretrees:date_palm_sapling"}) |  | ||||||
| 		minetest.place_node({x=662, y=26, z=-342}, {name="moretrees:date_palm_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=672, y=5, z=-305}, {name="moretrees:oak_sapling"}) |  | ||||||
| 		minetest.place_node({x=690, y=6, z=-322}, {name="moretrees:oak_sapling"}) |  | ||||||
| 		minetest.place_node({x=695, y=7, z=-335}, {name="moretrees:oak_sapling"}) |  | ||||||
| 		minetest.place_node({x=699, y=4, z=-301}, {name="moretrees:oak_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=751, y=5, z=-254}, {name="moretrees:apple_tree_sapling"}) |  | ||||||
| 		minetest.place_node({x=729, y=3, z=-275}, {name="moretrees:apple_tree_sapling"}) |  | ||||||
| 		minetest.place_node({x=747, y=4, z=-270}, {name="moretrees:apple_tree_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=671, y=5, z=-283}, {name="default:junglesapling"}) |  | ||||||
| 		minetest.place_node({x=680, y=4, z=-287}, {name="default:junglesapling"}) |  | ||||||
| 		minetest.place_node({x=702, y=4, z=-288}, {name="default:junglesapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=646, y=12, z=-199}, {name="moretrees:spruce_sapling"}) |  | ||||||
| 		minetest.place_node({x=644, y=14, z=-177}, {name="moretrees:spruce_sapling"}) |  | ||||||
| 		minetest.place_node({x=678, y=9, z=-211}, {name="moretrees:spruce_sapling"}) |  | ||||||
| 		minetest.place_node({x=663, y=10, z=-215}, {name="moretrees:spruce_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=637, y=3, z=-263}, {name="moretrees:sequoia_sapling"}) |  | ||||||
| 		minetest.place_node({x=625, y=3, z=-250}, {name="moretrees:sequoia_sapling"}) |  | ||||||
| 		minetest.place_node({x=616, y=3, z=-233}, {name="moretrees:sequoia_sapling"}) |  | ||||||
| 		minetest.place_node({x=635, y=3, z=-276}, {name="moretrees:sequoia_sapling"}) |  | ||||||
| 		minetest.place_node({x=681, y=11, z=-260}, {name="moretrees:sequoia_sapling"}) |  | ||||||
| 		minetest.place_node({x=682, y=10, z=-247}, {name="moretrees:sequoia_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=737, y=7, z=-195}, {name="moretrees:cedar_sapling"}) |  | ||||||
| 		minetest.place_node({x=720, y=8, z=-189}, {name="moretrees:cedar_sapling"}) |  | ||||||
| 		minetest.place_node({x=704, y=7, z=-187}, {name="moretrees:cedar_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=731, y=2, z=-227}, {name="moretrees:poplar_sapling"}) |  | ||||||
| 		minetest.place_node({x=721, y=2, z=-233}, {name="moretrees:poplar_sapling"}) |  | ||||||
| 		minetest.place_node({x=712, y=1, z=-237}, {name="moretrees:poplar_sapling"}) |  | ||||||
| 		minetest.place_node({x=743, y=3, z=-228}, {name="moretrees:poplar_small_sapling"}) |  | ||||||
| 		minetest.place_node({x=750, y=3, z=-230}, {name="moretrees:poplar_small_sapling"}) |  | ||||||
| 		minetest.place_node({x=731, y=5, z=-233}, {name="moretrees:poplar_small_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=702, y=2, z=-274}, {name="moretrees:birch_sapling"}) |  | ||||||
| 		minetest.place_node({x=697, y=2, z=-271}, {name="moretrees:birch_sapling"}) |  | ||||||
| 		minetest.place_node({x=696, y=2, z=-264}, {name="moretrees:birch_sapling"}) |  | ||||||
| 		minetest.place_node({x=710, y=2, z=-265}, {name="moretrees:birch_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=707, y=8, z=-247}, {name="moretrees:fir_sapling"}) |  | ||||||
| 		minetest.place_node({x=699, y=10, z=-254}, {name="moretrees:fir_sapling"}) |  | ||||||
| 		minetest.place_node({x=729, y=5, z=-261}, {name="moretrees:fir_sapling"}) |  | ||||||
| 		minetest.place_node({x=732, y=5, z=-252}, {name="moretrees:fir_sapling"}) |  | ||||||
| 		minetest.place_node({x=741, y=4, z=-262}, {name="moretrees:fir_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=751, y=2, z=-286}, {name="moretrees:willow_sapling"}) |  | ||||||
|  |  | ||||||
| 		minetest.place_node({x=760, y=5, z=-223}, {name="moretrees:rubber_tree_sapling"}) |  | ||||||
| 		minetest.place_node({x=762, y=5, z=-230}, {name="moretrees:rubber_tree_sapling"}) |  | ||||||
| 		minetest.place_node({x=766, y=5, z=-243}, {name="moretrees:rubber_tree_sapling"}) |  | ||||||
| 		minetest.place_node({x=764, y=6, z=-252}, {name="moretrees:rubber_tree_sapling"}) |  | ||||||
| 	end |  | ||||||
| }) |  | ||||||
|  |  | ||||||
| --[[ |  | ||||||
| The following is a search/replace command suitable for vi (/vim) or sed, to convert minetest log |  | ||||||
| messages to equivalent lua commands: |  | ||||||
|  |  | ||||||
| s/.*\(\(moretrees\|default\)[^ ]*\) at |  | ||||||
| 	(\([-0-9]\+\),\([-0-9]\+\),\([-0-9]\+\)).*/\t\tminetest.place_node({x=\3, y=\4, z=\5}, {name="\1"})/ |  | ||||||
|  |  | ||||||
| E.g. a minetest log line of the following kind: |  | ||||||
| 		2016-07-03 11:30:50: ACTION[Server]: singleplayer places node moretrees:rubber_tree_sapling at  (760,5,-223) |  | ||||||
| Becomes: |  | ||||||
| 		minetest.place_node({x=760, y=5, z=-223}, {name="moretrees:rubber_tree_sapling"}) |  | ||||||
| (Except that the example log line above has an extra space added, so it won't be converted) |  | ||||||
|  |  | ||||||
| vi/vim users: Add the minetest log lines to this file, then enter the following command, with |  | ||||||
| <expression> replaced with the search/replace expression above. |  | ||||||
| 	:%<expression> |  | ||||||
|  |  | ||||||
| sed users: Add the minetest log lines to this file, then execute the following command at the shell |  | ||||||
| prompt with <expression> replaced by the search/replace expression above. Don't forget the |  | ||||||
| single-quotes. |  | ||||||
| 	sed '<expression>' < screenshot.lua > screenshot-new.lua |  | ||||||
|  |  | ||||||
| Windows users: You're probably out of luck. And the effort of doing such a thing is probably |  | ||||||
| larger anyway than the effort of copying an existing line and typing things manually. |  | ||||||
| ]] |  | ||||||
|  |  | ||||||
							
								
								
									
										
											BIN
										
									
								
								screenshot.png
									
									
									
									
									
								
							
							
						
						| Before Width: | Height: | Size: 101 KiB | 
							
								
								
									
										57
									
								
								settings.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,57 +0,0 @@ | |||||||
| local stg = minetest.settings |  | ||||||
|  |  | ||||||
| --spawns tree on mapgen as saplings, legacy setting |  | ||||||
| moretrees.spawn_saplings		= stg:get_bool("moretrees.spawn_saplings", true) |  | ||||||
|  |  | ||||||
| --enable plantlike drawtype for leaves |  | ||||||
| moretrees.plantlike_leaves		= stg:get_bool("moretrees.plantlike_leaves", false) |  | ||||||
|  |  | ||||||
| -- Enable this if you want moretrees to redefine default apples so that they |  | ||||||
| -- fall when leaves decay/are dug. |  | ||||||
| moretrees.enable_redefine_apple		= stg:get_bool("moretrees.enable_redefine_apple", true) |  | ||||||
|  |  | ||||||
| -- various related settings to configure leaf decay. |  | ||||||
| moretrees.leafdecay_radius		= tonumber(stg:get("moretrees.leafdecay_radius")) or 5 |  | ||||||
| moretrees.palm_leafdecay_radius		= tonumber(stg:get("moretrees.palm_leafdecay_radius")) or 10 |  | ||||||
| moretrees.date_palm_leafdecay_radius	= tonumber(stg:get("moretrees.date_palm_leafdecay_radius")) or 14 |  | ||||||
|  |  | ||||||
| -- Cocos palm settings |  | ||||||
| moretrees.coconuts_regrow		= stg:get_bool("moretrees.coconuts_regrow", true) |  | ||||||
| moretrees.coconuts_convert_existing_palms = stg:get_bool("moretrees.coconuts_convert_existing_palms", true) |  | ||||||
| moretrees.coconut_flower_interval	= tonumber(stg:get("moretrees.coconut_flower_interval")) or 59 |  | ||||||
| moretrees.coconut_flower_chance		= tonumber(stg:get("moretrees.coconut_flower_chance")) or 67 |  | ||||||
| moretrees.coconut_grow_interval		= tonumber(stg:get("moretrees.coconut_grow_interval")) or |  | ||||||
|     2 * moretrees.coconut_flower_interval * moretrees.coconut_flower_chance |  | ||||||
| moretrees.coconut_item_drop_ichance	= tonumber(stg:get("moretrees.coconut_item_drop_ichance")) or 10 |  | ||||||
|  |  | ||||||
| -- Date palm settings |  | ||||||
| moretrees.dates_regrow_pollinated	= stg:get_bool("moretrees.dates_regrow_pollinated", true) |  | ||||||
| moretrees.dates_regrow_unpollinated_percent	= tonumber(stg:get("moretrees.dates_regrow_unpollinated_percent")) or 0 |  | ||||||
| moretrees.dates_female_percent		= tonumber(stg:get("moretrees.dates_female_percent")) or 57 |  | ||||||
| moretrees.dates_pollination_distance	= tonumber(stg:get("moretrees.dates_pollination_distance")) or 120 |  | ||||||
| moretrees.dates_blossom_search_time_treshold = tonumber(stg:get("moretrees.dates_blossom_search_time_treshold")) or 1000 |  | ||||||
| moretrees.dates_blossom_search_iload = tonumber(stg:get("moretrees.dates_blossom_search_iload")) or 10 |  | ||||||
| moretrees.dates_flower_interval		= tonumber(stg:get("moretrees.dates_flower_interval")) or 59 |  | ||||||
| moretrees.dates_flower_chance		= tonumber(stg:get("moretrees.dates_flower_chance")) or 181 |  | ||||||
| moretrees.dates_grow_interval		= tonumber(stg:get("moretrees.dates_grow_interval")) or |  | ||||||
|     2 * moretrees.dates_flower_interval * moretrees.dates_flower_chance |  | ||||||
| moretrees.dates_item_drop_ichance	= tonumber(stg:get("moretrees.dates_item_drop_ichance")) or 10 |  | ||||||
|  |  | ||||||
| -- Sapling settings |  | ||||||
| moretrees.sapling_interval		= 100 |  | ||||||
| moretrees.sapling_chance		= 5 |  | ||||||
|  |  | ||||||
| -- Enable this only if you have used an old moretrees version which was using biome_lib |  | ||||||
| -- and when you notice large areas with ongen saplings that don't grow |  | ||||||
| moretrees.grow_legacy_saplings	= stg:get_bool("moretrees.grow_legacy_saplings", false) |  | ||||||
|  |  | ||||||
| -- If this variable is set to true, drop leaves out as entities during leaf |  | ||||||
| -- decay, rather than just disappearing them. |  | ||||||
| moretrees.decay_leaves_as_items = stg:get_bool("moretrees.decay_leaves_as_items", false) |  | ||||||
|  |  | ||||||
| -- this is an internal setting for games that only have one type of planks |  | ||||||
| if type(minetest.get_game_info) == "function" then |  | ||||||
|     moretrees.enable_planks = minetest.get_game_info().id~="voxelgarden" |  | ||||||
| else |  | ||||||
|     moretrees.enable_planks = true |  | ||||||
| end |  | ||||||
							
								
								
									
										
											BIN
										
									
								
								textures/moretrees_acacia_leaves.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 150 B | 
							
								
								
									
										
											BIN
										
									
								
								textures/moretrees_acacia_sapling.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 205 B | 
							
								
								
									
										
											BIN
										
									
								
								textures/moretrees_acacia_trunk.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 599 B | 
							
								
								
									
										
											BIN
										
									
								
								textures/moretrees_acacia_trunk_top.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 651 B | 
							
								
								
									
										
											BIN
										
									
								
								textures/moretrees_acacia_wood.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 175 B | 
| Before Width: | Height: | Size: 877 B | 
| Before Width: | Height: | Size: 429 B | 
| Before Width: | Height: | Size: 1009 B | 
| Before Width: | Height: | Size: 2.1 KiB | 
| Before Width: | Height: | Size: 685 B | 
| Before Width: | Height: | Size: 608 B | 
| Before Width: | Height: | Size: 695 B | 
| Before Width: | Height: | Size: 450 B | 
| Before Width: | Height: | Size: 757 B | 
| Before Width: | Height: | Size: 261 B | 
| Before Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 673 B | 
| Before Width: | Height: | Size: 735 B | 
| Before Width: | Height: | Size: 9.2 KiB | 
| Before Width: | Height: | Size: 3.8 KiB | 
| Before Width: | Height: | Size: 4.0 KiB | 
| Before Width: | Height: | Size: 8.9 KiB | 
| Before Width: | Height: | Size: 8.1 KiB | 
| Before Width: | Height: | Size: 9.0 KiB | 
| Before Width: | Height: | Size: 2.5 KiB | 
| Before Width: | Height: | Size: 4.0 KiB | 
| Before Width: | Height: | Size: 2.1 KiB | 
| Before Width: | Height: | Size: 315 B After Width: | Height: | Size: 315 B | 
| Before Width: | Height: | Size: 205 B After Width: | Height: | Size: 205 B | 
| Before Width: | Height: | Size: 369 B After Width: | Height: | Size: 369 B | 
| Before Width: | Height: | Size: 202 B After Width: | Height: | Size: 202 B | 
| Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1.0 KiB | 
| Before Width: | Height: | Size: 451 B After Width: | Height: | Size: 451 B | 
| Before Width: | Height: | Size: 648 B After Width: | Height: | Size: 648 B | 
| Before Width: | Height: | Size: 563 B | 
| Before Width: | Height: | Size: 447 B | 
| Before Width: | Height: | Size: 347 B | 
| Before Width: | Height: | Size: 1.2 KiB | 
| Before Width: | Height: | Size: 980 B | 
| Before Width: | Height: | Size: 751 B | 
| Before Width: | Height: | Size: 726 B | 
| @@ -1,22 +1,21 @@ | |||||||
|  |  | ||||||
| 		Elevation	Temperature	Nearness to	Nearby	What nodes		Perlin		Avoid | 		Elevation	Temperature	Nearness to	Nearby	What nodes		Perlin		Avoid | ||||||
| Tree type	   (m)		(approx., °C)	some node	water	to spawn on		seed diff	radius | Tree type	   (m)		(approx., °C)	some node	water	to spawn on		seed diff	radius | ||||||
| -------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | ||||||
| jungle tree	- 5 to +10	 above +15	water, 20	  10	dirt_with_grass		329		 5 | jungle tree	- 5 to +10	 above +15	water, 20	  10	dirt_with_grass		329		 5 | ||||||
| fir		 above +25	-20 to +10	  n/a		n/a	dirt_with_grass		359		 8 | fir		 above +25	-20 to +10	  n/a		n/a	dirt_with_grass		359		 8 | ||||||
| firs on snow	 above +15	-20 to +10	  n/a		n/a	snow:snow		359		 8 | firs on snow	 above +15	-20 to +10	  n/a		n/a	snow:snow		359		 8 | ||||||
| palm		- 1 to + 1	+15 to +32	water, 15	  10	sand			330		 5 | palm		- 1 to + 1	+15 to +32	water, 15	  10	sand			330		 5 | ||||||
| date palm		- 1 to +10		 above +39		water, 20h,20v	100		desert_sand			339			10 |  | ||||||
| date palm		+11 to +30		 above +39		water, 1h,30v	  1		desert_sand			340			10 |  | ||||||
| apple		+ 1 to +10	+23 to +32	  n/a		n/a	dirt_with grass		331		15 | apple		+ 1 to +10	+23 to +32	  n/a		n/a	dirt_with grass		331		15 | ||||||
| oak		  0 to +10	+ 4 to +16	  n/a		n/a	dirt_with grass		332		15 | oak		  0 to +10	+ 4 to +16	  n/a		n/a	dirt_with grass		332		15 | ||||||
| sequoia		  0 to +10	-30 to +50	  n/a		n/a	dirt_with grass		333		10 | sequoia		  0 to +10	-30 to +50	  n/a		n/a	dirt_with grass		333		10 | ||||||
| birch		+10 to +15	-20 to +10	  n/a		n/a	dirt_with grass		334		 5 | birch		+10 to +15	-20 to +10	  n/a		n/a	dirt_with grass		334		 5 | ||||||
| spruce		 above +20	-20 to +10	  n/a		n/a	dirt_with grass		335		10 | spruce		 above +20	-20 to +10	  n/a		n/a	dirt_with grass		335		10 | ||||||
| cedar			    n/a			    n/a			water, 15		  5		dirt_with grass		336			10 | pine		    n/a		    n/a		water, 15	   5	dirt_with grass		336		10 | ||||||
| willow		- 5 to + 5	    n/a		water, 15	   5	dirt_with grass		337		20 | willow		- 5 to + 5	    n/a		water, 15	   5	dirt_with grass		337		20 | ||||||
|  | acacia		    n/a		    n/a		  n/a		n/a	dirt_with_grass, | ||||||
|  | 									desert_sand		n/a		15 | ||||||
| rubber		- 5 to + 5	 above +32	water, 15	  10	dirt_with_grass		338		20 | rubber		- 5 to + 5	 above +32	water, 15	  10	dirt_with_grass		338		20 | ||||||
| poplar			    n/a			-10 to +26		water, 15h,5v	  1		dirt_with_grass		341,342,343	10 |  | ||||||
|  |  | ||||||
| beech		    n/a		    n/a		  n/a		n/a	dirt_with_grass		2		10 | beech		    n/a		    n/a		  n/a		n/a	dirt_with_grass		2		10 | ||||||
|  |  | ||||||
| @@ -27,8 +26,9 @@ Notes: | |||||||
| Beech trees are meant to replace default trees, but are themselves disabled by default.  They grow in the same areas | Beech trees are meant to replace default trees, but are themselves disabled by default.  They grow in the same areas | ||||||
| as the default ones do, and under the same conditions. | as the default ones do, and under the same conditions. | ||||||
|  |  | ||||||
|  | Acacia trees depend on humidity as their primary control, and they don't use the fertile ground option. They grow near | ||||||
|  | the edges of a desert biome, occasionally into the grass beyond, and anywhere else on desert sand or dirt with grass, | ||||||
|  | where the humidity is low (but not bone dry). | ||||||
|  |  | ||||||
| Fir trees appear in a snow biome only with older versions of SPlizard's Snow Biomes mod.  In more recent versions, | Fir trees appear in a snow biome only with older versions of SPlizard's Snow Biomes mod.  In more recent versions, | ||||||
| these trees will not grow, due to an engine bug. | these trees will not grow, due to an engine bug. | ||||||
|  |  | ||||||
| Cedar trees replace, and are identical to, the original pine trees, as the minetest default game now has (a completely |  | ||||||
| different type of) pine trees. |  | ||||||
|   | |||||||
							
								
								
									
										155
									
								
								tree_models.lua
									
									
									
									
									
								
							
							
						
						| @@ -1,6 +1,5 @@ | |||||||
| moretrees.beech_model={ | moretrees.beech_model={ | ||||||
| 	axiom="FFFFFBFB", | 	axiom="FFFFFBFB", | ||||||
| 	-- luacheck: no max line length |  | ||||||
| 	rules_a="[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fdd]]", | 	rules_a="[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fdd]]", | ||||||
| 	rules_b="[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&Fd]//d[+^d][--&d]]", | 	rules_b="[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&Fd]//d[+^d][--&d]]", | ||||||
| 	rules_c="/", | 	rules_c="/", | ||||||
| @@ -11,7 +10,8 @@ moretrees.beech_model={ | |||||||
| 	iterations=2, | 	iterations=2, | ||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.apple_tree_model={ | moretrees.apple_tree_model={ | ||||||
| @@ -25,8 +25,9 @@ moretrees.apple_tree_model={ | |||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit=minetest.get_modpath("default") and "default:apple" or nil, | 	fruit="default:apple", | ||||||
| 	fruit_chance=minetest.get_modpath("default") and 15 or nil, | 	fruit_chance=15, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.oak_model={ | moretrees.oak_model={ | ||||||
| @@ -42,41 +43,11 @@ moretrees.oak_model={ | |||||||
| 	thin_branches=false, | 	thin_branches=false, | ||||||
| 	fruit="moretrees:acorn", | 	fruit="moretrees:acorn", | ||||||
| 	fruit_chance=3, | 	fruit_chance=3, | ||||||
| } | 	enable_unique_ids = true, | ||||||
|  |  | ||||||
| moretrees.poplar_model={ |  | ||||||
| 	axiom="TTTaaBCCCCCCCCCCCcccBBB[[f]&&G++f++Gf++Gf++Gf++G--]G[[f]&&G++f++Gf++Gf++Gf++G--]Gff", |  | ||||||
| 	rules_a="T", |  | ||||||
| 	rules_b="[[T]&&G++f++ff++ff++ff++f--]G", |  | ||||||
| 	rules_c="[[T]&&G++f++ff++ff++ff++f--G++[d]G[d]G++G[d]G[d]G[d]G++G[d]G[d]G[d]G++G[d]G[d]G[d]G++G[d]G]G", |  | ||||||
| 	rules_d="f", |  | ||||||
| 	trunk="moretrees:poplar_trunk", |  | ||||||
| 	leaves="moretrees:poplar_leaves", |  | ||||||
| 	angle=45, |  | ||||||
| 	iterations=0, |  | ||||||
| 	random_level=0, |  | ||||||
| 	trunk_type="single", |  | ||||||
| 	thin_branches=false, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| moretrees.poplar_small_model={ |  | ||||||
| 	axiom="TT[T]BCCCCccBBff", |  | ||||||
| 	rules_a="T", |  | ||||||
| 	rules_b="[[f]&&G++f++Gf++Gf++Gf++G--]G", |  | ||||||
| 	rules_c="[[T]&&G++f++[d]Gf++[d]Gf++[d]Gf++[d]G--]G", |  | ||||||
| 	rules_d="f", |  | ||||||
| 	trunk="moretrees:poplar_trunk", |  | ||||||
| 	leaves="moretrees:poplar_leaves", |  | ||||||
| 	angle=45, |  | ||||||
| 	iterations=0, |  | ||||||
| 	random_level=0, |  | ||||||
| 	trunk_type="single", |  | ||||||
| 	thin_branches=false, |  | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.sequoia_model={ | moretrees.sequoia_model={ | ||||||
| 	axiom="FFFFFFFFFFddccA///cccFddcFA///ddFcFA/cFFddFcdBddd/A/ccdcddd/ccAddddcFBcccAccFdFcFBcccc/BFdFFcFFdcccc/B", | 	axiom="FFFFFFFFFFddccA///cccFddcFA///ddFcFA/cFFddFcdBddd/A/ccdcddd/ccAddddcFBcccAccFdFcFBcccc/BFdFFcFFdcccc/B", | ||||||
| 	-- luacheck: no max line length |  | ||||||
| 	rules_a="[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]", | 	rules_a="[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]", | ||||||
| 	rules_b="[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]", | 	rules_b="[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]", | ||||||
| 	rules_c="/", | 	rules_c="/", | ||||||
| @@ -87,7 +58,8 @@ moretrees.sequoia_model={ | |||||||
| 	iterations=2, | 	iterations=2, | ||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="crossed", | 	trunk_type="crossed", | ||||||
| 	thin_branches=true | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.birch_model1={ | moretrees.birch_model1={ | ||||||
| @@ -102,7 +74,8 @@ moretrees.birch_model1={ | |||||||
| 	iterations=2, | 	iterations=2, | ||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.birch_model2={ | moretrees.birch_model2={ | ||||||
| @@ -117,16 +90,12 @@ moretrees.birch_model2={ | |||||||
| 	iterations=2, | 	iterations=2, | ||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| -- Coconuts can't be generated as fruit, because there is no support for the |  | ||||||
| -- special fruit trunks that allow coconuts to regrow at the correct position |  | ||||||
| -- in the tree. |  | ||||||
| -- So, a placeholder fruit trunk is spawned. An ABM will convert it to the final |  | ||||||
| -- fruit trunk, and generate the actual coconuts. |  | ||||||
| moretrees.palm_model={ | moretrees.palm_model={ | ||||||
| 	axiom="FFcccccc&FFFFFdddRA//A//A//A//A//A", | 	axiom="FFcccccc&FFFFFddd[^&&&GR][^///&&&GR][^//////&&&GR][^***&&&GR]FA//A//A//A//A//A", | ||||||
| 	rules_a="[&fb&bbb[++f--&ffff&ff][--f++&ffff&ff]&ffff&bbbb&b]", | 	rules_a="[&fb&bbb[++f--&ffff&ff][--f++&ffff&ff]&ffff&bbbb&b]", | ||||||
| 	rules_b="f", | 	rules_b="f", | ||||||
| 	rules_c="/", | 	rules_c="/", | ||||||
| @@ -138,37 +107,12 @@ moretrees.palm_model={ | |||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit="moretrees:palm_fruit_trunk_gen", | 	fruit="moretrees:coconut", | ||||||
| 	fruit_chance=0 | 	fruit_chance=0, | ||||||
| } | 	enable_unique_ids = true, | ||||||
|  |  | ||||||
| -- Dates can't be generated as fruit, because there is no support for the |  | ||||||
| -- special (male and female) fruit trunks that allow dates to regrow at the |  | ||||||
| -- correct position in the tree. |  | ||||||
| -- So, a generic fruit trunk is spawned. An ABM will convert it to a male |  | ||||||
| -- or female fruit trunk, and generate the actual dates. |  | ||||||
| moretrees.date_palm_model={ |  | ||||||
| 	axiom="TTTTddddddddddccccccccccRT[TTT]".. |  | ||||||
| 		"ccccc[&&a]ccccc[&&a]ccccc[&&a]ccccc[&&a]ccccc[&&a]ccccc[&&a]".. |  | ||||||
| 		"GGccccc[&a]ccccc[&a]ccccc[&a]ccccc[&a]ccccc[&a]ccccc[&a]".. |  | ||||||
| 		"GGccccc[a]ccccc[a]ccccc[a]ccccc[a]ccccc[a]ccccc[a]", |  | ||||||
| 	rules_a="Gffb&bbb[++f--&ffff&ff][--f++&ffff&ff]&ff&ff&bb&bb&bb", |  | ||||||
| 	rules_b="f", |  | ||||||
| 	rules_c="/", |  | ||||||
| 	rules_d="F", |  | ||||||
| 	trunk="moretrees:date_palm_trunk", |  | ||||||
| 	leaves="moretrees:date_palm_leaves", |  | ||||||
| 	angle=18, |  | ||||||
| 	iterations=1, |  | ||||||
| 	random_level=0, |  | ||||||
| 	trunk_type="single", |  | ||||||
| 	thin_branches=false, |  | ||||||
| 	fruit="moretrees:date_palm_fruit_trunk", |  | ||||||
| 	fruit_chance=0 |  | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.spruce_model1={ | moretrees.spruce_model1={ | ||||||
| 	-- luacheck: no max line length |  | ||||||
| 	axiom="FFFFFAFFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]", | 	axiom="FFFFFAFFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]", | ||||||
| 	rules_a="[&&&FFFFFF^^FFF][&&&++FFFFFF^^FFF][&&&++++FFFFFF^^FFF][&&&++++++FFFFFF^^FFF][&&&--FFFFFF^^FFF][&&&----FFFFFF^^FFF]", | 	rules_a="[&&&FFFFFF^^FFF][&&&++FFFFFF^^FFF][&&&++++FFFFFF^^FFF][&&&++++++FFFFFF^^FFF][&&&--FFFFFF^^FFF][&&&----FFFFFF^^FFF]", | ||||||
| 	rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]", | 	rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]", | ||||||
| @@ -182,11 +126,11 @@ moretrees.spruce_model1={ | |||||||
| 	trunk_type="crossed", | 	trunk_type="crossed", | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit="moretrees:spruce_cone", | 	fruit="moretrees:spruce_cone", | ||||||
| 	fruit_chance=8 | 	fruit_chance=8, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.spruce_model2={ | moretrees.spruce_model2={ | ||||||
| 	-- luacheck: no max line length |  | ||||||
| 	axiom="FFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]", | 	axiom="FFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]", | ||||||
| 	rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]", | 	rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]", | ||||||
| 	rules_c="[&&&FFFF^^FFF][&&&++FFFF^^FFF][&&&++++FFFF^^FFF][&&&++++++FFFF^^FFF][&&&--FFFF^^FFF][&&&----FFFF^^FFF]", | 	rules_c="[&&&FFFF^^FFF][&&&++FFFF^^FFF][&&&++++FFFF^^FFF][&&&++++++FFFF^^FFF][&&&--FFFF^^FFF][&&&----FFFF^^FFF]", | ||||||
| @@ -199,29 +143,30 @@ moretrees.spruce_model2={ | |||||||
| 	trunk_type="crossed", | 	trunk_type="crossed", | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit="moretrees:spruce_cone", | 	fruit="moretrees:spruce_cone", | ||||||
| 	fruit_chance=8 | 	fruit_chance=8, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.cedar_model={ | moretrees.pine_model={ | ||||||
| 	axiom="FFFFFcccdddB///cFdFB////cFdFB///cFdFB///cFdFA///cFdFA///cFdFB[FF]f", | 	axiom="FFFFFcccdddB///cFdFB////cFdFB///cFdFB///cFdFA///cFdFA///cFdFB[FF]f", | ||||||
| 	rules_a="[&&&TTTT[++^TFdd][--&TFd]//Tdd[+^Fd][--&Fdd]]", | 	rules_a="[&&&TTTT[++^TFdd][--&TFd]//Tdd[+^Fd][--&Fdd]]", | ||||||
| 	rules_b="[&&&TTT[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]", | 	rules_b="[&&&TTT[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]", | ||||||
| 	rules_c="/", | 	rules_c="/", | ||||||
| 	rules_d="F", | 	rules_d="F", | ||||||
| 	trunk="moretrees:cedar_trunk", | 	trunk="moretrees:pine_trunk", | ||||||
| 	leaves="moretrees:cedar_leaves", | 	leaves="moretrees:pine_leaves", | ||||||
| 	angle=30, | 	angle=30, | ||||||
| 	iterations=2, | 	iterations=2, | ||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit="moretrees:cedar_cone", | 	fruit="moretrees:pine_cone", | ||||||
| 	fruit_chance=8 | 	fruit_chance=8, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.willow_model={ | moretrees.willow_model={ | ||||||
| 	axiom="FFFFFFFFccA", | 	axiom="FFFFFFFFccA", | ||||||
| 	-- luacheck: no max line length |  | ||||||
| 	rules_a="[&FF&FFFF&&F&FFFFFFFdddd][**&FF&FFFF&&F&FFFFFFFdddd][//&FF&FFFF&&F&FFFFFFFdddd][////&FF&FFFF&&F&FFFFFFFdddd][//////&FF&FFFF&&F&FFFFFFFdddd][////////&FF&FFFF&&F&FFFFFFFdddd]", | 	rules_a="[&FF&FFFF&&F&FFFFFFFdddd][**&FF&FFFF&&F&FFFFFFFdddd][//&FF&FFFF&&F&FFFFFFFdddd][////&FF&FFFF&&F&FFFFFFFdddd][//////&FF&FFFF&&F&FFFFFFFdddd][////////&FF&FFFF&&F&FFFFFFFdddd]", | ||||||
| 	rules_c="/", | 	rules_c="/", | ||||||
| 	rules_d="F", | 	rules_d="F", | ||||||
| @@ -231,7 +176,40 @@ moretrees.willow_model={ | |||||||
| 	iterations=2, | 	iterations=2, | ||||||
| 	random_level=0, | 	random_level=0, | ||||||
| 	trunk_type="crossed", | 	trunk_type="crossed", | ||||||
| 	thin_branches=true | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | moretrees.acacia_model={ | ||||||
|  | 	axiom="FFFFFFccccA", | ||||||
|  | 	rules_a = "[B]//[B]//[B]//[B]", | ||||||
|  | 	rules_b = "&TTTT&TT^^G&&----GGGGGG++GGG++"	-- line up with the "canvas" edge | ||||||
|  | 			.."fffffffGG++G++"					-- first layer, drawn in a zig-zag raster pattern | ||||||
|  | 			.."Gffffffff--G--" | ||||||
|  | 			.."ffffffffG++G++" | ||||||
|  | 			.."fffffffff--G--" | ||||||
|  | 			.."fffffffff++G++" | ||||||
|  | 			.."fffffffff--G--" | ||||||
|  | 			.."ffffffffG++G++" | ||||||
|  | 			.."Gffffffff--G--" | ||||||
|  | 			.."fffffffGG" | ||||||
|  | 			.."^^G&&----GGGGGGG++GGGGGG++"		-- re-align to second layer canvas edge | ||||||
|  | 			.."ffffGGG++G++"					-- second layer | ||||||
|  | 			.."GGfffff--G--" | ||||||
|  | 			.."ffffffG++G++" | ||||||
|  | 			.."fffffff--G--" | ||||||
|  | 			.."ffffffG++G++" | ||||||
|  | 			.."GGfffff--G--" | ||||||
|  | 			.."ffffGGG", | ||||||
|  | 	rules_c = "/", | ||||||
|  | 	trunk="moretrees:acacia_trunk", | ||||||
|  | 	leaves="moretrees:acacia_leaves", | ||||||
|  | 	angle=45, | ||||||
|  | 	iterations=3, | ||||||
|  | 	random_level=0, | ||||||
|  | 	trunk_type="single", | ||||||
|  | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.rubber_tree_model={ | moretrees.rubber_tree_model={ | ||||||
| @@ -244,15 +222,16 @@ moretrees.rubber_tree_model={ | |||||||
| 	iterations=3, | 	iterations=3, | ||||||
| 	random_level=1, | 	random_level=1, | ||||||
| 	trunk_type="double", | 	trunk_type="double", | ||||||
| 	thin_branches=true | 	thin_branches=true, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.jungletree_model={ | moretrees.jungletree_model={ | ||||||
| 	axiom=nil, | 	axiom=nil, | ||||||
| 	rules_a=nil, | 	rules_a=nil, | ||||||
| 	rules_b=nil, | 	rules_b=nil, | ||||||
| 	trunk="moretrees:jungletree_trunk", | 	trunk="default:jungletree", | ||||||
| 	leaves=xcompat.materials.jungle_leaves, | 	leaves="moretrees:jungletree_leaves_green", | ||||||
| 	leaves2=nil, | 	leaves2=nil, | ||||||
| 	leaves2_chance=nil, | 	leaves2_chance=nil, | ||||||
| 	angle=45, | 	angle=45, | ||||||
| @@ -261,7 +240,8 @@ moretrees.jungletree_model={ | |||||||
| 	trunk_type=nil, | 	trunk_type=nil, | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit_chance=15, | 	fruit_chance=15, | ||||||
| 	fruit="vines:vine" | 	fruit="vines:vine", | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|  |  | ||||||
| moretrees.fir_model={ | moretrees.fir_model={ | ||||||
| @@ -276,5 +256,6 @@ moretrees.fir_model={ | |||||||
| 	trunk_type="single", | 	trunk_type="single", | ||||||
| 	thin_branches=true, | 	thin_branches=true, | ||||||
| 	fruit="moretrees:fir_cone", | 	fruit="moretrees:fir_cone", | ||||||
| 	fruit_chance=8 | 	fruit_chance=8, | ||||||
|  | 	enable_unique_ids = true, | ||||||
| } | } | ||||||
|   | |||||||