commit b2597068071536125d85943f4bfe6e20aa96985a
Author: 延皓 <1214946206@qq.com>
Date: Sat Jul 3 18:55:08 2021 +0800
2.1.0
diff --git a/LICENSE b/LICENSE
new file mode 100644
index 0000000..94a9ed0
--- /dev/null
+++ b/LICENSE
@@ -0,0 +1,674 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 3, 29 June 2007
+
+ Copyright (C) 2007 Free Software Foundation, Inc.
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The GNU General Public License is a free, copyleft license for
+software and other kinds of works.
+
+ The licenses for most software and other practical works are designed
+to take away your freedom to share and change the works. By contrast,
+the GNU General Public License is intended to guarantee your freedom to
+share and change all versions of a program--to make sure it remains free
+software for all its users. We, the Free Software Foundation, use the
+GNU General Public License for most of our software; it applies also to
+any other work released this way by its authors. You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+them if you wish), that you receive source code or can get it if you
+want it, that you can change the software or use pieces of it in new
+free programs, and that you know you can do these things.
+
+ To protect your rights, we need to prevent others from denying you
+these rights or asking you to surrender the rights. Therefore, you have
+certain responsibilities if you distribute copies of the software, or if
+you modify it: responsibilities to respect the freedom of others.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must pass on to the recipients the same
+freedoms that you received. You must make sure that they, too, receive
+or can get the source code. And you must show them these terms so they
+know their rights.
+
+ Developers that use the GNU GPL protect your rights with two steps:
+(1) assert copyright on the software, and (2) offer you this License
+giving you legal permission to copy, distribute and/or modify it.
+
+ For the developers' and authors' protection, the GPL clearly explains
+that there is no warranty for this free software. For both users' and
+authors' sake, the GPL requires that modified versions be marked as
+changed, so that their problems will not be attributed erroneously to
+authors of previous versions.
+
+ Some devices are designed to deny users access to install or run
+modified versions of the software inside them, although the manufacturer
+can do so. This is fundamentally incompatible with the aim of
+protecting users' freedom to change the software. The systematic
+pattern of such abuse occurs in the area of products for individuals to
+use, which is precisely where it is most unacceptable. Therefore, we
+have designed this version of the GPL to prohibit the practice for those
+products. If such problems arise substantially in other domains, we
+stand ready to extend this provision to those domains in future versions
+of the GPL, as needed to protect the freedom of users.
+
+ Finally, every program is threatened constantly by software patents.
+States should not allow patents to restrict development and use of
+software on general-purpose computers, but in those that do, we wish to
+avoid the special danger that patents applied to a free program could
+make it effectively proprietary. To prevent this, the GPL assures that
+patents cannot be used to render the program non-free.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ TERMS AND CONDITIONS
+
+ 0. Definitions.
+
+ "This License" refers to version 3 of the GNU General Public License.
+
+ "Copyright" also means copyright-like laws that apply to other kinds of
+works, such as semiconductor masks.
+
+ "The Program" refers to any copyrightable work licensed under this
+License. Each licensee is addressed as "you". "Licensees" and
+"recipients" may be individuals or organizations.
+
+ To "modify" a work means to copy from or adapt all or part of the work
+in a fashion requiring copyright permission, other than the making of an
+exact copy. The resulting work is called a "modified version" of the
+earlier work or a work "based on" the earlier work.
+
+ A "covered work" means either the unmodified Program or a work based
+on the Program.
+
+ To "propagate" a work means to do anything with it that, without
+permission, would make you directly or secondarily liable for
+infringement under applicable copyright law, except executing it on a
+computer or modifying a private copy. Propagation includes copying,
+distribution (with or without modification), making available to the
+public, and in some countries other activities as well.
+
+ To "convey" a work means any kind of propagation that enables other
+parties to make or receive copies. Mere interaction with a user through
+a computer network, with no transfer of a copy, is not conveying.
+
+ An interactive user interface displays "Appropriate Legal Notices"
+to the extent that it includes a convenient and prominently visible
+feature that (1) displays an appropriate copyright notice, and (2)
+tells the user that there is no warranty for the work (except to the
+extent that warranties are provided), that licensees may convey the
+work under this License, and how to view a copy of this License. If
+the interface presents a list of user commands or options, such as a
+menu, a prominent item in the list meets this criterion.
+
+ 1. Source Code.
+
+ The "source code" for a work means the preferred form of the work
+for making modifications to it. "Object code" means any non-source
+form of a work.
+
+ A "Standard Interface" means an interface that either is an official
+standard defined by a recognized standards body, or, in the case of
+interfaces specified for a particular programming language, one that
+is widely used among developers working in that language.
+
+ The "System Libraries" of an executable work include anything, other
+than the work as a whole, that (a) is included in the normal form of
+packaging a Major Component, but which is not part of that Major
+Component, and (b) serves only to enable use of the work with that
+Major Component, or to implement a Standard Interface for which an
+implementation is available to the public in source code form. A
+"Major Component", in this context, means a major essential component
+(kernel, window system, and so on) of the specific operating system
+(if any) on which the executable work runs, or a compiler used to
+produce the work, or an object code interpreter used to run it.
+
+ The "Corresponding Source" for a work in object code form means all
+the source code needed to generate, install, and (for an executable
+work) run the object code and to modify the work, including scripts to
+control those activities. However, it does not include the work's
+System Libraries, or general-purpose tools or generally available free
+programs which are used unmodified in performing those activities but
+which are not part of the work. For example, Corresponding Source
+includes interface definition files associated with source files for
+the work, and the source code for shared libraries and dynamically
+linked subprograms that the work is specifically designed to require,
+such as by intimate data communication or control flow between those
+subprograms and other parts of the work.
+
+ The Corresponding Source need not include anything that users
+can regenerate automatically from other parts of the Corresponding
+Source.
+
+ The Corresponding Source for a work in source code form is that
+same work.
+
+ 2. Basic Permissions.
+
+ All rights granted under this License are granted for the term of
+copyright on the Program, and are irrevocable provided the stated
+conditions are met. This License explicitly affirms your unlimited
+permission to run the unmodified Program. The output from running a
+covered work is covered by this License only if the output, given its
+content, constitutes a covered work. This License acknowledges your
+rights of fair use or other equivalent, as provided by copyright law.
+
+ You may make, run and propagate covered works that you do not
+convey, without conditions so long as your license otherwise remains
+in force. You may convey covered works to others for the sole purpose
+of having them make modifications exclusively for you, or provide you
+with facilities for running those works, provided that you comply with
+the terms of this License in conveying all material for which you do
+not control copyright. Those thus making or running the covered works
+for you must do so exclusively on your behalf, under your direction
+and control, on terms that prohibit them from making any copies of
+your copyrighted material outside their relationship with you.
+
+ Conveying under any other circumstances is permitted solely under
+the conditions stated below. Sublicensing is not allowed; section 10
+makes it unnecessary.
+
+ 3. Protecting Users' Legal Rights From Anti-Circumvention Law.
+
+ No covered work shall be deemed part of an effective technological
+measure under any applicable law fulfilling obligations under article
+11 of the WIPO copyright treaty adopted on 20 December 1996, or
+similar laws prohibiting or restricting circumvention of such
+measures.
+
+ When you convey a covered work, you waive any legal power to forbid
+circumvention of technological measures to the extent such circumvention
+is effected by exercising rights under this License with respect to
+the covered work, and you disclaim any intention to limit operation or
+modification of the work as a means of enforcing, against the work's
+users, your or third parties' legal rights to forbid circumvention of
+technological measures.
+
+ 4. Conveying Verbatim Copies.
+
+ You may convey verbatim copies of the Program's source code as you
+receive it, in any medium, provided that you conspicuously and
+appropriately publish on each copy an appropriate copyright notice;
+keep intact all notices stating that this License and any
+non-permissive terms added in accord with section 7 apply to the code;
+keep intact all notices of the absence of any warranty; and give all
+recipients a copy of this License along with the Program.
+
+ You may charge any price or no price for each copy that you convey,
+and you may offer support or warranty protection for a fee.
+
+ 5. Conveying Modified Source Versions.
+
+ You may convey a work based on the Program, or the modifications to
+produce it from the Program, in the form of source code under the
+terms of section 4, provided that you also meet all of these conditions:
+
+ a) The work must carry prominent notices stating that you modified
+ it, and giving a relevant date.
+
+ b) The work must carry prominent notices stating that it is
+ released under this License and any conditions added under section
+ 7. This requirement modifies the requirement in section 4 to
+ "keep intact all notices".
+
+ c) You must license the entire work, as a whole, under this
+ License to anyone who comes into possession of a copy. This
+ License will therefore apply, along with any applicable section 7
+ additional terms, to the whole of the work, and all its parts,
+ regardless of how they are packaged. This License gives no
+ permission to license the work in any other way, but it does not
+ invalidate such permission if you have separately received it.
+
+ d) If the work has interactive user interfaces, each must display
+ Appropriate Legal Notices; however, if the Program has interactive
+ interfaces that do not display Appropriate Legal Notices, your
+ work need not make them do so.
+
+ A compilation of a covered work with other separate and independent
+works, which are not by their nature extensions of the covered work,
+and which are not combined with it such as to form a larger program,
+in or on a volume of a storage or distribution medium, is called an
+"aggregate" if the compilation and its resulting copyright are not
+used to limit the access or legal rights of the compilation's users
+beyond what the individual works permit. Inclusion of a covered work
+in an aggregate does not cause this License to apply to the other
+parts of the aggregate.
+
+ 6. Conveying Non-Source Forms.
+
+ You may convey a covered work in object code form under the terms
+of sections 4 and 5, provided that you also convey the
+machine-readable Corresponding Source under the terms of this License,
+in one of these ways:
+
+ a) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by the
+ Corresponding Source fixed on a durable physical medium
+ customarily used for software interchange.
+
+ b) Convey the object code in, or embodied in, a physical product
+ (including a physical distribution medium), accompanied by a
+ written offer, valid for at least three years and valid for as
+ long as you offer spare parts or customer support for that product
+ model, to give anyone who possesses the object code either (1) a
+ copy of the Corresponding Source for all the software in the
+ product that is covered by this License, on a durable physical
+ medium customarily used for software interchange, for a price no
+ more than your reasonable cost of physically performing this
+ conveying of source, or (2) access to copy the
+ Corresponding Source from a network server at no charge.
+
+ c) Convey individual copies of the object code with a copy of the
+ written offer to provide the Corresponding Source. This
+ alternative is allowed only occasionally and noncommercially, and
+ only if you received the object code with such an offer, in accord
+ with subsection 6b.
+
+ d) Convey the object code by offering access from a designated
+ place (gratis or for a charge), and offer equivalent access to the
+ Corresponding Source in the same way through the same place at no
+ further charge. You need not require recipients to copy the
+ Corresponding Source along with the object code. If the place to
+ copy the object code is a network server, the Corresponding Source
+ may be on a different server (operated by you or a third party)
+ that supports equivalent copying facilities, provided you maintain
+ clear directions next to the object code saying where to find the
+ Corresponding Source. Regardless of what server hosts the
+ Corresponding Source, you remain obligated to ensure that it is
+ available for as long as needed to satisfy these requirements.
+
+ e) Convey the object code using peer-to-peer transmission, provided
+ you inform other peers where the object code and Corresponding
+ Source of the work are being offered to the general public at no
+ charge under subsection 6d.
+
+ A separable portion of the object code, whose source code is excluded
+from the Corresponding Source as a System Library, need not be
+included in conveying the object code work.
+
+ A "User Product" is either (1) a "consumer product", which means any
+tangible personal property which is normally used for personal, family,
+or household purposes, or (2) anything designed or sold for incorporation
+into a dwelling. In determining whether a product is a consumer product,
+doubtful cases shall be resolved in favor of coverage. For a particular
+product received by a particular user, "normally used" refers to a
+typical or common use of that class of product, regardless of the status
+of the particular user or of the way in which the particular user
+actually uses, or expects or is expected to use, the product. A product
+is a consumer product regardless of whether the product has substantial
+commercial, industrial or non-consumer uses, unless such uses represent
+the only significant mode of use of the product.
+
+ "Installation Information" for a User Product means any methods,
+procedures, authorization keys, or other information required to install
+and execute modified versions of a covered work in that User Product from
+a modified version of its Corresponding Source. The information must
+suffice to ensure that the continued functioning of the modified object
+code is in no case prevented or interfered with solely because
+modification has been made.
+
+ If you convey an object code work under this section in, or with, or
+specifically for use in, a User Product, and the conveying occurs as
+part of a transaction in which the right of possession and use of the
+User Product is transferred to the recipient in perpetuity or for a
+fixed term (regardless of how the transaction is characterized), the
+Corresponding Source conveyed under this section must be accompanied
+by the Installation Information. But this requirement does not apply
+if neither you nor any third party retains the ability to install
+modified object code on the User Product (for example, the work has
+been installed in ROM).
+
+ The requirement to provide Installation Information does not include a
+requirement to continue to provide support service, warranty, or updates
+for a work that has been modified or installed by the recipient, or for
+the User Product in which it has been modified or installed. Access to a
+network may be denied when the modification itself materially and
+adversely affects the operation of the network or violates the rules and
+protocols for communication across the network.
+
+ Corresponding Source conveyed, and Installation Information provided,
+in accord with this section must be in a format that is publicly
+documented (and with an implementation available to the public in
+source code form), and must require no special password or key for
+unpacking, reading or copying.
+
+ 7. Additional Terms.
+
+ "Additional permissions" are terms that supplement the terms of this
+License by making exceptions from one or more of its conditions.
+Additional permissions that are applicable to the entire Program shall
+be treated as though they were included in this License, to the extent
+that they are valid under applicable law. If additional permissions
+apply only to part of the Program, that part may be used separately
+under those permissions, but the entire Program remains governed by
+this License without regard to the additional permissions.
+
+ When you convey a copy of a covered work, you may at your option
+remove any additional permissions from that copy, or from any part of
+it. (Additional permissions may be written to require their own
+removal in certain cases when you modify the work.) You may place
+additional permissions on material, added by you to a covered work,
+for which you have or can give appropriate copyright permission.
+
+ Notwithstanding any other provision of this License, for material you
+add to a covered work, you may (if authorized by the copyright holders of
+that material) supplement the terms of this License with terms:
+
+ a) Disclaiming warranty or limiting liability differently from the
+ terms of sections 15 and 16 of this License; or
+
+ b) Requiring preservation of specified reasonable legal notices or
+ author attributions in that material or in the Appropriate Legal
+ Notices displayed by works containing it; or
+
+ c) Prohibiting misrepresentation of the origin of that material, or
+ requiring that modified versions of such material be marked in
+ reasonable ways as different from the original version; or
+
+ d) Limiting the use for publicity purposes of names of licensors or
+ authors of the material; or
+
+ e) Declining to grant rights under trademark law for use of some
+ trade names, trademarks, or service marks; or
+
+ f) Requiring indemnification of licensors and authors of that
+ material by anyone who conveys the material (or modified versions of
+ it) with contractual assumptions of liability to the recipient, for
+ any liability that these contractual assumptions directly impose on
+ those licensors and authors.
+
+ All other non-permissive additional terms are considered "further
+restrictions" within the meaning of section 10. If the Program as you
+received it, or any part of it, contains a notice stating that it is
+governed by this License along with a term that is a further
+restriction, you may remove that term. If a license document contains
+a further restriction but permits relicensing or conveying under this
+License, you may add to a covered work material governed by the terms
+of that license document, provided that the further restriction does
+not survive such relicensing or conveying.
+
+ If you add terms to a covered work in accord with this section, you
+must place, in the relevant source files, a statement of the
+additional terms that apply to those files, or a notice indicating
+where to find the applicable terms.
+
+ Additional terms, permissive or non-permissive, may be stated in the
+form of a separately written license, or stated as exceptions;
+the above requirements apply either way.
+
+ 8. Termination.
+
+ You may not propagate or modify a covered work except as expressly
+provided under this License. Any attempt otherwise to propagate or
+modify it is void, and will automatically terminate your rights under
+this License (including any patent licenses granted under the third
+paragraph of section 11).
+
+ However, if you cease all violation of this License, then your
+license from a particular copyright holder is reinstated (a)
+provisionally, unless and until the copyright holder explicitly and
+finally terminates your license, and (b) permanently, if the copyright
+holder fails to notify you of the violation by some reasonable means
+prior to 60 days after the cessation.
+
+ Moreover, your license from a particular copyright holder is
+reinstated permanently if the copyright holder notifies you of the
+violation by some reasonable means, this is the first time you have
+received notice of violation of this License (for any work) from that
+copyright holder, and you cure the violation prior to 30 days after
+your receipt of the notice.
+
+ Termination of your rights under this section does not terminate the
+licenses of parties who have received copies or rights from you under
+this License. If your rights have been terminated and not permanently
+reinstated, you do not qualify to receive new licenses for the same
+material under section 10.
+
+ 9. Acceptance Not Required for Having Copies.
+
+ You are not required to accept this License in order to receive or
+run a copy of the Program. Ancillary propagation of a covered work
+occurring solely as a consequence of using peer-to-peer transmission
+to receive a copy likewise does not require acceptance. However,
+nothing other than this License grants you permission to propagate or
+modify any covered work. These actions infringe copyright if you do
+not accept this License. Therefore, by modifying or propagating a
+covered work, you indicate your acceptance of this License to do so.
+
+ 10. Automatic Licensing of Downstream Recipients.
+
+ Each time you convey a covered work, the recipient automatically
+receives a license from the original licensors, to run, modify and
+propagate that work, subject to this License. You are not responsible
+for enforcing compliance by third parties with this License.
+
+ An "entity transaction" is a transaction transferring control of an
+organization, or substantially all assets of one, or subdividing an
+organization, or merging organizations. If propagation of a covered
+work results from an entity transaction, each party to that
+transaction who receives a copy of the work also receives whatever
+licenses to the work the party's predecessor in interest had or could
+give under the previous paragraph, plus a right to possession of the
+Corresponding Source of the work from the predecessor in interest, if
+the predecessor has it or can get it with reasonable efforts.
+
+ You may not impose any further restrictions on the exercise of the
+rights granted or affirmed under this License. For example, you may
+not impose a license fee, royalty, or other charge for exercise of
+rights granted under this License, and you may not initiate litigation
+(including a cross-claim or counterclaim in a lawsuit) alleging that
+any patent claim is infringed by making, using, selling, offering for
+sale, or importing the Program or any portion of it.
+
+ 11. Patents.
+
+ A "contributor" is a copyright holder who authorizes use under this
+License of the Program or a work on which the Program is based. The
+work thus licensed is called the contributor's "contributor version".
+
+ A contributor's "essential patent claims" are all patent claims
+owned or controlled by the contributor, whether already acquired or
+hereafter acquired, that would be infringed by some manner, permitted
+by this License, of making, using, or selling its contributor version,
+but do not include claims that would be infringed only as a
+consequence of further modification of the contributor version. For
+purposes of this definition, "control" includes the right to grant
+patent sublicenses in a manner consistent with the requirements of
+this License.
+
+ Each contributor grants you a non-exclusive, worldwide, royalty-free
+patent license under the contributor's essential patent claims, to
+make, use, sell, offer for sale, import and otherwise run, modify and
+propagate the contents of its contributor version.
+
+ In the following three paragraphs, a "patent license" is any express
+agreement or commitment, however denominated, not to enforce a patent
+(such as an express permission to practice a patent or covenant not to
+sue for patent infringement). To "grant" such a patent license to a
+party means to make such an agreement or commitment not to enforce a
+patent against the party.
+
+ If you convey a covered work, knowingly relying on a patent license,
+and the Corresponding Source of the work is not available for anyone
+to copy, free of charge and under the terms of this License, through a
+publicly available network server or other readily accessible means,
+then you must either (1) cause the Corresponding Source to be so
+available, or (2) arrange to deprive yourself of the benefit of the
+patent license for this particular work, or (3) arrange, in a manner
+consistent with the requirements of this License, to extend the patent
+license to downstream recipients. "Knowingly relying" means you have
+actual knowledge that, but for the patent license, your conveying the
+covered work in a country, or your recipient's use of the covered work
+in a country, would infringe one or more identifiable patents in that
+country that you have reason to believe are valid.
+
+ If, pursuant to or in connection with a single transaction or
+arrangement, you convey, or propagate by procuring conveyance of, a
+covered work, and grant a patent license to some of the parties
+receiving the covered work authorizing them to use, propagate, modify
+or convey a specific copy of the covered work, then the patent license
+you grant is automatically extended to all recipients of the covered
+work and works based on it.
+
+ A patent license is "discriminatory" if it does not include within
+the scope of its coverage, prohibits the exercise of, or is
+conditioned on the non-exercise of one or more of the rights that are
+specifically granted under this License. You may not convey a covered
+work if you are a party to an arrangement with a third party that is
+in the business of distributing software, under which you make payment
+to the third party based on the extent of your activity of conveying
+the work, and under which the third party grants, to any of the
+parties who would receive the covered work from you, a discriminatory
+patent license (a) in connection with copies of the covered work
+conveyed by you (or copies made from those copies), or (b) primarily
+for and in connection with specific products or compilations that
+contain the covered work, unless you entered into that arrangement,
+or that patent license was granted, prior to 28 March 2007.
+
+ Nothing in this License shall be construed as excluding or limiting
+any implied license or other defenses to infringement that may
+otherwise be available to you under applicable patent law.
+
+ 12. No Surrender of Others' Freedom.
+
+ If conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot convey a
+covered work so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you may
+not convey it at all. For example, if you agree to terms that obligate you
+to collect a royalty for further conveying from those to whom you convey
+the Program, the only way you could satisfy both those terms and this
+License would be to refrain entirely from conveying the Program.
+
+ 13. Use with the GNU Affero General Public License.
+
+ Notwithstanding any other provision of this License, you have
+permission to link or combine any covered work with a work licensed
+under version 3 of the GNU Affero General Public License into a single
+combined work, and to convey the resulting work. The terms of this
+License will continue to apply to the part which is the covered work,
+but the special requirements of the GNU Affero General Public License,
+section 13, concerning interaction through a network will apply to the
+combination as such.
+
+ 14. Revised Versions of this License.
+
+ The Free Software Foundation may publish revised and/or new versions of
+the GNU 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
+Program specifies that a certain numbered version of the GNU General
+Public License "or any later version" applies to it, you have the
+option of following the terms and conditions either of that numbered
+version or of any later version published by the Free Software
+Foundation. If the Program does not specify a version number of the
+GNU General Public License, you may choose any version ever published
+by the Free Software Foundation.
+
+ If the Program specifies that a proxy can decide which future
+versions of the GNU General Public License can be used, that proxy's
+public statement of acceptance of a version permanently authorizes you
+to choose that version for the Program.
+
+ Later license versions may give you additional or different
+permissions. However, no additional obligations are imposed on any
+author or copyright holder as a result of your choosing to follow a
+later version.
+
+ 15. Disclaimer of Warranty.
+
+ THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
+HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
+OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
+THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
+IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
+ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. Limitation of Liability.
+
+ IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
+THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
+USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
+DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
+EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
+SUCH DAMAGES.
+
+ 17. Interpretation of Sections 15 and 16.
+
+ If the disclaimer of warranty and limitation of liability provided
+above cannot be given local legal effect according to their terms,
+reviewing courts shall apply local law that most closely approximates
+an absolute waiver of all civil liability in connection with the
+Program, unless a warranty or assumption of liability accompanies a
+copy of the Program in return for a fee.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+state the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+
+ Copyright (C)
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see .
+
+Also add information on how to contact you by electronic and paper mail.
+
+ If the program does terminal interaction, make it output a short
+notice like this when it starts in an interactive mode:
+
+ Copyright (C)
+ This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, your program's commands
+might be different; for a GUI interface, you would use an "about box".
+
+ You should also get your employer (if you work as a programmer) or school,
+if any, to sign a "copyright disclaimer" for the program, if necessary.
+For more information on this, and how to apply and follow the GNU GPL, see
+.
+
+ The GNU General Public License does not permit incorporating your program
+into proprietary programs. If your program is a subroutine library, you
+may consider it more useful to permit linking proprietary applications with
+the library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License. But first, please read
+.
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..a5755dc
--- /dev/null
+++ b/README.md
@@ -0,0 +1,93 @@
+# FZ-sDataPack
+A Minecraft Datapack
+#### @Author: Harvey_Husky
+
+#### This project is licensed under the terms of the GNU General Public License v3.0.
+#### Copyright (C)2019-2020 Harvey_Husky
+
+### v2.0.2
+- 支持Minecraft1.16.x
+- 抬头并按一下shift来打开设置界面
+- 提供一些地毯脚本:*请在升级数据包的同时替换这些工具!!*
+ - 安装方法:
+ - 需要carpet mod 1.4.21:https://github.com/gnembon/fabric-carpet/releases
+ - 将其放入“world/scripts”中(在客户端位于“.minecraft/saves/存档名/scripts”或“.minecraft/config/carpet/scripts”)
+ - 这三个文件夹默认不会自动生成,直接新建即可
+ - here.sc:
+ - “/here”向所有人发送自己的位置和所在维度
+ - 发送的消息使用voxelmap可识别的数组格式
+ - 安装voxelmap mod后,左键高亮该坐标,ctrl+左键新建坐标点
+ - c.sc
+ - “/c”修改玩家模式为旁观模式
+ - s.sc
+ - “/s”修改玩家模式为生存模式
+ - tagplayer.sc:
+ - 这个工具可以防止将地毯mod生成的假人计入记分板
+ - 可以通过自定义文件名来自定义游戏内命令
+ - 使用方法:
+ - 输入“/script load tagplayer”加载工具
+ - 包含全部地毯假人自带的功能,以及新功能,如:
+ - “/tagplayer check xxx”检查玩家的状态
+ - “/tagplayer checkall”检查所有玩家的状态
+ - “/tagplayer killall”清除所有假人
+ - 其他用法可以在游戏内输入“/tagplayer”查看
+ - restore_scores.sc:
+ - 从数据包1.4升级时也需要使用这个工具
+ - 这个工具可以从白名单读取玩家列表,逐一召唤假人,读取统计信息并赋值给记分板
+ - 悄悄说一句没白名单的服把usercache.json复制一份改成whitelist.json就可以啦
+ - 注意:原有的记分板会被删除
+ - 使用方法:
+ - 输入“/script load restore_scores”加载工具
+ - 输入“/restore_scores by_whitelist”开始恢复
+ - 输入“/script unload restore_scores”卸载工具
+ - 记得用完就删掉它!
+- 无需配置即可支持该铁头功破基岩榜Mod:https://gitee.com/harvey-husky/FZ-BBL/releases
+ - 破基岩榜的分数和订阅设置会在铁头功记分板的总分大于0时显示,以免未添加该mod的服务器显示破基岩榜
+- 计划
+ - 添加单独的记分板升级工具
+##### v2.0.3
+- 修复在不添加tagplayer工具时记分板不加分的bug
+##### v2.0.2
+- 修复在使用carpet-1.4.22或以上版本时,tagplayer的玩家名错乱的bug
+##### v2.0.1.8
+- 修复使用金斧头挖掘会导致总量+2的bug
+- 修复使用金锄头挖掘不会给挖掘榜加分
+- 修复主手有铲子,斧头,锄头时,副手放置方块会导致挖掘榜-1的bug(原版bug,通过toolsfix2成就修复)
+##### v2.0.1.7
+- 修复有时设置界面打不开的bug
+- 修复交易榜只加一次分的bug..
+- 修复tagplayer中的事件多次触发的bug
+##### v2.0.1.6
+- tagplayer现在可以通过自定义文件名来自定义游戏内命令
+- 修复铁制工具依然不统计记分板的bug...
+##### v2.0.1.3
+- 修复部分铁质工具不统计挖掘榜的bug
+##### v2.0.1.1
+- 为设置界面的计分板添加悬浮文本
+- 无需配置即可支持该铁头功破基岩榜Mod:https://gitee.com/harvey-husky/FZ-BBL/releases
+ - 破基岩榜的分数和订阅设置会在铁头功记分板的总分大于0时显示,以免未添加该mod的服务器显示破基岩榜
+##### v2.0.0.11
+- “/tagplayer spawn xxx”后面现在可以追加“at”、“facing”、“in”参数
+##### v2.0.0.10
+- 扫地机添加了位于怪物血条栏的文字提示,同时添加了各种提示的开关功能
+##### v2.0.0.9
+- 修复矿车白名单状态反了的bug
+##### v2.0.0.8
+- 添加c.sc、s.sc、here.sc工具
+##### v2.0.0.7
+- tagplayer添加了新版carpet新指令,可以为假人切换热键栏
+- 现在tagplayer需要carpet1.4.21或以上版本运行!
+- 现在tagplayer可以给自己设置动作了
+- 添加“/tagplayer shadow”指令将自己变为前缀为“挂机”的假人
+##### v2.0.0.6
+- 修复restore_scores.sc工具不能恢复受伤害榜(抖M榜)的bug
+##### v2.0.0.5
+- 修复挖掘榜部分工具不起作用的bug
+- 添加restore_scores.sc工具便于恢复或从1.0版本升级记分板
+##### v2.0.0.4
+- 添加彩色字体
+##### v2.0.0.3
+- tagplayer需要地毯mod1.4.18或以上版本来运行
+- 优化了tagplayer体验及修复若干bug
+##### v2.0.0.2
+- 重写
diff --git a/c.sc b/c.sc
new file mode 100644
index 0000000..33b054d
--- /dev/null
+++ b/c.sc
@@ -0,0 +1,7 @@
+__config() -> {
+ 'stay_loaded' -> true
+};
+__command() -> (
+ run('gamemode spectator');
+ run('execute at @s run tp @s ~ ~0.2 ~')
+)
\ No newline at end of file
diff --git a/data/fz/advancements/config/sneak.json b/data/fz/advancements/config/sneak.json
new file mode 100644
index 0000000..198a225
--- /dev/null
+++ b/data/fz/advancements/config/sneak.json
@@ -0,0 +1,20 @@
+{
+ "criteria": {
+ "config_check_sneak":{
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_properties",
+ "entity": "this",
+ "predicate": {
+ "flags": {
+ "is_sneaking": true
+ }
+ }
+ }
+ ]
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/config/unsneak.json b/data/fz/advancements/config/unsneak.json
new file mode 100644
index 0000000..a6e6f8d
--- /dev/null
+++ b/data/fz/advancements/config/unsneak.json
@@ -0,0 +1,28 @@
+{
+ "criteria": {
+ "config_check_sneak":{
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_properties",
+ "entity": "this",
+ "predicate": {
+ "player": {
+ "advancements": {
+ "fz:config/sneak": true
+ }
+ },
+ "flags": {
+ "is_sneaking": false
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:config/unsneak"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/leavegame.json b/data/fz/advancements/leavegame.json
new file mode 100644
index 0000000..b52bc49
--- /dev/null
+++ b/data/fz/advancements/leavegame.json
@@ -0,0 +1,26 @@
+{
+ "criteria": {
+ "leave_game": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:inverted",
+ "term": {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "leaveGame": {
+ "max": 0
+ }
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:login/onlogin"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/activation.json b/data/fz/advancements/scoreboards/activation.json
new file mode 100644
index 0000000..99615cb
--- /dev/null
+++ b/data/fz/advancements/scoreboards/activation.json
@@ -0,0 +1,24 @@
+{
+ "criteria": {
+ "activation": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "actimeCounter": {
+ "max": 3600,
+ "min": 3600
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/activation/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/bedrockbreaked.json b/data/fz/advancements/scoreboards/bedrockbreaked.json
new file mode 100644
index 0000000..c7b54e5
--- /dev/null
+++ b/data/fz/advancements/scoreboards/bedrockbreaked.json
@@ -0,0 +1,23 @@
+{
+ "criteria": {
+ "damage_taken": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "fz.bbl": {
+ "min": 1
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/bedrockbreaked/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/damagetaken.json b/data/fz/advancements/scoreboards/damagetaken.json
new file mode 100644
index 0000000..783a077
--- /dev/null
+++ b/data/fz/advancements/scoreboards/damagetaken.json
@@ -0,0 +1,23 @@
+{
+ "criteria": {
+ "damage_taken": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "10xDamageTaken": {
+ "min": 1
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/damagetaken/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/deathcounter.json b/data/fz/advancements/scoreboards/deathcounter.json
new file mode 100644
index 0000000..af2b7e4
--- /dev/null
+++ b/data/fz/advancements/scoreboards/deathcounter.json
@@ -0,0 +1,23 @@
+{
+ "criteria": {
+ "death_counter": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "deathTester": {
+ "min": 1
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/deathcounter/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/digcounter/digtrigger.json b/data/fz/advancements/scoreboards/digcounter/digtrigger.json
new file mode 100644
index 0000000..10de185
--- /dev/null
+++ b/data/fz/advancements/scoreboards/digcounter/digtrigger.json
@@ -0,0 +1,244 @@
+{
+ "criteria": {
+ "used_tools": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:alternative",
+ "terms": [
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedWooShovel": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedWooPickaxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedWooHoe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedWooAxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedStoShovel": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedStoPickaxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedStoHoe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedStoAxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedNetShovel": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedNetPickaxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedNetHoe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedNetAxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedIroShovel": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedIroPickaxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedIroHoe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedIroAxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedGolShovel": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedGolPickaxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedGolHoe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedGolAxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedDiaShovel": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedDiaPickaxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedDiaHoe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedDiaAxe": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ },
+ {
+ "condition": "minecraft:entity_scores",
+ "scores": {
+ "usedShears": {
+ "min": 1
+ }
+ },
+ "entity": "this"
+ }
+ ]
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/digcounter/digtrigger"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/digcounter/toolsfix.json b/data/fz/advancements/scoreboards/digcounter/toolsfix.json
new file mode 100644
index 0000000..0fba25b
--- /dev/null
+++ b/data/fz/advancements/scoreboards/digcounter/toolsfix.json
@@ -0,0 +1,58 @@
+{
+ "criteria": {
+ "right_click_tools": {
+ "trigger": "minecraft:item_used_on_block",
+ "conditions": {
+ "item": {
+ "items": [
+ "golden_axe",
+ "golden_hoe",
+ "golden_shovel",
+ "wooden_axe",
+ "wooden_hoe",
+ "wooden_shovel",
+ "diamond_axe",
+ "diamond_hoe",
+ "diamond_shovel",
+ "iron_axe",
+ "iron_hoe",
+ "iron_shovel",
+ "stone_axe",
+ "stone_hoe",
+ "stone_shovel",
+ "netherite_axe",
+ "netherite_hoe",
+ "netherite_shovel"
+ ]
+ },
+ "location": {
+ "block": {
+ "blocks": [
+ "dirt_path",
+ "farmland",
+ "oak_log",
+ "stripped_birch_log",
+ "stripped_acacia_log",
+ "stripped_jungle_log",
+ "stripped_spruce_log",
+ "stripped_dark_oak_log",
+ "stripped_warped_stem",
+ "stripped_crimson_stem",
+ "stripped_oak_wood",
+ "stripped_birch_wood",
+ "stripped_acacia_wood",
+ "stripped_jungle_wood",
+ "stripped_spruce_wood",
+ "stripped_dark_oak_wood",
+ "stripped_warped_hyphae",
+ "stripped_crimson_hyphae"
+ ]
+ }
+ }
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/digcounter/toolsfix"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/digcounter/toolsfix2.json b/data/fz/advancements/scoreboards/digcounter/toolsfix2.json
new file mode 100644
index 0000000..633f1a7
--- /dev/null
+++ b/data/fz/advancements/scoreboards/digcounter/toolsfix2.json
@@ -0,0 +1,48 @@
+{
+ "criteria": {
+ "tools_hit_entities": {
+ "trigger": "minecraft:player_hurt_entity",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_properties",
+ "entity": "this",
+ "predicate": {
+ "equipment": {
+ "mainhand": {
+ "items": [
+ "iron_axe",
+ "stone_axe",
+ "golden_axe",
+ "wooden_axe",
+ "diamond_axe",
+ "netherite_axe",
+ "iron_shovel",
+ "stone_shovel",
+ "golden_shovel",
+ "wooden_shovel",
+ "diamond_shovel",
+ "netherite_shovel",
+ "iron_hoe",
+ "stone_hoe",
+ "golden_hoe",
+ "wooden_hoe",
+ "diamond_hoe",
+ "netherite_hoe",
+ "iron_pickaxe",
+ "stone_pickaxe",
+ "golden_pickaxe",
+ "wooden_pickaxe",
+ "diamond_pickaxe",
+ "netherite_pickaxe"
+ ]
+ }
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {"function": "fz:scoreboards/digcounter/toolsfix2"}
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/fishingcounter.json b/data/fz/advancements/scoreboards/fishingcounter.json
new file mode 100644
index 0000000..a8e658d
--- /dev/null
+++ b/data/fz/advancements/scoreboards/fishingcounter.json
@@ -0,0 +1,23 @@
+{
+ "criteria": {
+ "fishing_counter": {
+ "trigger": "minecraft:tick",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "fishingTester": {
+ "min": 1
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/fishingcounter/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/killcounter.json b/data/fz/advancements/scoreboards/killcounter.json
new file mode 100644
index 0000000..7bf3eeb
--- /dev/null
+++ b/data/fz/advancements/scoreboards/killcounter.json
@@ -0,0 +1,27 @@
+{
+ "criteria": {
+ "kill_counter": {
+ "trigger": "minecraft:player_killed_entity",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:inverted",
+ "term": {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "carpetBot": {
+ "max": 1,
+ "min": 1
+ }
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/killcounter/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/advancements/scoreboards/tradingcounter.json b/data/fz/advancements/scoreboards/tradingcounter.json
new file mode 100644
index 0000000..e362658
--- /dev/null
+++ b/data/fz/advancements/scoreboards/tradingcounter.json
@@ -0,0 +1,27 @@
+{
+ "criteria": {
+ "trading_counter": {
+ "trigger": "minecraft:villager_trade",
+ "conditions": {
+ "player": [
+ {
+ "condition": "minecraft:inverted",
+ "term": {
+ "condition": "minecraft:entity_scores",
+ "entity": "this",
+ "scores": {
+ "carpetBot": {
+ "max": 1,
+ "min": 1
+ }
+ }
+ }
+ }
+ ]
+ }
+ }
+ },
+ "rewards": {
+ "function": "fz:scoreboards/tradingcounter/calculator"
+ }
+}
\ No newline at end of file
diff --git a/data/fz/functions/carpet/autosetup.mcfunction b/data/fz/functions/carpet/autosetup.mcfunction
new file mode 100644
index 0000000..2f956a3
--- /dev/null
+++ b/data/fz/functions/carpet/autosetup.mcfunction
@@ -0,0 +1,18 @@
+#给萌新辅助自动配置地毯优化和功能的函数
+carpet setDefault language zh_cn
+carpet setDefault antiCheatDisabled true
+carpet setDefault combineXPOrbs true
+carpet setDefault persistentParrots true
+carpet setDefault stackableShulkerBoxes true
+carpet setDefault lagFreeSpawning true
+carpet setDefault ctrlQCraftingFix true
+carpet setDefault flippinCactus true
+carpet setDefault missingTools true
+carpet setDefault smoothClientAnimations true
+carpet setDefault optimizedTNT true
+carpet setDefault leadFix true
+carpet setDefault placementRotationFix true
+carpet setDefault xpNoCooldown true
+carpet setDefault defaultLoggers mobcaps,tps
+carpet setDefault commandTick true
+carpet setDefault commandTrackAI true
\ No newline at end of file
diff --git a/data/fz/functions/carpet/carpet.mcfunction b/data/fz/functions/carpet/carpet.mcfunction
new file mode 100644
index 0000000..315580e
--- /dev/null
+++ b/data/fz/functions/carpet/carpet.mcfunction
@@ -0,0 +1,5 @@
+#初始化tagplayer
+carpet setDefault commandScript true
+carpet setDefault commandScriptACE ops
+script run carpet_rules = system_info('world_carpet_rules'); if(carpet_rules:'scriptsAutoload' != 'true', run('carpet setDefault scriptsAutoload true'); run('tellraw @a {"text":"[错误]假人插件未正确加载,已自动将“scriptsAutoload”设为true。正在重载,如仍未加载,请手动加载...", "color":"#ff6100"}'); run('reload'))
+script unload player
diff --git a/data/fz/functions/config/display.mcfunction b/data/fz/functions/config/display.mcfunction
new file mode 100644
index 0000000..a21007a
--- /dev/null
+++ b/data/fz/functions/config/display.mcfunction
@@ -0,0 +1,27 @@
+#设置或重设超时时间为300s,超时后运行timeout函数
+schedule function fz:config/timeout 300s
+#输出玩家可见的设置页面
+##扫地机
+execute if data storage fz.installed {sweeper: 1b} run tellraw @s {"text": "扫地机:","color": "#ccff00"}
+ ##扫地机时间,对应分数1478966210-1478966215
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s [{"text": "- "},{"text": "[关]","color": "#00ff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966210"}},{"text": "[30秒]","color": "#5fff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966211"}},{"text": "[1分钟]","color": "#d7ff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966212"}},{"text": "[2分钟]","color": "#ffd900","clickEvent": {"action": "run_command","value": "/trigger config set 1478966213"}},{"text": "[3分钟]","color": "#ff6100","clickEvent": {"action": "run_command","value": "/trigger config set 1478966214"}},{"text": "[4分钟]","color": "#ff0000","clickEvent": {"action": "run_command","value": "/trigger config set 1478966215"}}]
+ ##开启矿车白名单1478966216
+ execute if data storage fz.installed {sweeper: 1b} unless score keepMinecart parameter matches 1 run tellraw @s [{"text": "- "},{"text": "矿车白名单:","color": "#8c8f91"},{"text": "[已关闭]","color": "#ff0000","clickEvent": {"action": "run_command","value": "/trigger config set 1478966216"}}]
+ ##关闭矿车白名单1478966217
+ execute if data storage fz.installed {sweeper: 1b} if score keepMinecart parameter matches 1 run tellraw @s [{"text": "- "},{"text": "矿车白名单:","color": "#8c8f91"},{"text": "[已开启]","color": "#00ff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966217"}}]
+ ##声音提示
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s[tag=!fz.sweeperSoundOff] [{"text": "- "},{"text": "声音:","color": "#8c8f91"},{"text": "[已开启]","color": "#00ff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966209"}}]
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s[tag=fz.sweeperSoundOff] [{"text": "- "},{"text": "声音:","color": "#8c8f91"},{"text": "[已关闭]","color": "#ff0000","clickEvent": {"action": "run_command","value": "/trigger config set 1478966208"}}]
+ ##消息提示
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s[tag=!fz.sweeperMessageOff] [{"text": "- "},{"text": "消息:","color": "#8c8f91"},{"text": "[已开启]","color": "#00ff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966205"}}]
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s[tag=fz.sweeperMessageOff] [{"text": "- "},{"text": "消息:","color": "#8c8f91"},{"text": "[已关闭]","color": "#ff0000","clickEvent": {"action": "run_command","value": "/trigger config set 1478966204"}}]
+ ##血条栏提示
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s[tag=!fz.sweeperBossbarOff] [{"text": "- "},{"text": "血条栏:","color": "#8c8f91"},{"text": "[已开启]","color": "#00ff00","clickEvent": {"action": "run_command","value": "/trigger config set 1478966207"}}]
+ execute if data storage fz.installed {sweeper: 1b} run tellraw @s[tag=fz.sweeperBossbarOff] [{"text": "- "},{"text": "血条栏:","color": "#8c8f91"},{"text": "[已关闭]","color": "#ff0000","clickEvent": {"action": "run_command","value": "/trigger config set 1478966206"}}]
+##记分板
+execute if data storage fz.installed {scoreboards: 1b} run tellraw @s {"text": "记分板:","color": "#ccff00"}
+ ##计分板显示,对应分数1838019370-1838019379
+ execute if data storage fz.installed {scoreboards: 1b} unless score 全员头铁 bedrockBreaked matches 1.. run tellraw @s [{"text": "- "},{"text": "[关]","color": "#ff0000","hoverEvent": {"action": "show_text","contents": {"text": "关", "color": "#ff0000"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019370"}},{"text": "[轮播]","color": "gold","hoverEvent": {"action": "show_text","contents": {"text": "轮播", "color": "gold"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019371"}},{"text": "[总量]","color": "dark_aqua","hoverEvent": {"action": "show_text","contents": {"text": "总量","color": "dark_aqua"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019379"}},{"text": "[在线时间(h)]","color": "aqua","hoverEvent": {"action": "show_text","contents": {"text": "在线时间(h)","color": "aqua"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019372"}},{"text": "[抖M名单]","color": "yellow","hoverEvent": {"action": "show_text","contents": {"text": "受伤害量","color": "yellow"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019373"}},{"text": "[死亡榜]","color": "dark_red","hoverEvent": {"action": "show_text","contents": {"text": "死亡榜","color": "dark_red"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019374"}},{"text": "[挖掘榜]","color": "gray","hoverEvent": {"action": "show_text","contents": {"text": "挖掘榜","color": "gray"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019375"}},{"text": "[钩直饵咸]","color": "blue","hoverEvent": {"action": "show_text","contents": {"text": "钓鱼榜","color": "blue"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019376"}},{"text": "[击杀榜]","color": "red","hoverEvent": {"action": "show_text","contents": {"text": "击杀榜","color": "red"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019377"}},{"text": "[交♂易榜]","color": "green","hoverEvent": {"action": "show_text","contents": {"text": "交易榜","color": "green"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019378"}}]
+ ##计分板显示,对应分数1838019369-1838019379(有破基岩榜)
+ execute if data storage fz.installed {scoreboards: 1b} if score 全员头铁 bedrockBreaked matches 1.. run tellraw @s [{"text": "- "},{"text": "[关]","color": "#ff0000","hoverEvent": {"action": "show_text","contents": {"text": "关", "color": "#ff0000"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019370"}},{"text": "[轮播]","color": "gold","hoverEvent": {"action": "show_text","contents": {"text": "轮播", "color": "gold"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019371"}},{"text": "[总量]","color": "dark_aqua","hoverEvent": {"action": "show_text","contents": {"text": "总量","color": "dark_aqua"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019379"}},{"text": "[在线时间(h)]","color": "aqua","hoverEvent": {"action": "show_text","contents": {"text": "在线时间(h)","color": "aqua"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019372"}},{"text": "[抖M名单]","color": "yellow","hoverEvent": {"action": "show_text","contents": {"text": "受伤害量","color": "yellow"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019373"}},{"text": "[死亡榜]","color": "dark_red","hoverEvent": {"action": "show_text","contents": {"text": "死亡榜","color": "dark_red"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019374"}},{"text": "[挖掘榜]","color": "gray","hoverEvent": {"action": "show_text","contents": {"text": "挖掘榜","color": "gray"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019375"}},{"text": "[钩直饵咸]","color": "blue","hoverEvent": {"action": "show_text","contents": {"text": "钓鱼榜","color": "blue"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019376"}},{"text": "[击杀榜]","color": "red","hoverEvent": {"action": "show_text","contents": {"text": "击杀榜","color": "red"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019377"}},{"text": "[交♂易榜]","color": "green","hoverEvent": {"action": "show_text","contents": {"text": "交易榜","color": "green"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019378"}}]
+ execute if data storage fz.installed {scoreboards: 1b} if score 全员头铁 bedrockBreaked matches 1.. run tellraw @s [{"text": "- "},{"text": "[铁头功]","color": "dark_green","hoverEvent": {"action": "show_text","contents": {"text": "破基岩榜","color": "dark_green"}},"clickEvent": {"action": "run_command","value": "/trigger config set 1838019369"}}]
diff --git a/data/fz/functions/config/install.mcfunction b/data/fz/functions/config/install.mcfunction
new file mode 100644
index 0000000..d9b5356
--- /dev/null
+++ b/data/fz/functions/config/install.mcfunction
@@ -0,0 +1,9 @@
+#安装设置功能
+#初始化触发器记分板
+scoreboard objectives add config trigger
+#存入已安装信息
+data merge storage fz.installed {config: 1b}
+#提示已安装
+tellraw @a {"text": "[信息]设置功能已安装","color": "#5fff00"}
+#开始运行
+function fz:config/start
\ No newline at end of file
diff --git a/data/fz/functions/config/main.mcfunction b/data/fz/functions/config/main.mcfunction
new file mode 100644
index 0000000..7dde148
--- /dev/null
+++ b/data/fz/functions/config/main.mcfunction
@@ -0,0 +1,8 @@
+#主函数
+#允许玩家操作config记分板
+scoreboard players enable @a config
+#每条子函数都要reset config分数和function fz:config/display
+execute if data storage fz.installed {sweeper: 1b} as @a if score @s config matches 1478966200..1478966217 run function fz:sweeper/config/trigger
+execute if data storage fz.installed {scoreboards: 1b} as @a if score @s config matches 1838019369..1838019379 run function fz:scoreboards/config
+#循环执行本函数
+schedule function fz:config/main 1t
\ No newline at end of file
diff --git a/data/fz/functions/config/start.mcfunction b/data/fz/functions/config/start.mcfunction
new file mode 100644
index 0000000..4ec825f
--- /dev/null
+++ b/data/fz/functions/config/start.mcfunction
@@ -0,0 +1,9 @@
+#删除进程残留
+schedule clear fz:config/main
+schedule clear fz:config/timeout
+data remove storage fz.config is_open
+scoreboard players enable @a config
+advancement revoke @a only fz:config/sneak
+advancement revoke @a only fz:config/unsneak
+#测试用的输出
+tellraw @a {"text": "[信息]设置功能已启用","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/config/timeout.mcfunction b/data/fz/functions/config/timeout.mcfunction
new file mode 100644
index 0000000..82b3025
--- /dev/null
+++ b/data/fz/functions/config/timeout.mcfunction
@@ -0,0 +1,8 @@
+#关闭主进程
+schedule clear fz:config/main
+#输出给打开过设置界面的玩家的消息
+tellraw @a[scores={openingConfig=1}] {"text": "[提醒]5分钟无任何人回应,为节省性能,已关闭设置功能,请重新唤起","color": "#66ffff"}
+#重置打开过设置界面的玩家的列表
+scoreboard objectives remove openingConfig
+#移除设置界面被打开的信息
+data remove storage fz.config is_open
\ No newline at end of file
diff --git a/data/fz/functions/config/turnon.mcfunction b/data/fz/functions/config/turnon.mcfunction
new file mode 100644
index 0000000..f322ebc
--- /dev/null
+++ b/data/fz/functions/config/turnon.mcfunction
@@ -0,0 +1,11 @@
+#触发函数,由成就和unsneak函数控制
+#重置玩家的config分数,避免开启设置功能后,由于该玩家先前的分数而直接运行某些功能
+scoreboard players reset @s config
+#判断设置功能是否已经开启,如果未开启则运行主函数
+execute unless data storage fz.config {is_open: 1b} run function fz:config/main
+execute unless data storage fz.config {is_open: 1b} run scoreboard objectives add openingConfig dummy
+execute unless data storage fz.config {is_open: 1b} run data merge storage fz.config {is_open: 1b}
+#将该玩家加入打开设置页面的玩家的列表
+scoreboard players set @s openingConfig 1
+#将设置内容输出给玩家
+function fz:config/display
\ No newline at end of file
diff --git a/data/fz/functions/config/uninstall.mcfunction b/data/fz/functions/config/uninstall.mcfunction
new file mode 100644
index 0000000..1bd213a
--- /dev/null
+++ b/data/fz/functions/config/uninstall.mcfunction
@@ -0,0 +1,9 @@
+#卸载设置功能
+#移除进程残留
+schedule clear fz:config/main
+schedule clear fz:config/timeout
+data remove storage fz.config is_open
+#写入已卸载的信息
+data merge storage fz.installed {config: 0b}
+#提示已卸载
+tellraw @a {"text": "[信息]设置功能已卸载","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/config/unsneak.mcfunction b/data/fz/functions/config/unsneak.mcfunction
new file mode 100644
index 0000000..e2cb0ce
--- /dev/null
+++ b/data/fz/functions/config/unsneak.mcfunction
@@ -0,0 +1,6 @@
+#由config/sneak和config/unsneak成就触发
+#判断玩家视角是否指向正上方,是则运行turnon函数
+execute if data storage fz.installed {config: 1b} if entity @s[x_rotation=-90] run function fz:config/turnon
+#重置该玩家的两个成就
+advancement revoke @s only fz:config/sneak
+advancement revoke @s only fz:config/unsneak
\ No newline at end of file
diff --git a/data/fz/functions/health/install.mcfunction b/data/fz/functions/health/install.mcfunction
new file mode 100644
index 0000000..a35a56b
--- /dev/null
+++ b/data/fz/functions/health/install.mcfunction
@@ -0,0 +1,10 @@
+#安装血量显示
+#初始化
+scoreboard objectives add Health health {"text": "cm","color": "yellow"}
+scoreboard objectives modify Health rendertype hearts
+scoreboard objectives setdisplay list Health
+scoreboard objectives setdisplay belowName Health
+#写入已安装的信息
+data merge storage fz.installed {health: 1b}
+#提示已安装
+tellraw @a {"text": "[信息]血量显示已安装","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/health/uninstall.mcfunction b/data/fz/functions/health/uninstall.mcfunction
new file mode 100644
index 0000000..d709f66
--- /dev/null
+++ b/data/fz/functions/health/uninstall.mcfunction
@@ -0,0 +1,7 @@
+#卸载血量显示
+#删除计分板
+scoreboard objectives remove Health
+#写入已卸载的信息
+data merge storage fz.installed {health: 0b}
+#提示已卸载
+tellraw @a {"text": "[信息]血量显示已卸载","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/install.mcfunction b/data/fz/functions/install.mcfunction
new file mode 100644
index 0000000..c7f8a30
--- /dev/null
+++ b/data/fz/functions/install.mcfunction
@@ -0,0 +1,30 @@
+
+#用于储存参数的记分板
+scoreboard objectives add parameter dummy
+#用于数学计算的记分板
+scoreboard objectives add calculator dummy
+scoreboard players set 10 calculator 10
+scoreboard players set 1 calculator 1
+#检测玩家退出游戏的记分板
+scoreboard objectives add leaveGame minecraft.custom:minecraft.leave_game
+#安装各功能
+function fz:config/install
+function fz:sweeper/install
+function fz:scoreboards/install
+function fz:health/install
+function fz:login/logintips/install
+function fz:carpet/carpet
+#版本信息
+data merge storage fz.installed {installed: 1b}
+data merge storage fz {version: 2.1.0}
+data merge storage fz {date: 2020-7.1}
+data merge storage fz {time: "02:43"}
+##data merge storage fz {snapshot: -SNAPSHOT}
+data remove storage fz snapshot
+tellraw @a {"text": "[信息]启动完毕","color": "#5fff00"}
+#提示已安装
+tellraw @a {"text": "[信息]安装完成!","color": "#5fff00"}
+#info: #5fff00 信息
+#alert: #d7ff00 提醒
+#warn: #ffd900 警告
+#error: #ff6100 错误
\ No newline at end of file
diff --git a/data/fz/functions/load.mcfunction b/data/fz/functions/load.mcfunction
new file mode 100644
index 0000000..eb1992c
--- /dev/null
+++ b/data/fz/functions/load.mcfunction
@@ -0,0 +1,8 @@
+#如果未安装且未卸载则安装
+execute unless data storage fz.installed {installed: 1b} unless data storage fz.installed {installed: 0b} run function fz:install
+#如果版本正确且已安装则开始运行
+execute if data storage fz {version: 2.1.0} if data storage fz.installed {installed: 1b} run function fz:start
+#如果版本不符则更新
+execute unless data storage fz {version: 2.1.0} run function fz:update
+#输出版本信息
+tellraw @a [{"text": "[版本信息]FZ's Datapack-","color": "#ffd900"},{"nbt":"version","storage":"fz","color": "#ffd900"},{"nbt": "snapshot", "storage": "fz","color": "red"}]
\ No newline at end of file
diff --git a/data/fz/functions/login/logintips/install.mcfunction b/data/fz/functions/login/logintips/install.mcfunction
new file mode 100644
index 0000000..48cdff3
--- /dev/null
+++ b/data/fz/functions/login/logintips/install.mcfunction
@@ -0,0 +1,4 @@
+#安装登陆提示
+data merge storage fz.installed {logintips: 1b}
+#提示已安装
+tellraw @a {"text": "[信息]登陆提示已安装","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/login/logintips/uninstall.mcfunction b/data/fz/functions/login/logintips/uninstall.mcfunction
new file mode 100644
index 0000000..5b383c3
--- /dev/null
+++ b/data/fz/functions/login/logintips/uninstall.mcfunction
@@ -0,0 +1,4 @@
+#卸载登陆提示
+data merge storage fz.installed {logintips: 0b}
+#提示已卸载
+tellraw @a {"text": "[信息]登陆提示已卸载","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/login/onlogin.mcfunction b/data/fz/functions/login/onlogin.mcfunction
new file mode 100644
index 0000000..d817020
--- /dev/null
+++ b/data/fz/functions/login/onlogin.mcfunction
@@ -0,0 +1,17 @@
+execute if data storage fz.installed {logintips: 1b} run tellraw @s {"text": "[提醒]站在地面,抬头并按一下shift即可打开设置页面","color": "#66ffff"}
+
+scoreboard players set @s leaveGame 0
+
+advancement revoke @s only fz:scoreboards/activation
+advancement revoke @s only fz:scoreboards/damagetaken
+advancement revoke @s only fz:scoreboards/deathcounter
+advancement revoke @s only fz:scoreboards/fishingcounter
+advancement revoke @s only fz:scoreboards/killcounter
+advancement revoke @s only fz:scoreboards/tradingcounter
+advancement revoke @s only fz:scoreboards/digcounter/digtrigger
+advancement revoke @s only fz:scoreboards/digcounter/toolsfix
+advancement revoke @s only fz:scoreboards/digcounter/toolsfix2
+advancement revoke @s only fz:config/sneak
+advancement revoke @s only fz:config/unsneak
+
+advancement revoke @s from fz:leavegame
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/activation/calculator.mcfunction b/data/fz/functions/scoreboards/activation/calculator.mcfunction
new file mode 100644
index 0000000..286ceee
--- /dev/null
+++ b/data/fz/functions/scoreboards/activation/calculator.mcfunction
@@ -0,0 +1,9 @@
+#计算在线时间和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s activation += 1 calculator
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总在线时间(h) activation += 1 calculator
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总在线时间(h) totalList += 1 calculator
+#重置玩家计时器
+scoreboard players reset @s actimeCounter
+#重置触发该函数的成就
+advancement revoke @s only fz:scoreboards/activation
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/activation/main.mcfunction b/data/fz/functions/scoreboards/activation/main.mcfunction
new file mode 100644
index 0000000..f3f95d8
--- /dev/null
+++ b/data/fz/functions/scoreboards/activation/main.mcfunction
@@ -0,0 +1,3 @@
+#主函数给在线玩家的计时器1s+1分
+scoreboard players add @a actimeCounter 1
+schedule function fz:scoreboards/activation/main 1s
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/activation/setdisplay.mcfunction b/data/fz/functions/scoreboards/activation/setdisplay.mcfunction
new file mode 100644
index 0000000..1076882
--- /dev/null
+++ b/data/fz/functions/scoreboards/activation/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将在线时间榜显示给轮播计分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.gold activation
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/bedrockbreaked/calculator.mcfunction b/data/fz/functions/scoreboards/bedrockbreaked/calculator.mcfunction
new file mode 100644
index 0000000..11fb9ec
--- /dev/null
+++ b/data/fz/functions/scoreboards/bedrockbreaked/calculator.mcfunction
@@ -0,0 +1,8 @@
+#计算受破基岩量和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s bedrockBreaked += @s fz.bbl
+execute unless score @s carpetBot matches 1 run scoreboard players operation 全员头铁 bedrockBreaked += @s fz.bbl
+execute unless score @s carpetBot matches 1 run scoreboard players operation 全员头铁 totalList += @s fz.bbl
+execute unless score @s carpetBot matches 1 run scoreboard players reset @s fz.bbl
+#重置触发该函数的成就
+advancement revoke @s only fz:scoreboards/bedrockbreaked
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/bedrockbreaked/setdisplay.mcfunction b/data/fz/functions/scoreboards/bedrockbreaked/setdisplay.mcfunction
new file mode 100644
index 0000000..19ce500
--- /dev/null
+++ b/data/fz/functions/scoreboards/bedrockbreaked/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将破基岩榜显示给轮播计分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.dark_gray bedrockBreaked
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/config.mcfunction b/data/fz/functions/scoreboards/config.mcfunction
new file mode 100644
index 0000000..9305fd1
--- /dev/null
+++ b/data/fz/functions/scoreboards/config.mcfunction
@@ -0,0 +1,15 @@
+#应用计分板显示,对应分数1838019369-1838019379
+execute if score @s config matches 1838019370 run team leave @s
+execute if score @s config matches 1838019371 run team join gold
+execute if score @s config matches 1838019372 run team join aqua
+execute if score @s config matches 1838019373 run team join yellow
+execute if score @s config matches 1838019374 run team join dark_red
+execute if score @s config matches 1838019375 run team join gray
+execute if score @s config matches 1838019376 run team join blue
+execute if score @s config matches 1838019377 run team join red
+execute if score @s config matches 1838019378 run team join green
+execute if score @s config matches 1838019379 run team join dark_aqua
+execute if score @s config matches 1838019369 run team join dark_green
+#每条子函数都要reset config分数和function fz:config/display
+scoreboard players reset @s config
+function fz:config/display
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/damagetaken/calculator.mcfunction b/data/fz/functions/scoreboards/damagetaken/calculator.mcfunction
new file mode 100644
index 0000000..46d90fb
--- /dev/null
+++ b/data/fz/functions/scoreboards/damagetaken/calculator.mcfunction
@@ -0,0 +1,10 @@
+#计算受伤害量和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s 10xDamageTaken /= 10 calculator
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s damageTaken += @s 10xDamageTaken
+execute unless score @s carpetBot matches 1 run scoreboard players operation 群p抖M damageTaken += @s 10xDamageTaken
+execute unless score @s carpetBot matches 1 run scoreboard players operation 群p抖M totalList += @s 10xDamageTaken
+#重置伤害探测记分板
+scoreboard players reset @s 10xDamageTaken
+#重置触发该函数的成就
+advancement revoke @s only fz:scoreboards/damagetaken
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/damagetaken/setdisplay.mcfunction b/data/fz/functions/scoreboards/damagetaken/setdisplay.mcfunction
new file mode 100644
index 0000000..28dc770
--- /dev/null
+++ b/data/fz/functions/scoreboards/damagetaken/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将抖M榜显示给轮播记分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.gold damageTaken
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/deathcounter/calculator.mcfunction b/data/fz/functions/scoreboards/deathcounter/calculator.mcfunction
new file mode 100644
index 0000000..ca06270
--- /dev/null
+++ b/data/fz/functions/scoreboards/deathcounter/calculator.mcfunction
@@ -0,0 +1,9 @@
+#计算死亡数和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s deathCounter += @s deathTester
+execute unless score @s carpetBot matches 1 run scoreboard players operation 全部木大 deathCounter += @s deathTester
+execute unless score @s carpetBot matches 1 run scoreboard players operation 全部木大 totalList += @s deathTester
+#重置死亡探测记分板
+scoreboard players reset @s deathTester
+#重置触发该函数的成就
+advancement revoke @s only fz:scoreboards/deathcounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/deathcounter/setdisplay.mcfunction b/data/fz/functions/scoreboards/deathcounter/setdisplay.mcfunction
new file mode 100644
index 0000000..9799976
--- /dev/null
+++ b/data/fz/functions/scoreboards/deathcounter/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将死亡榜显示给轮播计分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.gold deathCounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/delscore.mcfunction b/data/fz/functions/scoreboards/delscore.mcfunction
new file mode 100644
index 0000000..5dae1b1
--- /dev/null
+++ b/data/fz/functions/scoreboards/delscore.mcfunction
@@ -0,0 +1,12 @@
+#计分板数据将永久失去(真的很久!)
+scoreboard objectives remove killCounter
+scoreboard objectives remove digCounter
+scoreboard objectives remove deathCounter
+scoreboard objectives remove tradingCounter
+scoreboard objectives remove fishingCounter
+scoreboard objectives remove damageTaken
+scoreboard objectives remove activation
+scoreboard objectives remove totalList
+scoreboard objectives remove bedrockBreaked
+#提示已删除
+tellraw @a {"text": "[信息]计分板数据已删除","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/digtrigger.mcfunction b/data/fz/functions/scoreboards/digcounter/digtrigger.mcfunction
new file mode 100644
index 0000000..a319a23
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/digtrigger.mcfunction
@@ -0,0 +1,31 @@
+#判断各工具是否被使用并运行相应函数计算挖掘榜(左右键都会探测)
+#需要配合修正函数toolfix修正右键使用带来的加分
+execute if score @s usedDiaAxe matches 1.. run function fz:scoreboards/digcounter/tools/diaaxe
+execute if score @s usedDiaHoe matches 1.. run function fz:scoreboards/digcounter/tools/diahoe
+execute if score @s usedDiaPickaxe matches 1.. run function fz:scoreboards/digcounter/tools/diapickaxe
+execute if score @s usedDiaShovel matches 1.. run function fz:scoreboards/digcounter/tools/diashovel
+execute if score @s usedGolAxe matches 1.. run function fz:scoreboards/digcounter/tools/golaxe
+execute if score @s usedGolHoe matches 1.. run function fz:scoreboards/digcounter/tools/golhoe
+execute if score @s usedGolHoe matches 1.. run kill @s
+execute if score @s usedGolPickaxe matches 1.. run function fz:scoreboards/digcounter/tools/golpickaxe
+execute if score @s usedGolShovel matches 1.. run function fz:scoreboards/digcounter/tools/golshovel
+execute if score @s usedIroAxe matches 1.. run function fz:scoreboards/digcounter/tools/iroaxe
+execute if score @s usedIroHoe matches 1.. run function fz:scoreboards/digcounter/tools/irohoe
+execute if score @s usedIroHoe matches 1.. run kill @s
+execute if score @s usedIroPickaxe matches 1.. run function fz:scoreboards/digcounter/tools/iropickaxe
+execute if score @s usedIroShovel matches 1.. run function fz:scoreboards/digcounter/tools/iroshovel
+execute if score @s usedNetAxe matches 1.. run function fz:scoreboards/digcounter/tools/netaxe
+execute if score @s usedNetHoe matches 1.. run function fz:scoreboards/digcounter/tools/nethoe
+execute if score @s usedNetPickaxe matches 1.. run function fz:scoreboards/digcounter/tools/netpickaxe
+execute if score @s usedNetShovel matches 1.. run function fz:scoreboards/digcounter/tools/netshovel
+execute if score @s usedStoAxe matches 1.. run function fz:scoreboards/digcounter/tools/stoaxe
+execute if score @s usedStoHoe matches 1.. run function fz:scoreboards/digcounter/tools/stohoe
+execute if score @s usedStoPickaxe matches 1.. run function fz:scoreboards/digcounter/tools/stopickaxe
+execute if score @s usedStoShovel matches 1.. run function fz:scoreboards/digcounter/tools/stoshovel
+execute if score @s usedWooAxe matches 1.. run function fz:scoreboards/digcounter/tools/wooaxe
+execute if score @s usedWooHoe matches 1.. run function fz:scoreboards/digcounter/tools/woohoe
+execute if score @s usedWooPickaxe matches 1.. run function fz:scoreboards/digcounter/tools/woopickaxe
+execute if score @s usedWooShovel matches 1.. run function fz:scoreboards/digcounter/tools/wooshovel
+execute if score @s usedShears matches 1.. run function fz:scoreboards/digcounter/tools/shears
+#重置探测使用工具的记分板的成就
+advancement revoke @s only fz:scoreboards/digcounter/digtrigger
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/setdisplay.mcfunction b/data/fz/functions/scoreboards/digcounter/setdisplay.mcfunction
new file mode 100644
index 0000000..6de8eff
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将挖掘榜显示给轮播记分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.gold digCounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/diaaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/diaaxe.mcfunction
new file mode 100644
index 0000000..e1db1c1
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/diaaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedDiaAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedDiaAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedDiaAxe
+scoreboard players reset @s usedDiaAxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/diahoe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/diahoe.mcfunction
new file mode 100644
index 0000000..5370df0
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/diahoe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedDiaHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedDiaHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedDiaHoe
+scoreboard players reset @s usedDiaHoe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/diapickaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/diapickaxe.mcfunction
new file mode 100644
index 0000000..0ff4e77
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/diapickaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedDiaPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedDiaPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedDiaPickaxe
+scoreboard players reset @s usedDiaPickaxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/diashovel.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/diashovel.mcfunction
new file mode 100644
index 0000000..a64f4df
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/diashovel.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedDiaShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedDiaShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedDiaShovel
+scoreboard players reset @s usedDiaShovel
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/golaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/golaxe.mcfunction
new file mode 100644
index 0000000..2539d27
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/golaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedGolAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedGolAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedGolAxe
+scoreboard players reset @s usedGolAxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/golhoe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/golhoe.mcfunction
new file mode 100644
index 0000000..43c0d36
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/golhoe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedGolHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedGolHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedGolHoe
+scoreboard players reset @s usedGolHoe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/golpickaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/golpickaxe.mcfunction
new file mode 100644
index 0000000..aa30907
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/golpickaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedGolPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedGolPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedGolPickaxe
+scoreboard players reset @s usedGolPickaxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/golshovel.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/golshovel.mcfunction
new file mode 100644
index 0000000..e809157
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/golshovel.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedGolShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedGolShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedGolShovel
+scoreboard players reset @s usedGolShovel
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/iroaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/iroaxe.mcfunction
new file mode 100644
index 0000000..65cc56c
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/iroaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedIroAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedIroAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedIroAxe
+scoreboard players reset @s usedIroAxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/irohoe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/irohoe.mcfunction
new file mode 100644
index 0000000..01f236b
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/irohoe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedIroHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedIroHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedIroHoe
+scoreboard players reset @s usedIroHoe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/iropickaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/iropickaxe.mcfunction
new file mode 100644
index 0000000..d8fc182
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/iropickaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedIroPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedIroPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedIroPickaxe
+scoreboard players reset @s usedIroPickaxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/iroshovel.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/iroshovel.mcfunction
new file mode 100644
index 0000000..b8c0d2b
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/iroshovel.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedIroShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedIroShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedIroShovel
+scoreboard players reset @s usedIroShovel
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/netaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/netaxe.mcfunction
new file mode 100644
index 0000000..300d5fe
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/netaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedNetAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedNetAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedNetAxe
+scoreboard players reset @s usedNetAxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/nethoe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/nethoe.mcfunction
new file mode 100644
index 0000000..544a35a
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/nethoe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedNetHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedNetHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedNetHoe
+scoreboard players reset @s usedNetHoe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/netpickaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/netpickaxe.mcfunction
new file mode 100644
index 0000000..5a0fce4
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/netpickaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedNetPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedNetPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedNetPickaxe
+scoreboard players reset @s usedNetPickaxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/netshovel.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/netshovel.mcfunction
new file mode 100644
index 0000000..1f93374
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/netshovel.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedNetShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedNetShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedNetShovel
+scoreboard players reset @s usedNetShovel
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/shears.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/shears.mcfunction
new file mode 100644
index 0000000..eec6202
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/shears.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedShears
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedShears
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedShears
+scoreboard players reset @s usedShears
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/stoaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/stoaxe.mcfunction
new file mode 100644
index 0000000..2a8ff60
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/stoaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedStoAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedStoAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedStoAxe
+scoreboard players reset @s usedStoAxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/stohoe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/stohoe.mcfunction
new file mode 100644
index 0000000..e552f56
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/stohoe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedStoHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedStoHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedStoHoe
+scoreboard players reset @s usedStoHoe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/stopickaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/stopickaxe.mcfunction
new file mode 100644
index 0000000..b80c61a
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/stopickaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedStoPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedStoPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedStoPickaxe
+scoreboard players reset @s usedStoPickaxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/stoshovel.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/stoshovel.mcfunction
new file mode 100644
index 0000000..8791b85
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/stoshovel.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedStoShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedStoShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedStoShovel
+scoreboard players reset @s usedStoShovel
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/wooaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/wooaxe.mcfunction
new file mode 100644
index 0000000..7b460d8
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/wooaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedWooAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedWooAxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedWooAxe
+scoreboard players reset @s usedWooAxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/woohoe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/woohoe.mcfunction
new file mode 100644
index 0000000..9f135e5
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/woohoe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedWooHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedWooHoe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedWooHoe
+scoreboard players reset @s usedWooHoe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/woopickaxe.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/woopickaxe.mcfunction
new file mode 100644
index 0000000..317eccb
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/woopickaxe.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedWooPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedWooPickaxe
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedWooPickaxe
+scoreboard players reset @s usedWooPickaxe
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/tools/wooshovel.mcfunction b/data/fz/functions/scoreboards/digcounter/tools/wooshovel.mcfunction
new file mode 100644
index 0000000..65b91c3
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/tools/wooshovel.mcfunction
@@ -0,0 +1,6 @@
+#计算挖掘榜和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s digCounter += @s usedWooShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 digCounter += @s usedWooShovel
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总挖掘量 totalList += @s usedWooShovel
+scoreboard players reset @s usedWooShovel
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/toolsfix.mcfunction b/data/fz/functions/scoreboards/digcounter/toolsfix.mcfunction
new file mode 100644
index 0000000..9427f96
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/toolsfix.mcfunction
@@ -0,0 +1,7 @@
+#为digtrigger函数修正非挖掘的使用带来的加分(对一些方块使用工具)
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players remove @s digCounter 1
+execute unless score @s carpetBot matches 1 run scoreboard players remove 总挖掘量 digCounter 1
+execute unless score @s carpetBot matches 1 run scoreboard players remove 总挖掘量 totalList 1
+advancement revoke @s only fz:scoreboards/digcounter/toolsfix
+#铲子和锄头的方块判断居然只响应产物不响应原方块,更离谱的是斧头两者会同时相应
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/digcounter/toolsfix2.mcfunction b/data/fz/functions/scoreboards/digcounter/toolsfix2.mcfunction
new file mode 100644
index 0000000..de1fd51
--- /dev/null
+++ b/data/fz/functions/scoreboards/digcounter/toolsfix2.mcfunction
@@ -0,0 +1,6 @@
+#为digtrigger函数修正非挖掘的使用带来的加分(使用工具攻击实体)
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players remove @s digCounter 1
+execute unless score @s carpetBot matches 1 run scoreboard players remove 总挖掘量 digCounter 1
+execute unless score @s carpetBot matches 1 run scoreboard players remove 总挖掘量 totalList 1
+advancement revoke @s only fz:scoreboards/digcounter/toolsfix2
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/fishingcounter/calculator.mcfunction b/data/fz/functions/scoreboards/fishingcounter/calculator.mcfunction
new file mode 100644
index 0000000..c43765b
--- /dev/null
+++ b/data/fz/functions/scoreboards/fishingcounter/calculator.mcfunction
@@ -0,0 +1,9 @@
+#计算钓鱼数和总榜
+#判断条件用于排除地毯小人
+execute unless score @s carpetBot matches 1 run scoreboard players operation @s fishingCounter += @s fishingTester
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总钓鱼数 fishingCounter += @s fishingTester
+execute unless score @s carpetBot matches 1 run scoreboard players operation 总钓鱼数 totalList += @s fishingTester
+#重置钓鱼探测记分板
+scoreboard players reset @s fishingTester
+#重置出发该函数的成就
+advancement revoke @s only fz:scoreboards/fishingcounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/fishingcounter/setdisplay.mcfunction b/data/fz/functions/scoreboards/fishingcounter/setdisplay.mcfunction
new file mode 100644
index 0000000..e56e857
--- /dev/null
+++ b/data/fz/functions/scoreboards/fishingcounter/setdisplay.mcfunction
@@ -0,0 +1 @@
+scoreboard objectives setdisplay sidebar.team.gold fishingCounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/install.mcfunction b/data/fz/functions/scoreboards/install.mcfunction
new file mode 100644
index 0000000..1785bed
--- /dev/null
+++ b/data/fz/functions/scoreboards/install.mcfunction
@@ -0,0 +1,114 @@
+scoreboard objectives add carpetBot dummy
+#在线时间计数器记分板,用于activation/main函数
+scoreboard objectives add actimeCounter dummy
+
+scoreboard objectives add killCounter dummy
+scoreboard objectives add digCounter dummy
+ scoreboard objectives add usedDiaAxe minecraft.used:minecraft.diamond_axe
+ scoreboard objectives add usedDiaPickaxe minecraft.used:minecraft.diamond_pickaxe
+ scoreboard objectives add usedDiaShovel minecraft.used:minecraft.diamond_shovel
+ scoreboard objectives add usedDiaHoe minecraft.used:minecraft.diamond_hoe
+ scoreboard objectives add usedIroAxe minecraft.used:minecraft.iron_axe
+ scoreboard objectives add usedIroPickaxe minecraft.used:minecraft.iron_pickaxe
+ scoreboard objectives add usedIroShovel minecraft.used:minecraft.iron_shovel
+ scoreboard objectives add usedIroHoe minecraft.used:minecraft.iron_hoe
+ scoreboard objectives add usedStoAxe minecraft.used:minecraft.stone_axe
+ scoreboard objectives add usedStoPickaxe minecraft.used:minecraft.stone_pickaxe
+ scoreboard objectives add usedStoShovel minecraft.used:minecraft.stone_shovel
+ scoreboard objectives add usedStoHoe minecraft.used:minecraft.stone_hoe
+ scoreboard objectives add usedWooAxe minecraft.used:minecraft.wooden_axe
+ scoreboard objectives add usedWooPickaxe minecraft.used:minecraft.wooden_pickaxe
+ scoreboard objectives add usedWooShovel minecraft.used:minecraft.wooden_shovel
+ scoreboard objectives add usedWooHoe minecraft.used:minecraft.wooden_hoe
+ scoreboard objectives add usedGolAxe minecraft.used:minecraft.golden_axe
+ scoreboard objectives add usedGolPickaxe minecraft.used:minecraft.golden_pickaxe
+ scoreboard objectives add usedGolShovel minecraft.used:minecraft.golden_shovel
+ scoreboard objectives add usedGolHoe minecraft.used:minecraft.golden_hoe
+ scoreboard objectives add usedNetAxe minecraft.used:minecraft.netherite_axe
+ scoreboard objectives add usedNetPickaxe minecraft.used:minecraft.netherite_pickaxe
+ scoreboard objectives add usedNetShovel minecraft.used:minecraft.netherite_shovel
+ scoreboard objectives add usedNetHoe minecraft.used:minecraft.netherite_hoe
+ scoreboard objectives add usedShears minecraft.used:minecraft.shears
+scoreboard objectives add deathCounter dummy
+ scoreboard objectives add deathTester deathCount
+scoreboard objectives add tradingCounter dummy
+scoreboard objectives add fishingCounter dummy
+ scoreboard objectives add fishingTester minecraft.custom:fish_caught
+scoreboard objectives add damageTaken dummy
+ scoreboard objectives add 10xDamageTaken minecraft.custom:damage_taken
+scoreboard objectives add activation dummy
+scoreboard objectives add totalList dummy
+scoreboard objectives add bedrockBreaked dummy
+scoreboard objectives add fz.bbl dummy
+
+scoreboard objectives modify activation displayname {"text": "活跃时间(h)","color": "aqua"}
+scoreboard objectives modify damageTaken displayname {"text": "抖M名单","color": "yellow"}
+scoreboard objectives modify deathCounter displayname {"text": "死亡榜","color": "dark_red"}
+scoreboard objectives modify digCounter displayname {"text": "挖掘榜","color": "gray"}
+scoreboard objectives modify fishingCounter displayname {"text": "钩直饵咸","color": "blue"}
+scoreboard objectives modify killCounter displayname {"text": "击杀榜","color": "red"}
+scoreboard objectives modify tradingCounter displayname {"text": "交♂易榜","color": "green"}
+scoreboard objectives modify totalList displayname {"text": "总 量","color": "dark_aqua"}
+scoreboard objectives modify bedrockBreaked displayname {"text": "铁头功","color": "dark_green"}
+
+team add gold
+team add aqua
+team add yellow
+team add dark_red
+team add gray
+team add blue
+team add red
+team add green
+team add dark_aqua
+team add dark_green
+team modify gold color gold
+team modify aqua color aqua
+team modify yellow color yellow
+team modify dark_red color dark_red
+team modify gray color gray
+team modify blue color blue
+team modify red color red
+team modify dark_aqua color dark_aqua
+team modify green color green
+team modify dark_green color dark_green
+
+team join aqua 总在线时间(h)
+team join yellow 群p抖M
+team join dark_red 全部木大
+team join gray 总挖掘量
+team join blue 总钓鱼数
+team join red 总击杀数
+team join green 总交♂易数
+team join dark_green 全员头铁
+#各计分板的总量
+scoreboard players operation 总在线时间(h) activation = 总在线时间(h) activation
+scoreboard players operation 群p抖M damageTaken = 群p抖M damageTaken
+scoreboard players operation 全部木大 deathCounter = 全部木大 deathCounter
+scoreboard players operation 总挖掘量 digCounter = 总挖掘量 digCounter
+scoreboard players operation 总钓鱼数 fishingCounter = 总钓鱼数 fishingCounter
+scoreboard players operation 总击杀数 killCounter = 总击杀数 killCounter
+scoreboard players operation 总交♂易数 tradingCounter = 总交♂易数 tradingCounter
+#总榜的总量
+scoreboard players operation 总在线时间(h) totalList = 总在线时间(h) totalList
+scoreboard players operation 群p抖M totalList = 群p抖M totalList
+scoreboard players operation 全部木大 totalList = 全部木大 totalList
+scoreboard players operation 总挖掘量 totalList = 总挖掘量 totalList
+scoreboard players operation 总钓鱼数 totalList = 总钓鱼数 totalList
+scoreboard players operation 总击杀数 totalList = 总击杀数 totalList
+scoreboard players operation 总交♂易数 totalList = 总交♂易数 totalList
+
+scoreboard objectives setdisplay sidebar.team.aqua activation
+scoreboard objectives setdisplay sidebar.team.yellow damageTaken
+scoreboard objectives setdisplay sidebar.team.dark_red deathCounter
+scoreboard objectives setdisplay sidebar.team.gray digCounter
+scoreboard objectives setdisplay sidebar.team.blue fishingCounter
+scoreboard objectives setdisplay sidebar.team.red killCounter
+scoreboard objectives setdisplay sidebar.team.dark_aqua totalList
+scoreboard objectives setdisplay sidebar.team.green tradingCounter
+scoreboard objectives setdisplay sidebar.team.dark_green bedrockBreaked
+
+data merge storage fz.installed {scoreboards:1b}
+
+#提示已安装
+tellraw @a {"text": "[信息]记分板已安装","color": "#5fff00"}
+function fz:scoreboards/start
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/killcounter/calculator.mcfunction b/data/fz/functions/scoreboards/killcounter/calculator.mcfunction
new file mode 100644
index 0000000..a476e0a
--- /dev/null
+++ b/data/fz/functions/scoreboards/killcounter/calculator.mcfunction
@@ -0,0 +1,6 @@
+#计算击杀榜和总榜
+scoreboard players add @s killCounter 1
+scoreboard players add 总击杀数 killCounter 1
+scoreboard players add 总击杀数 totalList 1
+#重置触发该函数的成就,地毯小人已在成就里排除
+advancement revoke @s only fz:scoreboards/killcounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/killcounter/setdisplay.mcfunction b/data/fz/functions/scoreboards/killcounter/setdisplay.mcfunction
new file mode 100644
index 0000000..05ede4c
--- /dev/null
+++ b/data/fz/functions/scoreboards/killcounter/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将击杀榜显示给轮播记分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.gold killCounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/main.mcfunction b/data/fz/functions/scoreboards/main.mcfunction
new file mode 100644
index 0000000..dddbb42
--- /dev/null
+++ b/data/fz/functions/scoreboards/main.mcfunction
@@ -0,0 +1,10 @@
+function fz:scoreboards/killcounter/killcounter
+schedule function fz:scoreboards/deathcounter/setdisplay 10s replace
+schedule function fz:scoreboards/digcounter/setdisplay 20s replace
+schedule function fz:scoreboards/tradingcounter/setdisplay 30s replace
+schedule function fz:scoreboards/fishingcounter/setdisplay 40s replace
+schedule function fz:scoreboards/damagetaken/setdisplay 50s replace
+schedule function fz:scoreboards/activation/setdisplay 60s replace
+schedule function fz:scoreboards/totallist 70s replace
+schedule function fz:scoreboards/bedrockbreaked/setdisplay 80s replace
+schedule function fz:scoreboards/main 90s replace
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/start.mcfunction b/data/fz/functions/scoreboards/start.mcfunction
new file mode 100644
index 0000000..bfc34bb
--- /dev/null
+++ b/data/fz/functions/scoreboards/start.mcfunction
@@ -0,0 +1,13 @@
+function fz:scoreboards/main
+function fz:scoreboards/activation/main
+
+advancement revoke @a only fz:scoreboards/activation
+advancement revoke @a only fz:scoreboards/damagetaken
+advancement revoke @a only fz:scoreboards/deathcounter
+advancement revoke @a only fz:scoreboards/fishingcounter
+advancement revoke @a only fz:scoreboards/killcounter
+advancement revoke @a only fz:scoreboards/tradingcounter
+advancement revoke @a only fz:scoreboards/digcounter/digtrigger
+advancement revoke @a only fz:scoreboards/digcounter/toolsfix
+
+tellraw @a {"text": "[信息]记分板已启用","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/totallist.mcfunction b/data/fz/functions/scoreboards/totallist.mcfunction
new file mode 100644
index 0000000..ef72da7
--- /dev/null
+++ b/data/fz/functions/scoreboards/totallist.mcfunction
@@ -0,0 +1 @@
+scoreboard objectives setdisplay sidebar.team.gold totalList
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/tradingcounter/calculator.mcfunction b/data/fz/functions/scoreboards/tradingcounter/calculator.mcfunction
new file mode 100644
index 0000000..78a58d6
--- /dev/null
+++ b/data/fz/functions/scoreboards/tradingcounter/calculator.mcfunction
@@ -0,0 +1,6 @@
+#计算交易榜和总榜
+scoreboard players add @s tradingCounter 1
+scoreboard players add 总交♂易数 tradingCounter 1
+scoreboard players add 总交♂易数 totalList 1
+#重置触发该函数的成就,地毯小人已在成就里排除
+advancement revoke @s only fz:scoreboards/tradingcounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/tradingcounter/setdisplay.mcfunction b/data/fz/functions/scoreboards/tradingcounter/setdisplay.mcfunction
new file mode 100644
index 0000000..3e4d637
--- /dev/null
+++ b/data/fz/functions/scoreboards/tradingcounter/setdisplay.mcfunction
@@ -0,0 +1,2 @@
+#将交易榜显示给轮播记分板的队伍(金队)
+scoreboard objectives setdisplay sidebar.team.gold tradingCounter
\ No newline at end of file
diff --git a/data/fz/functions/scoreboards/uninstall.mcfunction b/data/fz/functions/scoreboards/uninstall.mcfunction
new file mode 100644
index 0000000..4d0e5b3
--- /dev/null
+++ b/data/fz/functions/scoreboards/uninstall.mcfunction
@@ -0,0 +1,58 @@
+schedule clear fz:scoreboards/totallist
+schedule clear fz:scoreboards/activation/activation
+schedule clear fz:scoreboards/damagetaken/damagetaken
+schedule clear fz:scoreboards/deathcounter/deathcounter
+schedule clear fz:scoreboards/digcounter/digcounter
+schedule clear fz:scoreboards/fishingcounter/fishingcounter
+schedule clear fz:scoreboards/killcounter/killcounter
+schedule clear fz:scoreboards/tradingcounter/tradingcounter
+schedule clear fz:scoreboards/main
+
+scoreboard objectives remove carpetBot
+scoreboard objectives remove actimeCounter
+
+scoreboard objectives remove usedDiaAxe
+scoreboard objectives remove usedDiaPickaxe
+scoreboard objectives remove usedDiaShovel
+scoreboard objectives remove usedDiaHoe
+scoreboard objectives remove usedIroAxe
+scoreboard objectives remove usedIroPickaxe
+scoreboard objectives remove usedIroShovel
+scoreboard objectives remove usedIroHoe
+scoreboard objectives remove usedStoAxe
+scoreboard objectives remove usedStoPickaxe
+scoreboard objectives remove usedStoShovel
+scoreboard objectives remove usedStoHoe
+scoreboard objectives remove usedWooAxe
+scoreboard objectives remove usedWooPickaxe
+scoreboard objectives remove usedWooShovel
+scoreboard objectives remove usedWooHoe
+scoreboard objectives remove usedGolAxe
+scoreboard objectives remove usedGolPickaxe
+scoreboard objectives remove usedGolShovel
+scoreboard objectives remove usedGolHoe
+scoreboard objectives remove usedNetAxe
+scoreboard objectives remove usedNetPickaxe
+scoreboard objectives remove usedNetShovel
+scoreboard objectives remove usedNetHoe
+scoreboard objectives remove fz.bbl
+
+scoreboard objectives remove deathTester
+scoreboard objectives remove fishingTester
+scoreboard objectives remove 10xDamageTaken
+
+scoreboard objectives setdisplay sidebar.team.aqua
+scoreboard objectives setdisplay sidebar.team.yellow
+scoreboard objectives setdisplay sidebar.team.dark_red
+scoreboard objectives setdisplay sidebar.team.gray
+scoreboard objectives setdisplay sidebar.team.blue
+scoreboard objectives setdisplay sidebar.team.red
+scoreboard objectives setdisplay sidebar.team.light_purple
+scoreboard objectives setdisplay sidebar.team.green
+scoreboard objectives setdisplay sidebar.team.gold
+
+#提示已卸载
+tellraw @a {"text": "[信息]记分板已卸载","color": "#5fff00"}
+tellraw @s [{"text": "[警告]您要删除计分板数据吗,它将会永久失去!(真的很久!)", "color": "#ffd900"},{"text": "[确定]","clickEvent": {"action": "run_command", "value": "/function fz:scoreboards/delscore"}, "color": "#00ff00"}]
+
+data merge storage fz.installed {scoreboards:0b}
\ No newline at end of file
diff --git a/data/fz/functions/start.mcfunction b/data/fz/functions/start.mcfunction
new file mode 100644
index 0000000..761cf37
--- /dev/null
+++ b/data/fz/functions/start.mcfunction
@@ -0,0 +1,7 @@
+#判断各功能是否已安装并运行
+execute if data storage fz.installed {scoreboards: 1b} run function fz:scoreboards/start
+execute if data storage fz.installed {sweeper: 1b} run function fz:sweeper/start
+execute if data storage fz.installed {config: 1b} run function fz:config/start
+function fz:carpet/carpet
+#测试用的输出
+tellraw @a {"text": "[信息]启动完毕","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/bossbar.mcfunction b/data/fz/functions/sweeper/bossbar.mcfunction
new file mode 100644
index 0000000..901f8d2
--- /dev/null
+++ b/data/fz/functions/sweeper/bossbar.mcfunction
@@ -0,0 +1,4 @@
+bossbar set fz.sweeper name [{"score": {"name": "sweeperBossbar","objective": "parameter"},"color": "#ff6100","underlined": true,"bold": true},{"text": "秒后清理垃圾","color": "#ffd900","bold": false}]
+bossbar set fz.sweeper players @a[tag=!fz.sweeperBossbarOff]
+scoreboard players remove sweeperBossbar parameter 1
+schedule function fz:sweeper/bossbar 1s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/config/off.mcfunction b/data/fz/functions/sweeper/config/off.mcfunction
new file mode 100644
index 0000000..93f4d1f
--- /dev/null
+++ b/data/fz/functions/sweeper/config/off.mcfunction
@@ -0,0 +1,19 @@
+execute unless score sweeperTime parameter matches 0 run scoreboard players set sweeperTime parameter 0
+schedule clear fz:sweeper/bossbar
+schedule clear fz:sweeper/main
+schedule clear fz:sweeper/timer/1s
+schedule clear fz:sweeper/timer/2s
+schedule clear fz:sweeper/timer/3s
+schedule clear fz:sweeper/timer/4s
+schedule clear fz:sweeper/timer/5s
+schedule clear fz:sweeper/timer/10s
+schedule clear fz:sweeper/timer/30s
+schedule clear fz:sweeper/timer/1min
+schedule clear fz:sweeper/timer/2min
+schedule clear fz:sweeper/timer/3min
+schedule clear fz:sweeper/timer/4min
+#设置怪物血条
+bossbar set minecraft:fz.sweeper visible false
+
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[信息]扫地机已关闭","color": "#5fff00"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 2
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/config/on.mcfunction b/data/fz/functions/sweeper/config/on.mcfunction
new file mode 100644
index 0000000..302b44a
--- /dev/null
+++ b/data/fz/functions/sweeper/config/on.mcfunction
@@ -0,0 +1,23 @@
+execute if score @s config matches 1478966211 run scoreboard players set sweeperTime parameter 30
+execute if score @s config matches 1478966212 run scoreboard players set sweeperTime parameter 60
+execute if score @s config matches 1478966213 run scoreboard players set sweeperTime parameter 120
+execute if score @s config matches 1478966214 run scoreboard players set sweeperTime parameter 180
+execute if score @s config matches 1478966215 run scoreboard players set sweeperTime parameter 240
+schedule clear fz:sweeper/bossbar
+schedule clear fz:sweeper/main
+schedule clear fz:sweeper/timer/1s
+schedule clear fz:sweeper/timer/2s
+schedule clear fz:sweeper/timer/3s
+schedule clear fz:sweeper/timer/4s
+schedule clear fz:sweeper/timer/5s
+schedule clear fz:sweeper/timer/10s
+schedule clear fz:sweeper/timer/30s
+schedule clear fz:sweeper/timer/1min
+schedule clear fz:sweeper/timer/2min
+schedule clear fz:sweeper/timer/3min
+schedule clear fz:sweeper/timer/4min
+#设置怪物血条
+bossbar set minecraft:fz.sweeper visible true
+
+function fz:sweeper/main
+function fz:sweeper/bossbar
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/config/trigger.mcfunction b/data/fz/functions/sweeper/config/trigger.mcfunction
new file mode 100644
index 0000000..d3c7de1
--- /dev/null
+++ b/data/fz/functions/sweeper/config/trigger.mcfunction
@@ -0,0 +1,19 @@
+execute if score @s config matches 1478966211..1478966215 run function fz:sweeper/config/on
+execute if score @s config matches 1478966210 run function fz:sweeper/config/off
+#提示音开关
+execute if score @s config matches 1478966208 run tag @s remove fz.sweeperSoundOff
+execute if score @s config matches 1478966209 run tag @s add fz.sweeperSoundOff
+#boss血条时间提示开关
+execute if score @s config matches 1478966206 run tag @s remove fz.sweeperBossbarOff
+execute if score @s config matches 1478966207 run tag @s add fz.sweeperBossbarOff
+#文字时间提示开关
+execute if score @s config matches 1478966204 run tag @s remove fz.sweeperMessageOff
+execute if score @s config matches 1478966205 run tag @s add fz.sweeperMessageOff
+#矿车白名单
+execute if score @s config matches 1478966216 run scoreboard players set keepMinecart parameter 1
+execute if score @s config matches 1478966217 run scoreboard players reset keepMinecart parameter
+
+bossbar set minecraft:fz.sweeper players @a[tag=!fz.sweeperBossbarOff]
+
+scoreboard players reset @s config
+function fz:config/display
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/install.mcfunction b/data/fz/functions/sweeper/install.mcfunction
new file mode 100644
index 0000000..4705a8e
--- /dev/null
+++ b/data/fz/functions/sweeper/install.mcfunction
@@ -0,0 +1,6 @@
+data merge storage fz.installed {sweeper: 1b}
+bossbar add fz.sweeper {"text":"null"}
+bossbar set fz.sweeper value 0
+#提示已安装
+tellraw @a {"text": "[信息]扫地机已安装","color": "#5fff00"}
+function fz:sweeper/start
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/main.mcfunction b/data/fz/functions/sweeper/main.mcfunction
new file mode 100644
index 0000000..5bce38c
--- /dev/null
+++ b/data/fz/functions/sweeper/main.mcfunction
@@ -0,0 +1,10 @@
+execute if score keepMinecart parameter matches 1 run execute store result score sweeperItem parameter run kill @e[type=item,predicate=!fz:sweeper/minecart]
+execute unless score keepMinecart parameter matches 1 run execute store result score sweeperItem parameter run kill @e[type=item]
+tellraw @a [{"text": "[信息]本次清理了","color": "#5fff00"},{"score": {"objective": "parameter", "name": "sweeperItem"},"color": "#5fff00"},{"text": "堆物品","color": "#5fff00"}]
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 2
+execute if score sweeperTime parameter matches 30 run function fz:sweeper/timer/30s
+execute if score sweeperTime parameter matches 60 run function fz:sweeper/timer/1min
+execute if score sweeperTime parameter matches 120 run function fz:sweeper/timer/2min
+execute if score sweeperTime parameter matches 180 run function fz:sweeper/timer/3min
+execute if score sweeperTime parameter matches 240 run function fz:sweeper/timer/4min
+scoreboard players operation sweeperBossbar parameter = sweeperTime parameter
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/start.mcfunction b/data/fz/functions/sweeper/start.mcfunction
new file mode 100644
index 0000000..9e39f82
--- /dev/null
+++ b/data/fz/functions/sweeper/start.mcfunction
@@ -0,0 +1,16 @@
+schedule clear fz:sweeper/bossbar
+schedule clear fz:sweeper/main
+schedule clear fz:sweeper/timer/1s
+schedule clear fz:sweeper/timer/2s
+schedule clear fz:sweeper/timer/3s
+schedule clear fz:sweeper/timer/4s
+schedule clear fz:sweeper/timer/5s
+schedule clear fz:sweeper/timer/10s
+schedule clear fz:sweeper/timer/30s
+schedule clear fz:sweeper/timer/1min
+schedule clear fz:sweeper/timer/2min
+schedule clear fz:sweeper/timer/3min
+schedule clear fz:sweeper/timer/4min
+bossbar set fz.sweeper visible false
+
+tellraw @a {"text": "[信息]扫地机已启用","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/10s.mcfunction b/data/fz/functions/sweeper/timer/10s.mcfunction
new file mode 100644
index 0000000..a7c3940
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/10s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]10s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/5s 5s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/1min.mcfunction b/data/fz/functions/sweeper/timer/1min.mcfunction
new file mode 100644
index 0000000..16e8a70
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/1min.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]1min后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/30s 30s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/1s.mcfunction b/data/fz/functions/sweeper/timer/1s.mcfunction
new file mode 100644
index 0000000..d64f111
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/1s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]1s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/main 1s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/2min.mcfunction b/data/fz/functions/sweeper/timer/2min.mcfunction
new file mode 100644
index 0000000..e2599a5
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/2min.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]2min后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/1min 60s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/2s.mcfunction b/data/fz/functions/sweeper/timer/2s.mcfunction
new file mode 100644
index 0000000..e277735
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/2s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]2s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/1s 1s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/30s.mcfunction b/data/fz/functions/sweeper/timer/30s.mcfunction
new file mode 100644
index 0000000..8bda140
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/30s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]30s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/10s 20s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/3min.mcfunction b/data/fz/functions/sweeper/timer/3min.mcfunction
new file mode 100644
index 0000000..f1414ca
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/3min.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]3min后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/2min 60s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/3s.mcfunction b/data/fz/functions/sweeper/timer/3s.mcfunction
new file mode 100644
index 0000000..94390ab
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/3s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]3s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/2s 1s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/4min.mcfunction b/data/fz/functions/sweeper/timer/4min.mcfunction
new file mode 100644
index 0000000..1dc97a9
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/4min.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]4min后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/3min 60s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/4s.mcfunction b/data/fz/functions/sweeper/timer/4s.mcfunction
new file mode 100644
index 0000000..5a91789
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/4s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]4s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/3s 1s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/timer/5s.mcfunction b/data/fz/functions/sweeper/timer/5s.mcfunction
new file mode 100644
index 0000000..dbbbc2a
--- /dev/null
+++ b/data/fz/functions/sweeper/timer/5s.mcfunction
@@ -0,0 +1,3 @@
+tellraw @a[tag=!fz.sweeperMessageOff] {"text": "[提醒]5s后清理掉落物","color": "#66ffff"}
+execute as @a[tag=!fz.sweeperSoundOff] at @s run playsound minecraft:block.note_block.pling voice @s ~ ~ ~ 1 1
+schedule function fz:sweeper/timer/4s 1s
\ No newline at end of file
diff --git a/data/fz/functions/sweeper/uninstall.mcfunction b/data/fz/functions/sweeper/uninstall.mcfunction
new file mode 100644
index 0000000..e19627a
--- /dev/null
+++ b/data/fz/functions/sweeper/uninstall.mcfunction
@@ -0,0 +1,17 @@
+schedule clear fz:sweeper/bossbar
+schedule clear fz:sweeper/main
+schedule clear fz:sweeper/timer/1s
+schedule clear fz:sweeper/timer/2s
+schedule clear fz:sweeper/timer/3s
+schedule clear fz:sweeper/timer/4s
+schedule clear fz:sweeper/timer/5s
+schedule clear fz:sweeper/timer/10s
+schedule clear fz:sweeper/timer/30s
+schedule clear fz:sweeper/timer/1min
+schedule clear fz:sweeper/timer/2min
+schedule clear fz:sweeper/timer/3min
+schedule clear fz:sweeper/timer/4min
+
+data merge storage fz.installed {sweeper: 0b}
+#提示已卸载
+tellraw @a {"text": "[信息]扫地机已卸载","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/uninstall.mcfunction b/data/fz/functions/uninstall.mcfunction
new file mode 100644
index 0000000..9f72e0b
--- /dev/null
+++ b/data/fz/functions/uninstall.mcfunction
@@ -0,0 +1,14 @@
+#全卸载
+function fz:config/uninstall
+function fz:health/uninstall
+function fz:scoreboards/uninstall
+function fz:sweeper/uninstall
+function fz:login/logintips/uninstall
+#删除系统计分板
+scoreboard objectives remove parameter
+scoreboard objectives remove calculator
+scoreboard objectives remove leaveGame
+#存入已卸载信息,下次启动不会重新安装
+data merge storage fz.installed {installed: 0b}
+#提示已卸载
+tellraw @a {"text": "[信息]FZ'sDatapack已卸载","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/functions/update.mcfunction b/data/fz/functions/update.mcfunction
new file mode 100644
index 0000000..6525bce
--- /dev/null
+++ b/data/fz/functions/update.mcfunction
@@ -0,0 +1,12 @@
+#卸载
+function fz:uninstall
+#安装
+function fz:install
+#再卸载已经被卸载的项目
+execute if data storage fz.installed {config: 0b} run function fz:config/uninstall
+execute if data storage fz.installed {sweeper: 0b} run function fz:sweeper/uninstall
+execute if data storage fz.installed {scoreboards: 0b} run function fz:scoreboards/uninstall
+execute if data storage fz.installed {health: 0b} run function fz:health/uninstall
+execute if data storage fz.installed {logintips: 0b} run function fz:login/logintips/uninstall
+#提示已安装
+tellraw @a {"text": "[信息]升级完成","color": "#5fff00"}
\ No newline at end of file
diff --git a/data/fz/predicates/sweeper/minecart.json b/data/fz/predicates/sweeper/minecart.json
new file mode 100644
index 0000000..60a6104
--- /dev/null
+++ b/data/fz/predicates/sweeper/minecart.json
@@ -0,0 +1,7 @@
+{
+ "condition": "minecraft:entity_properties",
+ "entity": "this",
+ "predicate": {
+ "nbt": "{Item:{id:\"minecraft:minecart\",Count:1b}}"
+ }
+}
\ No newline at end of file
diff --git a/data/minecraft/tags/functions/load.json b/data/minecraft/tags/functions/load.json
new file mode 100644
index 0000000..d88c51a
--- /dev/null
+++ b/data/minecraft/tags/functions/load.json
@@ -0,0 +1,5 @@
+{
+ "values": [
+ "fz:load"
+ ]
+}
\ No newline at end of file
diff --git a/data/minecraft/tags/functions/tick.json b/data/minecraft/tags/functions/tick.json
new file mode 100644
index 0000000..8aecd26
--- /dev/null
+++ b/data/minecraft/tags/functions/tick.json
@@ -0,0 +1,3 @@
+{
+ "values": []
+}
\ No newline at end of file
diff --git a/here.sc b/here.sc
new file mode 100644
index 0000000..015f6f0
--- /dev/null
+++ b/here.sc
@@ -0,0 +1,37 @@
+__config() -> {
+ 'stay_loaded' -> true
+};
+__command() -> (
+ s_player = player();
+ pos = query(s_player, 'pos');
+ dim = query(s_player, 'dimension');
+ if(dim == 'overworld',
+ (
+ run(str('tellraw @a [{"selector": "@s"},{"text":"说: 我在主世界[x:%d, y:%d, z:%d, dim:overworld]","color": "aqua"}]',
+ round(pos:0), round(pos:1), round(pos:2)
+ ));
+ run(str('tellraw @a [{"text":"- 对应地狱: [x:%d, y:128, z:%d, dim:the_nether]","color": "aqua"}]',
+ round((pos:0)/8), round((pos:2)/8)
+ ))
+ ),
+ dim == 'the_nether',
+ (
+ run(str('tellraw @a [{"selector": "@s"},{"text":"说: 我在下界[x:%d, y:%d, z:%d, dim:the_nether]","color": "aqua"}]',
+ round(pos:0), round(pos:1), round(pos:2)
+ ));
+ run(str('tellraw @a [{"text":"- 对应主世界: [x:%d, y:64, z:%d, dim:overworld]","color": "aqua"}]',
+ round((pos:0)*8), round((pos:2)*8)
+ ))
+ ),
+ dim == 'the_end',
+ (
+ run(str('tellraw @a [{"selector": "@s"},{"text":"说: 我在末地[x:%d, y:%d, z:%d, dim:%s]","color": "aqua"}]',
+ round(pos:0), round(pos:1), round(pos:2), dim
+ ))
+ ),
+ run(str('tellraw @a [{"selector": "@s"},{"text":"说: 我在%s世界[x:%d, y:%d, z:%d, dim:%s]","color": "aqua"}]',
+ dim, round(pos:0), round(pos:1), round(pos:2), dim
+ ))
+ );
+ exit()
+)
\ No newline at end of file
diff --git a/pack.mcmeta b/pack.mcmeta
new file mode 100644
index 0000000..79b7482
--- /dev/null
+++ b/pack.mcmeta
@@ -0,0 +1,6 @@
+{
+ "pack": {
+ "description": "FZ's Datapack - Code By Harvey_Husky",
+ "pack_format": 7
+ }
+}
\ No newline at end of file
diff --git a/restore_scores.sc b/restore_scores.sc
new file mode 100644
index 0000000..6ef7823
--- /dev/null
+++ b/restore_scores.sc
@@ -0,0 +1,218 @@
+global_version = '1.2.0';
+__config() -> {
+ 'scope' -> 'global',
+ 'stay_loaded' -> false
+};
+__command() -> print('版本:' + global_version);
+global_bl = ['stone', 'granite', 'polished_granite', 'diorite', 'polished_diorite', 'andesite', 'polished_andesite', 'grass_block',
+ 'dirt', 'coarse_dirt', 'podzol', 'crimson_nylium', 'warped_nylium', 'cobblestone', 'oak_planks', 'spruce_planks', 'birch_planks',
+ 'jungle_planks', 'acacia_planks', 'dark_oak_planks', 'crimson_planks', 'warped_planks', 'sand', 'red_sand', 'gravel', 'gold_ore',
+ 'iron_ore', 'coal_ore', 'nether_gold_ore', 'oak_log', 'spruce_log', 'birch_log', 'jungle_log', 'acacia_log', 'dark_oak_log',
+ 'crimson_stem', 'warped_stem', 'stripped_oak_log', 'stripped_spruce_log', 'stripped_birch_log', 'stripped_jungle_log',
+ 'stripped_acacia_log', 'stripped_dark_oak_log', 'stripped_crimson_stem', 'stripped_warped_stem', 'stripped_oak_wood',
+ 'stripped_spruce_wood', 'stripped_birch_wood', 'stripped_jungle_wood', 'stripped_acacia_wood', 'stripped_dark_oak_wood',
+ 'stripped_crimson_hyphae', 'stripped_warped_hyphae', 'oak_wood', 'spruce_wood', 'birch_wood', 'jungle_wood', 'acacia_wood',
+ 'dark_oak_wood', 'crimson_hyphae', 'warped_hyphae', 'sponge', 'wet_sponge', 'glass', 'lapis_ore', 'lapis_block', 'sandstone',
+ 'chiseled_sandstone', 'cut_sandstone', 'white_wool', 'orange_wool', 'magenta_wool', 'light_blue_wool', 'yellow_wool',
+ 'lime_wool', 'pink_wool', 'gray_wool', 'light_gray_wool', 'cyan_wool', 'purple_wool', 'blue_wool', 'brown_wool', 'green_wool',
+ 'red_wool', 'black_wool', 'gold_block', 'iron_block', 'oak_slab', 'spruce_slab', 'birch_slab', 'jungle_slab', 'acacia_slab',
+ 'dark_oak_slab', 'crimson_slab', 'warped_slab', 'stone_slab', 'smooth_stone_slab', 'sandstone_slab', 'cut_sandstone_slab',
+ 'petrified_oak_slab', 'cobblestone_slab', 'brick_slab', 'stone_brick_slab', 'nether_brick_slab', 'quartz_slab',
+ 'red_sandstone_slab', 'cut_red_sandstone_slab', 'purpur_slab', 'prismarine_slab', 'prismarine_brick_slab',
+ 'dark_prismarine_slab', 'smooth_quartz', 'smooth_red_sandstone', 'smooth_sandstone', 'smooth_stone', 'bricks', 'bookshelf',
+ 'mossy_cobblestone', 'obsidian', 'purpur_block', 'purpur_pillar', 'purpur_stairs', 'oak_stairs', 'diamond_ore', 'diamond_block',
+ 'cobblestone_stairs', 'redstone_ore', 'ice', 'snow_block', 'clay', 'pumpkin', 'carved_pumpkin', 'netherrack', 'soul_sand',
+ 'soul_soil', 'basalt', 'polished_basalt', 'glowstone', 'jack_o_lantern', 'stone_bricks', 'mossy_stone_bricks',
+ 'cracked_stone_bricks', 'chiseled_stone_bricks', 'melon', 'brick_stairs', 'stone_brick_stairs', 'mycelium', 'nether_bricks',
+ 'cracked_nether_bricks', 'chiseled_nether_bricks', 'nether_brick_stairs', 'end_stone_bricks', 'sandstone_stairs', 'emerald_ore',
+ 'emerald_block', 'spruce_stairs', 'birch_stairs', 'jungle_stairs', 'crimson_stairs', 'warped_stairs', 'nether_quartz_ore',
+ 'chiseled_quartz_block', 'quartz_block', 'quartz_bricks', 'quartz_pillar', 'quartz_stairs', 'white_terracotta',
+ 'orange_terracotta', 'magenta_terracotta', 'light_blue_terracotta', 'yellow_terracotta', 'lime_terracotta', 'pink_terracotta',
+ 'gray_terracotta', 'light_gray_terracotta', 'cyan_terracotta', 'purple_terracotta', 'blue_terracotta', 'brown_terracotta',
+ 'green_terracotta', 'red_terracotta', 'black_terracotta', 'hay_block', 'terracotta', 'coal_block', 'packed_ice', 'acacia_stairs',
+ 'dark_oak_stairs', 'white_stained_glass', 'orange_stained_glass', 'magenta_stained_glass', 'light_blue_stained_glass',
+ 'yellow_stained_glass', 'lime_stained_glass', 'pink_stained_glass', 'gray_stained_glass', 'light_gray_stained_glass',
+ 'cyan_stained_glass', 'purple_stained_glass', 'blue_stained_glass', 'brown_stained_glass', 'green_stained_glass',
+ 'red_stained_glass', 'black_stained_glass', 'prismarine', 'prismarine_bricks', 'dark_prismarine', 'prismarine_stairs',
+ 'prismarine_brick_stairs', 'dark_prismarine_stairs', 'sea_lantern', 'red_sandstone', 'chiseled_red_sandstone',
+ 'cut_red_sandstone', 'red_sandstone_stairs', 'magma_block', 'nether_wart_block', 'warped_wart_block', 'red_nether_bricks',
+ 'bone_block', 'white_concrete', 'orange_concrete', 'magenta_concrete', 'light_blue_concrete', 'yellow_concrete', 'lime_concrete',
+ 'pink_concrete', 'gray_concrete', 'light_gray_concrete', 'cyan_concrete', 'purple_concrete', 'blue_concrete', 'brown_concrete',
+ 'green_concrete', 'red_concrete', 'black_concrete', 'white_concrete_powder', 'orange_concrete_powder', 'magenta_concrete_powder',
+ 'light_blue_concrete_powder', 'yellow_concrete_powder', 'lime_concrete_powder', 'pink_concrete_powder', 'gray_concrete_powder',
+ 'light_gray_concrete_powder', 'cyan_concrete_powder', 'purple_concrete_powder', 'blue_concrete_powder', 'brown_concrete_powder',
+ 'green_concrete_powder', 'red_concrete_powder', 'black_concrete_powder', 'dead_tube_coral_block', 'dead_brain_coral_block',
+ 'dead_bubble_coral_block', 'dead_fire_coral_block', 'dead_horn_coral_block', 'tube_coral_block', 'brain_coral_block',
+ 'bubble_coral_block', 'fire_coral_block', 'horn_coral_block', 'blue_ice', 'polished_granite_stairs',
+ 'smooth_red_sandstone_stairs', 'mossy_stone_brick_stairs', 'polished_diorite_stairs', 'mossy_cobblestone_stairs',
+ 'end_stone_brick_stairs', 'stone_stairs', 'smooth_sandstone_stairs', 'smooth_quartz_stairs', 'granite_stairs', 'andesite_stairs',
+ 'red_nether_brick_stairs', 'polished_andesite_stairs', 'diorite_stairs', 'polished_granite_slab', 'smooth_red_sandstone_slab',
+ 'mossy_stone_brick_slab', 'polished_diorite_slab', 'mossy_cobblestone_slab', 'end_stone_brick_slab', 'smooth_sandstone_slab',
+ 'smooth_quartz_slab', 'granite_slab', 'andesite_slab', 'red_nether_brick_slab', 'polished_andesite_slab', 'diorite_slab',
+ 'dried_kelp_block', 'netherite_block', 'ancient_debris', 'crying_obsidian', 'blackstone', 'blackstone_slab',
+ 'blackstone_stairs', 'gilded_blackstone', 'polished_blackstone', 'polished_blackstone_slab', 'polished_blackstone_stairs',
+ 'chiseled_polished_blackstone', 'polished_blackstone_bricks', 'polished_blackstone_brick_slab',
+ 'polished_blackstone_brick_stairs', 'cracked_polished_blackstone_bricks', 'oak_sapling', 'spruce_sapling', 'birch_sapling',
+ 'jungle_sapling', 'acacia_sapling', 'dark_oak_sapling', 'oak_leaves', 'spruce_leaves', 'birch_leaves', 'jungle_leaves',
+ 'acacia_leaves', 'dark_oak_leaves', 'cobweb', 'grass', 'fern', 'dead_bush', 'seagrass', 'sea_pickle', 'dandelion', 'poppy',
+ 'blue_orchid', 'allium', 'azure_bluet', 'red_tulip', 'orange_tulip', 'white_tulip', 'pink_tulip', 'oxeye_daisy', 'cornflower',
+ 'lily_of_the_valley', 'wither_rose', 'brown_mushroom', 'red_mushroom', 'crimson_fungus', 'warped_fungus', 'crimson_roots',
+ 'warped_roots', 'nether_sprouts', 'weeping_vines', 'twisting_vines', 'sugar_cane', 'kelp', 'bamboo', 'torch', 'end_rod',
+ 'chorus_plant', 'chorus_flower', 'chest', 'crafting_table', 'furnace', 'ladder', 'cactus', 'jukebox', 'oak_fence',
+ 'spruce_fence', 'birch_fence', 'jungle_fence', 'acacia_fence', 'dark_oak_fence', 'crimson_fence', 'warped_fence', 'soul_torch',
+ 'brown_mushroom_block', 'red_mushroom_block', 'mushroom_stem', 'iron_bars', 'chain', 'glass_pane', 'vine', 'lily_pad',
+ 'nether_brick_fence', 'enchanting_table', 'end_portal_frame', 'ender_chest', 'cobblestone_wall', 'mossy_cobblestone_wall',
+ 'brick_wall', 'prismarine_wall', 'red_sandstone_wall', 'mossy_stone_brick_wall', 'granite_wall', 'stone_brick_wall',
+ 'nether_brick_wall', 'andesite_wall', 'red_nether_brick_wall', 'sandstone_wall', 'end_stone_brick_wall', 'diorite_wall',
+ 'blackstone_wall', 'polished_blackstone_wall', 'polished_blackstone_brick_wall', 'anvil', 'chipped_anvil', 'damaged_anvil',
+ 'white_carpet', 'orange_carpet', 'magenta_carpet', 'light_blue_carpet', 'yellow_carpet', 'lime_carpet', 'pink_carpet',
+ 'gray_carpet', 'light_gray_carpet', 'cyan_carpet', 'purple_carpet', 'blue_carpet', 'brown_carpet', 'green_carpet', 'red_carpet',
+ 'black_carpet', 'slime_block', 'sunflower', 'lilac', 'rose_bush', 'peony', 'white_stained_glass_pane',
+ 'orange_stained_glass_pane', 'magenta_stained_glass_pane', 'light_blue_stained_glass_pane', 'yellow_stained_glass_pane',
+ 'lime_stained_glass_pane', 'pink_stained_glass_pane', 'gray_stained_glass_pane', 'light_gray_stained_glass_pane',
+ 'cyan_stained_glass_pane', 'purple_stained_glass_pane', 'blue_stained_glass_pane', 'brown_stained_glass_pane',
+ 'green_stained_glass_pane', 'red_stained_glass_pane', 'black_stained_glass_pane', 'shulker_box', 'white_shulker_box',
+ 'orange_shulker_box', 'magenta_shulker_box', 'light_blue_shulker_box', 'yellow_shulker_box', 'lime_shulker_box',
+ 'pink_shulker_box', 'gray_shulker_box', 'light_gray_shulker_box', 'cyan_shulker_box', 'purple_shulker_box', 'blue_shulker_box',
+ 'brown_shulker_box', 'green_shulker_box', 'red_shulker_box', 'black_shulker_box', 'white_glazed_terracotta',
+ 'orange_glazed_terracotta', 'magenta_glazed_terracotta', 'light_blue_glazed_terracotta', 'yellow_glazed_terracotta',
+ 'lime_glazed_terracotta', 'pink_glazed_terracotta', 'gray_glazed_terracotta', 'light_gray_glazed_terracotta',
+ 'cyan_glazed_terracotta', 'purple_glazed_terracotta', 'blue_glazed_terracotta', 'brown_glazed_terracotta',
+ 'green_glazed_terracotta', 'red_glazed_terracotta', 'black_glazed_terracotta', 'tube_coral', 'brain_coral', 'bubble_coral',
+ 'fire_coral', 'horn_coral', 'dead_brain_coral', 'dead_bubble_coral', 'dead_fire_coral', 'dead_horn_coral', 'dead_tube_coral',
+ 'tube_coral_fan', 'brain_coral_fan', 'bubble_coral_fan', 'fire_coral_fan', 'horn_coral_fan', 'dead_tube_coral_fan',
+ 'dead_brain_coral_fan', 'dead_bubble_coral_fan', 'dead_fire_coral_fan', 'dead_horn_coral_fan', 'scaffolding', 'oak_sign',
+ 'spruce_sign', 'birch_sign', 'jungle_sign', 'acacia_sign', 'dark_oak_sign', 'crimson_sign', 'warped_sign', 'white_bed',
+ 'orange_bed', 'magenta_bed', 'light_blue_bed', 'yellow_bed', 'lime_bed', 'pink_bed', 'gray_bed', 'light_gray_bed', 'cyan_bed',
+ 'purple_bed', 'blue_bed', 'brown_bed', 'green_bed', 'red_bed', 'black_bed', 'flower_pot', 'skeleton_skull',
+ 'wither_skeleton_skull', 'player_head', 'zombie_head', 'creeper_head', 'dragon_head', 'white_banner', 'orange_banner',
+ 'magenta_banner', 'light_blue_banner', 'yellow_banner', 'lime_banner', 'pink_banner', 'gray_banner', 'light_gray_banner',
+ 'cyan_banner', 'purple_banner', 'blue_banner', 'brown_banner', 'green_banner', 'red_banner', 'black_banner', 'loom', 'composter',
+ 'barrel', 'smoker', 'blast_furnace', 'cartography_table', 'fletching_table', 'grindstone', 'smithing_table', 'stonecutter',
+ 'bell', 'lantern', 'soul_lantern', 'campfire', 'soul_campfire', 'shroomlight', 'bee_nest', 'beehive', 'honey_block',
+ 'honeycomb_block', 'lodestone', 'respawn_anchor', 'dispenser', 'note_block', 'sticky_piston', 'piston', 'tnt', 'lever',
+ 'stone_pressure_plate', 'oak_pressure_plate', 'spruce_pressure_plate', 'birch_pressure_plate', 'jungle_pressure_plate',
+ 'acacia_pressure_plate', 'dark_oak_pressure_plate', 'crimson_pressure_plate', 'warped_pressure_plate',
+ 'polished_blackstone_pressure_plate', 'redstone_torch', 'oak_trapdoor', 'spruce_trapdoor', 'birch_trapdoor', 'jungle_trapdoor',
+ 'acacia_trapdoor', 'dark_oak_trapdoor', 'crimson_trapdoor', 'warped_trapdoor', 'oak_fence_gate', 'spruce_fence_gate',
+ 'birch_fence_gate', 'jungle_fence_gate', 'acacia_fence_gate', 'dark_oak_fence_gate', 'crimson_fence_gate', 'warped_fence_gate',
+ 'redstone_lamp', 'tripwire_hook', 'stone_button', 'oak_button', 'spruce_button', 'birch_button', 'jungle_button',
+ 'acacia_button', 'dark_oak_button', 'crimson_button', 'warped_button', 'polished_blackstone_button', 'trapped_chest',
+ 'light_weighted_pressure_plate', 'heavy_weighted_pressure_plate', 'daylight_detector', 'redstone_block', 'hopper', 'dropper',
+ 'iron_trapdoor', 'observer', 'iron_door', 'oak_door', 'spruce_door', 'birch_door', 'jungle_door', 'acacia_door', 'dark_oak_door',
+ 'crimson_door', 'warped_door', 'repeater', 'comparator', 'redstone', 'lectern', 'target', 'powered_rail', 'detector_rail',
+ 'rail', 'activator_rail', 'beacon', 'turtle_egg', 'conduit', 'brewing_stand', 'cauldron', 'sculk_sensor', 'raw_iron_block',
+ 'raw_copper_block', 'raw_gold_block', 'powder_snow', 'candle', 'deepslate_coal_ore', 'deepslate_iron_ore', 'deepslate_copper_ore',
+ 'deepslate_lapis_ore', 'deepslate_gold_ore', 'deepslate_redstone_ore', 'deepslate_diamond_ore', 'deepslate_emerald_ore',
+ 'cobbled_deepslate', 'infested_stone', 'infested_cobblestone', 'infested_stone_bricks', 'infested_cracked_stone_bricks',
+ 'infested_mossy_stone_bricks', 'infested_chiseled_stone_bricks', 'infested_deepslate', 'deepslate', 'chiseled_deepslate',
+ 'polished_deepslate', 'spore_blossom', 'hanging_roots', 'rooted_dirt', 'dirt_path', 'farmland', 'wall_torch', 'tall_grass',
+ 'tall_seagrass', 'big_dripleaf', 'small_dripleaf', 'glow_berries', 'cave_vines', 'cave_vines_plant', 'moss_carpet', 'moss_block',
+ 'flowering_azalea_leaves', 'azalea_leaves', 'azalea', 'flowering_azalea', 'glow_lichen', 'dripstone_block', 'pointed_dripstone',
+ 'lightning_rod', 'cobbled_deepslate_stairs', 'polished_deepslate_stairs', 'deepslate_brick_stairs', 'deepslate_tile_stairs',
+ 'cut_copper_stairs', 'exposed_cut_copper_stairs', 'weathered_cut_copper_stairs', 'oxidized_cut_copper_stairs',
+ 'waxed_cut_copper_stairs', 'waxed_exposed_cut_copper_stairs', 'waxed_weathered_cut_copper_stairs',
+ 'waxed_oxidized_cut_copper_stairs', 'cobbled_deepslate_slab', 'polished_deepslate_slab', 'deepslate_brick_slab',
+ 'deepslate_tile_slab', 'cut_copper_slab', 'exposed_cut_copper_slab', 'weathered_cut_copper_slab', 'oxidized_cut_copper_slab',
+ 'waxed_cut_copper_slab', 'waxed_exposed_cut_copper_slab', 'waxed_weathered_cut_copper_slab', 'waxed_oxidized_cut_copper_slab',
+ 'copper_block', 'exposed_copper', 'weathered_copper', 'oxidized_copper', 'cut_copper', 'exposed_cut_copper',
+ 'weathered_cut_copper', 'oxidized_cut_copper', 'waxed_copper_block', 'waxed_exposed_copper', 'waxed_weathered_copper',
+ 'waxed_oxidized_copper', 'waxed_cut_copper', 'waxed_exposed_cut_copper', 'waxed_weathered_cut_copper', 'waxed_oxidized_cut_copper',
+ 'copper_ore', 'tinted_glass', 'smooth_basalt', 'calcite', 'amethyst_block', 'budding_amethyst', 'amethyst_cluster',
+ 'small_amethyst_bud', 'medium_amethyst_bud', 'large_amethyst_bud', 'amethyst_cluster', 'tuff', 'white_candle', 'orange_candle',
+ 'magenta_candle', 'light_blue_candle', 'yellow_candle', 'lime_candle', 'pink_candle', 'gray_candle', 'light_gray_candle',
+ 'cyan_candle', 'purple_candle', 'blue_candle', 'brown_candle', 'green_candle', 'red_candle', 'black_candle'
+];
+__restore(pl, s_player) ->(
+ scoreboard_remove('killCounter');
+ scoreboard_remove('digCounter');
+ scoreboard_remove('deathCounter');
+ scoreboard_remove('tradingCounter');
+ scoreboard_remove('fishingCounter');
+ scoreboard_remove('damageTaken');
+ scoreboard_remove('activation');
+ scoreboard_remove('totalList');
+ scoreboard_add('killCounter');
+ scoreboard_add('digCounter');
+ scoreboard_add('deathCounter');
+ scoreboard_add('tradingCounter');
+ scoreboard_add('fishingCounter');
+ scoreboard_add('damageTaken');
+ scoreboard_add('activation');
+ scoreboard_add('totalList');
+ total_actime = 0;
+ total_death = 0;
+ total_mined = 0;
+ total_fished = 0;
+ total_killed = 0;
+ total_traded = 0;
+ total_hurt = 0;
+ c_for(i = 0, i < length(pl), i += 1,
+ run('player ' + pl:i + ' spawn');
+ game_tick(50);
+ //活跃时间
+ actime = statistic(pl:i, 'custom', 'play_one_minute')/72000;
+ print(actime);
+ scoreboard('activation', pl:i, actime);
+ total_actime += actime;
+ //抖M榜
+ hurt = statistic(pl:i, 'custom', 'damage_taken')/100;
+ print(hurt);
+ scoreboard('damageTaken', pl:i, hurt);
+ total_hurt += hurt;
+ //死亡榜
+ death = statistic(pl:i, 'custom', 'deaths');
+ print(death);
+ scoreboard('deathCounter', pl:i, death);
+ total_death += death;
+ //挖掘榜
+ mined = 0;
+ c_for(j = 0, j < length(global_bl), j += 1,
+ mined += statistic(pl:i, 'mined', global_bl:j);
+ );
+ print(mined);
+ scoreboard('digCounter', pl:i, mined);
+ total_mined += mined;
+ //钓鱼榜
+ fished = statistic(pl:i, 'custom', 'fish_caught');
+ print(fished);
+ scoreboard('fishingCounter', pl:i, fished);
+ total_fished += fished;
+ //击杀榜
+ killed = statistic(pl:i, 'custom', 'mob_kills');
+ killed += statistic(pl:i, 'custom', 'player_kills');
+ print(killed);
+ scoreboard('killCounter', pl:i, killed);
+ total_killed += killed;
+ //交易榜
+ traded = statistic(pl:i, 'custom', 'traded_with_villager');
+ print(traded);
+ scoreboard('tradingCounter', pl:i, traded);
+ total_traded += traded;
+ run('player ' + pl:i + ' kill')
+ );
+ scoreboard('tradingCounter', '总交♂易数', total_traded);
+ scoreboard('totalList', '总交♂易数', total_traded);
+ scoreboard('killCounter', '总击杀数', total_killed);
+ scoreboard('totalList', '总击杀数', total_killed);
+ scoreboard('fishingCounter', '总钓鱼数', total_fished);
+ scoreboard('totalList', '总钓鱼数', total_fished);
+ scoreboard('digCounter', '总挖掘量', total_mined);
+ scoreboard('totalList', '总挖掘量', total_mined);
+ scoreboard('deathCounter', '全部木大', total_death);
+ scoreboard('totalList', '全部木大', total_death);
+ scoreboard('activation', '总在线时间(h)', total_actime);
+ scoreboard('totalList', '总在线时间(h)', total_actime);
+ scoreboard('damageTaken', '群p抖M', total_hurt);
+ scoreboard('totalList', '群p抖M', total_hurt);
+ game_tick(50);
+ print('完成!');
+ run('function fz:scoreboards/install')
+);
+by_whitelist() ->(
+ pl = keys(system_info('server_whitelist'));
+ s_player = player();
+ game_tick(50);
+ __restore(pl, s_player);
+ return()
+)
\ No newline at end of file
diff --git a/s.sc b/s.sc
new file mode 100644
index 0000000..eda9e40
--- /dev/null
+++ b/s.sc
@@ -0,0 +1,6 @@
+__config() -> {
+ 'stay_loaded' -> true
+};
+__command() -> (
+ run('gamemode survival')
+)
\ No newline at end of file
diff --git a/tagplayer.sc b/tagplayer.sc
new file mode 100644
index 0000000..27502b2
--- /dev/null
+++ b/tagplayer.sc
@@ -0,0 +1,1286 @@
+//*************************************************************
+//************请将该文件放入"world\scripts"文件夹中************
+//*************可以自定义插件名,但不能为“player”**************
+//*************************************************************
+__on_start() -> (
+ if(scoreboard_add('carpetBot') == null,
+ scoreboard_property('carpetBot', 'criterion', 'dummy');
+ );
+ team_add('carpetBot');
+ team_add('shadowedPlayer');
+ team_property('carpetBot', 'prefix', '假的');
+ team_property('shadowedPlayer', 'prefix', '挂机');
+ global_version = '2.4.0';
+ global_carpet_version = split('\\+v',system_info('scarpet_version'));
+ global_require_carpet_version = ['1.4.30', 210331];
+ global_filename = system_info('app_name');
+ run('data merge storage minecraft:fz.tagplayer {filename:"' + global_filename + '"}');
+ run('carpet setDefault commandPlayer ops');
+ reload();
+ run(str('tellraw @a {"text": "[版本信息]' + global_filename + '版本: ' + global_version + '", "color": "#ffd900"}'));
+ run(str('tellraw @a {"text": "[版本信息]carpet版本: ' + global_carpet_version:0 + '", "color": "#ffd900"}'));
+ if(number(global_carpet_version:1) < global_require_carpet_version:1 || global_carpet_version == null,
+ run(str('tellraw @a {"text": "[错误]' + global_filename + '需要地毯' + global_require_carpet_version:0 + '或以上来运行!否则会出现预期之外的问题", "color": "#ff6100"}'));
+ );
+);
+__config() -> {
+ 'scope' -> 'global',
+ 'stay_loaded' -> true,
+ 'allow_command_conflicts' -> true,
+ 'commands' -> {
+ '' -> 'help',
+ ' ' -> 'tp',
+ ' ' -> 'tp_with_rotation',
+ ' ' -> 'tp_to_player',
+ ' atBot' -> 'tp_at_bot',
+ ' atBot' -> 'tp_at_bot_with_rotation',
+ 'spawn ' -> ['summon',null,null,null],
+ 'spawn at ' -> ['summon',null,null],
+ 'spawn at facing ' -> ['summon',null],
+ 'spawn at facing in ' -> 'summon',
+ 'kill ' -> 'kill',
+ 'killall' -> 'killall',
+ 'attack ' -> 'attack_once',
+ 'attack continuous' -> 'attack_continuous',
+ 'attack interval ' -> 'attack_interval',
+ 'attack once' -> 'attack_once',
+ 'drop all' -> 'drop_all',
+ 'drop ' -> 'drop_once',
+ 'drop continuous' -> 'drop_continuous',
+ 'drop interval ' -> 'drop_interval',
+ 'drop mainhand' -> 'drop_mainhand',
+ 'drop offhand' -> 'drop_offhand',
+ 'drop once' -> 'drop_once',
+ 'dropStack all' -> 'drop_stack_all',
+ 'dropStack ' -> 'drop_stack_once',
+ 'dropStack continuous' -> 'drop_stack_continuous',
+ 'dropStack interval ' -> 'drop_stack_interval',
+ 'dropStack mainhand' -> 'drop_stack_mainhand',
+ 'dropStack offhand' -> 'drop_stack_offhand',
+ 'dropStack once' -> 'drop_stack_once',
+ 'jump ' -> 'jump_once',
+ 'jump continuous' -> 'jump_continuous',
+ 'jump interval ' -> 'jump_interval',
+ 'jump once' -> 'jump_once',
+ 'swapHands ' -> 'swap_hands_once',
+ 'swapHands continuous' -> 'swap_hands_continuous',
+ 'swapHands interval ' -> 'swap_hands_interval',
+ 'swapHands once' -> 'swap_hands_once',
+ 'use ' -> 'use_once',
+ 'use continuous' -> 'use_continuous',
+ 'use interval ' -> 'use_interval',
+ 'use once' -> 'use_once',
+ 'mount ' -> 'mount',
+ 'dismount ' -> 'dismount',
+ 'sprint ' -> 'sprint',
+ 'unsprint ' -> 'unsprint',
+ 'sneak ' -> 'sneak',
+ 'unsneak ' -> 'unsneak',
+ 'look back' -> 'turn_back',
+ 'look left' -> 'turn_left',
+ 'look right' -> 'turn_right',
+ 'look up' -> 'look_up',
+ 'look down' -> 'look_down',
+ 'look east' -> 'look_east',
+ 'look north' -> 'look_north',
+ 'look south' -> 'look_south',
+ 'look west' -> 'look_west',
+ 'look ' -> 'look',
+ 'look position ' -> 'look_pos',
+ 'move backward' -> 'move_backward',
+ 'move forward' -> 'move_forward',
+ 'move left' -> 'move_left',
+ 'move right' -> 'move_right',
+ 'move stop' -> 'move_stop',
+ 'stop ' -> 'stop',
+ 'check ' -> 'check',
+ 'checkall' -> 'checkall',
+ 'hotbar ' -> 'hotbar',
+ 'shadow' -> 'shadow',
+ 'reload' -> 'reload'
+ },
+ 'arguments' -> {
+ 'tp' -> {
+ 'type' -> 'term',
+ 'suggester' -> _(args) -> (
+ if(global_config:'allow_bot_tp' == 'true',
+ return(['tp']);
+ ,(return(null));
+ );
+ );
+ },
+ 'dimension' -> {
+ 'type' -> 'term',
+ 'suggest' -> ['overworld','the_nether','the_end']
+ },
+ 'hotbar' -> {
+ 'type' -> 'int',
+ 'min' -> 1,
+ 'max' -> 9,
+ 'suggest' -> [1,2,3,4,5,6,7,8,9]
+ },
+ 'bot' -> {
+ 'type' -> 'term',
+ 'suggester' -> _(args) -> (
+ player_list = player('all');
+ bot_list = l();
+ c_for(i = 0, i < length(player_list), i += 1,
+ one_player_str = player_list:i;
+ if (scoreboard('carpetBot', one_player_str) == 1,
+ put(bot_list, length(bot_list), player_list:i)
+ );
+ );
+ put(bot_list, length(bot_list), player());
+ return(bot_list);
+ );
+ },
+ 'killbot' -> {
+ 'type' -> 'term',
+ 'suggester' -> _(args) -> (
+ player_list = player('all');
+ bot_list = l();
+ c_for(i = 0, i < length(player_list), i += 1,
+ one_player_str = player_list:i;
+ if (scoreboard('carpetBot', one_player_str) == 1,
+ put(bot_list, length(bot_list), player_list:i)
+ );
+ );
+ return(bot_list);
+ );
+ },
+ 'player' -> {
+ 'type' -> 'term',
+ 'suggester' -> _(args) -> player('all')
+ },
+ 'tick' -> {
+ 'type' -> 'int',
+ 'min' -> 1,
+ 'suggest' -> []
+ },
+ 'rotation' -> {
+ 'type' -> 'rotation'
+ },
+ 'position' -> {
+ 'type' -> 'location'
+ };
+ };
+};
+__on_player_disconnects(player, reason) ->(
+ delete_all_files(player);
+ if(scoreboard('carpetBot', player) == 1,
+ scoreboard_remove('actimeCounter', player);
+ scoreboard_remove('carpetBot', player);
+ team_leave(player);
+ leaveGame = scoreboard('leaveGame', player);
+ scoreboard('leaveGame', player, leaveGame + 1);
+ );
+);
+__on_player_connects(player) -> (
+ run('tellraw ' + player + ' {"text":"[提醒]输入“/' + global_filename + '”查看假人相关功能的帮助", "color":"#66ffff"}');
+);
+__on_server_shuts_down() ->(
+ player_list = player('all');
+ c_for(i = 0, i < length(player_list), i += 1,
+ delete_all_files(player_list:i);
+ if(scoreboard('carpetBot', player) == 1,
+ scoreboard_remove('actimeCounter', player_list:i);
+ team_leave(player);
+ );
+ );
+ scoreboard_remove('carpetBot');
+ team_remove('carpetBot');
+ team_remove('shadowedPlayer');
+);
+check_fakeplayer(player_name) ->(
+ f_player = player(player_name);
+ if (!f_player,
+ (
+ print('§4假人'+player_name+'未在线');
+ exit();
+ ),
+ scoreboard('carpetBot', f_player) != 1 || f_player == player(),
+ (
+ print('§4'+f_player+'不是假人');
+ exit();
+ );
+ );
+);
+check_offline(player_name) ->(
+ f_player = player(player_name);
+ if (!f_player,
+ print('§4玩家或假人'+player_name+'未在线');
+ exit();
+ );
+);
+check_online(player_name) ->(
+ if (global_config:'allow_spawning_whitelist_players' == 'false',
+ wl = keys(system_info('server_whitelist'));
+ c_for(i = 0, i < length(wl), i += 1,
+ if (lower(wl:i) == lower(player_name),
+ print('§4'+player_name+'是白名单玩家');
+ exit()
+ );
+ );
+ );
+ f_player = player(player_name);
+ if (f_player,
+ if (scoreboard('carpetBot', f_player) == 1,
+ print('§4假人'+f_player+'已经在线了');
+ exit();
+ );
+ print('§4玩家'+f_player+'已经在线了');
+ exit();
+ );
+);
+check_pos(x) ->(
+ x = number(x);
+ if(x == null,
+ print('§4请输入正确的坐标');
+ exit();
+ );
+ return(x);
+);
+check_dim(s_player,f_player) ->(
+ if (s_player~'dimension' != f_player~'dimension',
+ print('§4不在同一维度!');
+ exit();
+ );
+);
+delete_all_files(f_player) ->(
+ delete_file(f_player + '-' + 'attack', 'text');
+ delete_file(f_player + '-' + 'drop', 'text');
+ delete_file(f_player + '-' + 'drop_stack', 'text');
+ delete_file(f_player + '-' + 'jump', 'text');
+ delete_file(f_player + '-' + 'swap_hands', 'text');
+ delete_file(f_player + '-' + 'use', 'text');
+ delete_file(f_player + '-' + 'move_vertical', 'text');
+ delete_file(f_player + '-' + 'move_transverse', 'text');
+);
+reload() -> (
+ config = read_file('config/config', 'json');
+ global_config = m();
+ if (config == null,
+ (
+ global_config = {
+ 'allow_spawning_whitelist_players' -> 'true',
+ 'allow_bot_tp' -> 'true'
+ };
+ ),
+ if (config:'allow_spawning_whitelist_players' == null ||
+ (
+ config:'allow_spawning_whitelist_players' != 'true' &&
+ config:'allow_spawning_whitelist_players' != 'false'
+ ),
+ (
+ global_config:'allow_spawning_whitelist_players' = 'true'
+ ),
+ global_config:'allow_spawning_whitelist_players' = config:'allow_spawning_whitelist_players';
+ );
+ if (config:'allow_bot_tp' == null || (config:'allow_bot_tp' != 'true' && config:'allow_bot_tp' != 'false'),
+ (
+ global_config:'allow_bot_tp' = 'true'
+ ),
+ global_config:'allow_bot_tp' = config:'allow_bot_tp';
+ );
+ );
+ logger(global_config:'allow_spawning_whitelist_players');
+ logger(global_config:'allow_bot_tp');
+ delete_file('config/config', 'json');
+ write_file('config/config', 'json', global_config);
+ print('配置文件重载成功!');
+);
+help() ->(
+ print('--使用帮助:');
+ print('/' + global_filename + ' spawn <玩家名> (at facing <仰俯> <偏转> in )\n - 生成假人可选“at”、“facing”、“in”参数');
+ print('/' + global_filename + ' kill <玩家名>\n - 删除假人');
+ print('/' + global_filename + ' killall\n - 删除全部假人');
+ print('/' + global_filename + ' tp <玩家名> (<仰俯> <偏转>) (atBot)\n - 传送假人到,,,可选<仰俯>和<偏转>角度,如以结尾则相对坐标以假人为原点');
+ print('/' + global_filename + ' look <玩家名> <仰俯> <偏转>\n - 转动假人视角,、可替换为“s”来代表你的视角方向');
+ print('/' + global_filename + ' look <玩家名> \n - 让假人向<上/下/东/西/南/北>方向看');
+ print('/' + global_filename + ' look <玩家名> \n - 让假人向<后/左/右>方向看');
+ print('/' + global_filename + ' move <玩家名> \n - 让假人<向前/向后/向左/向右>移动');
+ print('/' + global_filename + ' <玩家名> continuous\n - 让假人持续<攻击或挖掘/丢一个物品/丢一组物品/跳跃/换手/使用物品>');
+ print('/' + global_filename + ' <玩家名> interval <整数>\n - 让假人每<整数>游戏刻<攻击/丢一个物品/丢一组物品/跳跃/换手/使用物品>一次');
+ print('/' + global_filename + ' <玩家名> once\n - 让假人<攻击或挖掘/丢一个物品/丢一组物品/跳跃/换手/使用物品>一次');
+ print('/' + global_filename + ' <玩家名> <1-9>\n - 更改假人使用的热键栏');
+ print('/' + global_filename + ' <玩家名> \n - 让假人<丢一个/丢一组><主手/副手>的物品');
+ print('/' + global_filename + ' <玩家名>\n - 让假人<潜行/站立>');
+ print('/' + global_filename + ' <玩家名>\n - 让假人准备<疾跑/行走>,在水中疾跑以游泳');
+ print('/' + global_filename + ' <玩家名>\n - 让假人<乘坐/卸下>');
+ print('/' + global_filename + ' stop <玩家名>\n - 停止假人的一切动作');
+ print('/' + global_filename + ' check <玩家名>\n - 检查假人状态');
+ print('/' + global_filename + ' checkall\n - 检查所有假人状态');
+ print('' + global_filename + '版本: ' + global_version);
+ print('carpet版本: ' + global_carpet_version:0);
+ if(number(global_carpet_version:1) < global_require_carpet_version:1 || global_carpet_version == null,
+ print('§4' + global_filename + '需要地毯' + global_require_carpet_version:0 + '或以上来运行!否则会出现预期之外的问题')
+ );
+ return();
+);
+summon(player_name, position, rotation, dimension) ->(
+ if(length(player_name) > 16,
+ player_name = slice(player_name,0,15);
+ );
+ check_online(player_name);
+ s_player = player();
+ if(position == null,
+ position = query(s_player, 'pos');
+ );
+ if(rotation == null,
+ rotation = l(query(s_player, 'yaw'), query(s_player, 'pitch'));
+ );
+ if(dimension == null,
+ dimension = query(s_player, 'dimension');
+ );
+ run(
+ str('player %s spawn at %f %f %f facing %f %f in %s',
+ player_name, position:0, position:1, position:2, rotation:0, rotation:1, dimension
+ );
+ );
+ f_player = player(player_name);
+ if (!f_player,
+ print('§4生成失败');
+ return();
+ );
+ delete_all_files(f_player);
+ team_add('carpetBot', f_player);
+ run('tellraw @a {"text":"↑假的"}');
+ scoreboard('carpetBot', f_player, 1);
+ return();
+);
+kill(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ if(f_player != player(),
+ (
+ run('tellraw @a {"text":"↓假的"}');
+ run(str('player %s kill', f_player));
+ ),
+ print('§4你不是假人');
+ );
+ return();
+);
+killall() ->(
+ player_list = team_list('carpetBot');
+ c_for(i = 0, i < length(player_list), i += 1,
+ run(str('player %s kill', player_list:i));
+ );
+ if(player_list == l(),
+ print('§4不存在假人');
+ return();
+ );
+ game_tick(50);
+ run('tellraw @a {"text":"已清除全部假人"}');
+ return();
+);
+//挂机
+shadow() ->(
+ f_player = player();
+ run(str('player %s shadow', f_player));
+ scoreboard('carpetBot', f_player, 1);
+ team_add('shadowedPlayer', f_player);
+ return();
+);
+//热键栏
+hotbar(player_name, hotbar) ->(
+ run(str('player %s hotbar %d', player_name, hotbar));
+ return();
+);
+//攻击
+attack_continuous(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s attack continuous', player_name));
+ delete_file(f_player + '-' + 'attack', 'text');
+ write_file(f_player + '-' + 'attack', 'text', 0);
+ return();
+);
+attack_interval(player_name,tick) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s attack interval %d', player_name, tick));
+ delete_file(f_player + '-' + 'attack', 'text');
+ write_file(f_player + '-' + 'attack', 'text', tick);
+ return();
+);
+attack_once(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s attack once', player_name));
+ delete_file(f_player + '-' + 'attack', 'text');
+ return();
+);
+attack_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s attack', player_name));
+ delete_file(f_player + '-' + 'attack', 'text');
+ return();
+);
+//丢弃
+drop_continuous(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s drop continuous', player_name));
+ delete_file(f_player + '-' + 'drop', 'text');
+ write_file(f_player + '-' + 'drop', 'text', 0);
+ return();
+);
+drop_interval(player_name,tick) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s drop interval %d', player_name, tick));
+ delete_file(f_player + '-' + 'drop', 'text');
+ write_file(f_player + '-' + 'drop', 'text', tick);
+ return();
+);
+drop_once(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s drop once', player_name));
+ delete_file(f_player + '-' + 'drop', 'text');
+ return();
+);
+drop_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s drop', player_name));
+ delete_file(f_player + '-' + 'drop', 'text');
+ return();
+);
+drop_all(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s drop all', player_name));
+ return();
+);
+drop_offhand(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ return();
+);
+drop_mainhand(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s drop mainhand', player_name));
+ return();
+);
+//丢弃一组
+drop_stack_continuous(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack continuous', player_name));
+ delete_file(f_player + '-' + 'drop_stack', 'text');
+ write_file(f_player + '-' + 'drop_stack', 'text', 0);
+ return();
+);
+drop_stack_interval(player_name,tick) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack interval %d', player_name, tick));
+ delete_file(f_player + '-' + 'drop_stack', 'text');
+ write_file(f_player + '-' + 'drop_stack', 'text', tick);
+ return();
+);
+drop_stack_once(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack once', player_name));
+ delete_file(f_player + '-' + 'drop_stack', 'text');
+ return();
+);
+drop_stack_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack', player_name));
+ delete_file(f_player + '-' + 'drop_stack', 'text');
+ return();
+);
+drop_stack_all(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack all', player_name));
+ return();
+);
+drop_stack_offhand(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack offhand', player_name));
+ return();
+);
+drop_stack_mainhand(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dropStack mainhand', player_name));
+ return();
+);
+//跳跃
+jump_continuous(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s jump continuous', player_name));
+ delete_file(f_player + '-' + 'jump', 'text');
+ write_file(f_player + '-' + 'jump', 'text', 0);
+ return();
+);
+jump_interval(player_name,tick) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s jump interval %d', player_name, tick));
+ delete_file(f_player + '-' + 'jump', 'text');
+ write_file(f_player + '-' + 'jump', 'text', tick);
+ return();
+);
+jump_once(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s jump once', player_name));
+ delete_file(f_player + '-' + 'jump', 'text');
+ return();
+);
+jump_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s jump', player_name));
+ delete_file(f_player + '-' + 'jump', 'text');
+ return();
+);
+//换手
+swap_hands_continuous(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s swapHands continuous', player_name));
+ delete_file(f_player + '-' + 'swap_hands', 'text');
+ write_file(f_player + '-' + 'swap_hands', 'text', 0);
+ return();
+);
+swap_hands_interval(player_name,tick) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s swapHands interval %d', player_name, tick));
+ delete_file(f_player + '-' + 'swap_hands', 'text');
+ write_file(f_player + '-' + 'swap_hands', 'text', tick);
+ return();
+);
+swap_hands_once(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s swapHands once', player_name));
+ delete_file(f_player + '-' + 'swap_hands', 'text');
+ return();
+);
+swap_hands_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s swapHands', player_name));
+ delete_file(f_player + '-' + 'swap_hands', 'text');
+ return();
+);
+//右键
+use_continuous(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s use continuous', player_name));
+ delete_file(f_player + '-' + 'use', 'text');
+ write_file(f_player + '-' + 'use', 'text', 0);
+ return();
+);
+use_interval(player_name,tick) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s use interval %d', player_name, tick));
+ delete_file(f_player + '-' + 'use', 'text');
+ write_file(f_player + '-' + 'use', 'text', tick);
+ return();
+);
+use_once(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s use once', player_name));
+ delete_file(f_player + '-' + 'use', 'text');
+ return();
+);
+use_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s use', player_name));
+ delete_file(f_player + '-' + 'use', 'text');
+ return();
+);
+//骑乘
+mount(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s mount', player_name));
+ return();
+);
+dismount(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s dismount', player_name));
+ return();
+);
+//冲刺
+sprint(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s sprint', player_name));
+ write_file(f_player + '-' + 'sprint', 'text', tick);
+ return();
+);
+unsprint(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s unsprint', player_name));
+ delete_file(f_player + '-' + 'sprint', 'text');
+ return();
+);
+//下蹲
+sneak(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s sneak', player_name));
+ write_file(f_player + '-' + 'sneak', 'text', tick);
+ return();
+);
+unsneak(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s unsneak', player_name));
+ delete_file(f_player + '-' + 'sneak', 'text');
+ return();
+);
+//转向
+turn_back(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s turn back', player_name));
+ return();
+);
+turn_left(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s turn left', player_name));
+ return();
+);
+turn_right(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s turn right', player_name));
+ return();
+);
+//看向
+look(player_name,rotation) ->(
+ print(rotation);
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ s_player = player();
+ x = (rotation:1)%360;
+ y = (rotation:0)%180;
+ if(x > 180,
+ x = x - 360
+ );
+ if(x < -180,
+ x = x + 360
+ );
+ if(y > 90,
+ y = y - 180
+ );
+ if(y < -90,
+ y = y + 180
+ );
+ modify(player(player_name), 'yaw', x);
+ modify(player(player_name), 'pitch', y);
+ print(str('已将'+player_name+'的视角指向§a[%.1f,%.1f]',x,y));
+ return();
+);
+look_up(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look up', player_name));
+ return();
+);
+look_down(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look down', player_name));
+ return();
+);
+look_east(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look east', player_name));
+ return();
+);
+look_north(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look north', player_name));
+ return();
+);
+look_south(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look south', player_name));
+ return();
+);
+look_west(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look west', player_name));
+ return();
+);
+look_pos(player_name, position) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s look at %f %f %f', player_name, position:0, position:1, position:2));
+ return();
+);
+//移动
+move_backward(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s move backward', player_name));
+ delete_file(f_player + '-' + 'move_vertical', 'text');
+ write_file(f_player + '-' + 'move_vertical', 'text', 'backward');
+ return();
+);
+move_forward(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s move forward', player_name));
+ delete_file(f_player + '-' + 'move_vertical', 'text');
+ write_file(f_player + '-' + 'move_vertical', 'text', 'forward');
+ return();
+);
+move_left(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s move left', player_name));
+ delete_file(f_player + '-' + 'move_transverse', 'text');
+ write_file(f_player + '-' + 'move_transverse', 'text', 'left');
+ return();
+);
+move_right(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s move right', player_name));
+ delete_file(f_player + '-' + 'move_transverse', 'text');
+ write_file(f_player + '-' + 'move_transverse', 'text', 'right');
+ return();
+);
+move_stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s move', player_name));
+ delete_file(f_player + '-' + 'move_vertical', 'text');
+ delete_file(f_player + '-' + 'move_transverse', 'text');
+ return();
+);
+//停止
+stop(player_name) ->(
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ run(str('player %s stop', player_name));
+ delete_all_files(f_player);
+ return();
+);
+//传送
+tp(tp, player_name, position) ->(
+ if(global_config:'allow_bot_tp' == true,
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ s_player = player();
+ x = position:0;
+ y = position:1;
+ if(y>4096 || y<-4096,
+ print('§4y值不能超过±4096!');
+ return();
+ );
+ z = position:2;
+ print(s_player~'yaw'+'|'+s_player~'pitch');
+ run(str('tp %s %f %f %f %f %f', f_player, x, y, z, s_player~'yaw', s_player~'pitch'));
+ print(str('已将'+player_name+'传送至§a[%.2f,%.2f,%.2f]',x,y,z));
+ );
+ return();
+);
+tp_with_rotation(tp, player_name, position, rotation) ->(
+ if(global_config:'allow_bot_tp' == true,
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ s_player = player();
+ f_player = player(player_name);
+ x = position:0;
+ y = position:1;
+ if(y>4096 || y<-4096,
+ print('§4y值不能超过±4096!');
+ return();
+ );
+ z = position:2;
+ yaw = (rotation:1)%360;
+ pitch = (rotation:0)%180;
+ if(yaw > 180,
+ yaw = yaw - 360
+ );
+ if(yaw < -180,
+ yaw = yaw + 360
+ );
+ if(pitch > 90,
+ pitch = pitch - 180
+ );
+ if(pitch < -90,
+ pitch = pitch + 180
+ );
+ run(str('tp %s %f %f %f %f %f', f_player, x, y, z, yaw, pitch));
+ print(str('已将'+player_name+'传送至§a[%.2f,%.2f,%.2f]',x,y,z));
+ );
+ return();
+);
+tp_to_player(tp, player_name, target_name) ->(
+ if(global_config:'allow_bot_tp' == true,
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ s_player = player(target_name);
+ if (!s_player,
+ print('§4玩家未在线');
+ return();
+ );
+ run(str('tp %s %s', f_player, s_player));
+ print(str('已将'+player_name+'传送至'+s_player));
+ );
+ return();
+);
+tp_at_bot(tp, player_name, position) ->(
+ if(global_config:'allow_bot_tp' == true,
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ s_player = player();
+ x = position:0;
+ y = position:1;
+ if(y>4096 || y<-4096,
+ print('§4y值不能超过±4096!');
+ return();
+ );
+ z = position:2;
+ print(s_player~'yaw'+'|'+s_player~'pitch');
+ run(str('execute at %s run tp %s %f %f %f', f_player, x, y, z));
+ print(str('已将'+player_name+'传送至§a[%.2f,%.2f,%.2f]',x,y,z));
+ );
+ return();
+);
+tp_at_bot_with_rotation(tp, player_name, position, rotation) ->(
+ if(global_config:'allow_bot_tp' == true,
+ f_player = player(player_name);
+ check_fakeplayer(player_name);
+ s_player = player();
+ f_player = player(player_name);
+ x = position:0;
+ y = position:1;
+ if(y>4096 || y<-4096,
+ print('§4y值不能超过±4096!');
+ return();
+ );
+ z = position:2;
+ yaw = (rotation:1)%360;
+ pitch = (rotation:0)%180;
+ if(yaw > 180,
+ yaw = yaw - 360
+ );
+ if(yaw < -180,
+ yaw = yaw + 360
+ );
+ if(pitch > 90,
+ pitch = pitch - 180
+ );
+ if(pitch < -90,
+ pitch = pitch + 180
+ );
+ run(str('execute at %s run tp %s %f %f %f %f %f', f_player, f_player, x, y, z, yaw, pitch));
+ print(str('已将'+player_name+'传送至§a[%.2f,%.2f,%.2f]',x,y,z));
+ );
+ return();
+);
+//状态检查
+check(player_name) ->(
+ check_offline(player_name);
+ f_player = player(player_name);
+ if(scoreboard('carpetBot', f_player) == 1,
+ (
+ print('假人“'+f_player+'”:');
+ ),
+ print('玩家“'+f_player+'”:');
+ );
+ //血量
+ inner_health = number(str('%d',query(f_player,'health')+0.9));
+ if(inner_health <= 5,
+ inner_color = '§4';
+ );
+ if(inner_health > 5 && inner_health <= 10,
+ inner_color = '§c';
+ );
+ if(inner_health > 10 && inner_health <= 15,
+ inner_color = '§e';
+ );
+ if(inner_health > 15,
+ inner_color = '§a';
+ );
+ print('- 血量:'+inner_color+inner_health);
+ //位置
+ if(f_player~'dimension' == 'overworld',
+ f_dimension = '§2主世界'
+ );
+ if(f_player~'dimension' == 'the_nether',
+ f_dimension = '§4地狱'
+ );
+ if(f_player~'dimension' == 'the_end',
+ f_dimension = '§7末地'
+ );
+ print(str('- 位于:%s§a[%.2f,%.2f,%.2f]',f_dimension,f_player~'x',f_player~'y',f_player~'z'));
+ //指向
+ f_yaw = f_player~'yaw';
+ if(f_yaw > 180,
+ f_yaw = f_yaw - 360
+ );
+ if(f_yaw < -180,
+ f_yaw = f_yaw + 360
+ );
+ if(f_yaw > -112.5 && f_yaw <= -67.5,
+ f_yaw_curt = '东'
+ );
+ if(f_yaw > -22.5 && f_yaw <= 22.5,
+ f_yaw_curt = '南'
+ );
+ if(f_yaw > 67.5 && f_yaw <= 112.5,
+ f_yaw_curt = '西'
+ );
+ if(f_yaw > 157.5 || f_yaw <= -157.5,
+ f_yaw_curt = '北'
+ );
+ if(f_yaw > -157.5 && f_yaw <= -112.5,
+ f_yaw_curt = '东北'
+ );
+ if(f_yaw > -67.5 && f_yaw <= -22.5,
+ f_yaw_curt = '东南'
+ );
+ if(f_yaw > 112.5 && f_yaw <= 157.5,
+ f_yaw_curt = '西北'
+ );
+ if(f_yaw > 22.5 && f_yaw <= 67.5,
+ f_yaw_curt = '西南'
+ );
+ f_pitch = f_player~'pitch';
+ if(f_pitch > -15 && f_pitch <= 15,
+ f_pitch_curt = '前方'
+ );
+ if(f_pitch > 15 && f_pitch <= 75,
+ f_pitch_curt = '斜下方'
+ );
+ if(f_pitch > 75 && f_pitch <= 90,
+ f_pitch_curt = '下方'
+ );
+ if(f_pitch > -75 && f_pitch <= -15,
+ f_pitch_curt = '斜上方'
+ );
+ if(f_pitch >= -90 && f_pitch <= -75,
+ f_pitch_curt = '上方'
+ );
+ print(str('- 指向:§e%s,%s§a[%.1f,%.1f]',f_yaw_curt,f_pitch_curt,f_yaw,f_pitch));
+ f_state = global_bot_state:f_player;
+ //潜行/疾跑/游泳
+ inner_sneak = query(f_player,'sneaking');
+ inner_sprint = query(f_player,'sprinting');
+ inner_swim = query(f_player,'swimming');
+//***************************************************
+ noAct = true;
+ //攻击/挖掘
+ inner_attack = read_file(f_player + '-' + 'attack', 'text'):0;
+ if(inner_attack != null,
+ if(inner_attack == 0,
+ print('- 正在挖掘');
+ noAct = false
+ );
+ if(inner_attack > 0,
+ inner_sec = inner_attack/20;
+ print('- 每' + inner_attack + '游戏刻(' + inner_sec + '游戏秒)尝试攻击一次');
+ noAct = false
+ );
+ );
+ //扔东西
+ inner_drop = read_file(f_player + '-' + 'drop', 'text'):0;
+ if(inner_drop != null,
+ if(inner_drop == 0,
+ print('- 正在持续每次扔一个物品');
+ noAct = false
+ );
+ if(inner_drop > 0,
+ inner_sec = inner_drop/20;
+ print('- 每' + inner_drop + '游戏刻(' + inner_sec + '游戏秒)扔1个物品');
+ noAct = false
+ );
+ );
+ inner_drop_stack = read_file(f_player + '-' + 'drop_stack', 'text'):0;
+ if(inner_drop_stack != null,
+ if(inner_drop_stack == 0,
+ print('- 正在持续每次扔一组物品');
+ noAct = false
+ );
+ if(inner_drop > 0,
+ inner_sec = inner_drop_stack/20;
+ print('- 每' + inner_drop_stack + '游戏刻(' + inner_sec + '游戏秒)扔1个物品');
+ noAct = false
+ );
+ );
+ //跳跃
+ inner_jump = read_file(f_player + '-' + 'jump', 'text'):0;
+ if(inner_jump != null,
+ if(inner_jump == 0,
+ print('- 正在持续跳跃');
+ noAct = false
+ );
+ if(inner_jump > 0,
+ inner_sec = inner_jump/20;
+ print('- 每' + inner_jump + '游戏刻(' + inner_sec + '游戏秒)尝试跳跃一次');
+ noAct = false
+ );
+ );
+ //换手
+ inner_swap_hands = read_file(f_player + '-' + 'swap_hands', 'text'):0;
+ if(inner_swap_hands != null,
+ if(inner_swap_hands == 0,
+ print('- 正在持续交换左右手的物品');
+ noAct = false
+ );
+ if(inner_swap_hands > 0,
+ inner_sec = inner_swap_hands/20;
+ print('- 每' + inner_swap_hands + '游戏刻(' + inner_sec + '游戏秒)交换一次左右手的物品');
+ noAct = false
+ );
+ );
+ //使用物品
+ inner_use = read_file(f_player + '-' + 'use', 'text'):0;
+ if(inner_use != null,
+ if(inner_use == 0,
+ print('- 正在持续使♂用物品');
+ noAct = false
+ );
+ if(inner_use > 0,
+ inner_sec = inner_use/20;
+ print('- 每' + inner_use + '游戏刻(' + inner_sec + '游戏秒)尝试使用一次物♂品');
+ noAct = false
+ );
+ );
+ //移动**********************************重点*********************************
+ inner_move_vertical = read_file(f_player + '-' + 'move_vertical', 'text'):0;
+ inner_move_transverse = read_file(f_player + '-' + 'move_transverse', 'text'):0;
+ if(inner_sneak == true,
+ if(inner_move_vertical == 'forward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右前方潜行↗');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左前方潜行↖');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向前潜行↑');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == 'backward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右后方潜行↘');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左后方潜行↙');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向后潜行↓');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == null,
+ if(inner_move_transverse == 'right',
+ print('- 正在向右潜行→');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左潜行←');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在潜伏');
+ noAct = false
+ );
+ );
+ );
+ if(inner_sprint == true,
+ if(inner_swim == true,
+ if(inner_move_vertical == 'forward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右前方游泳↗');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左前方游泳↖');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向前游泳↑');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == 'backward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右后方游泳↘§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左后方游泳↙§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向后游泳↓§e(没错它可以开挂)');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == null,
+ if(inner_move_transverse == 'right',
+ print('- 正在向右游泳→§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左游泳←§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在原地游泳↓§e(没错它可以开挂)');
+ noAct = false
+ );
+ );
+ );
+ if(inner_swim == false,
+ if(inner_move_vertical == 'forward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右前方疾跑↗');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左前方疾跑↖');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向前疾跑↑');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == 'backward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右后方疾跑↘§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左后方疾跑↙§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向后疾跑↓§e(没错它可以开挂)');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == null,
+ if(inner_move_transverse == 'right',
+ print('- 正在向右疾跑→§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左疾跑←§e(没错它可以开挂)');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在原地疾跑,§e(没错它可以开挂)');
+ noAct = false
+ );
+ );
+ );
+ );
+ if(inner_sprint == false && inner_sneak == false,
+ if(inner_move_vertical == 'forward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右前方走↗');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左前方走↖');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向前走↑');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == 'backward',
+ if(inner_move_transverse == 'right',
+ print('- 正在向右后方走↘');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左后方走↙');
+ noAct = false
+ );
+ if(inner_move_transverse == null,
+ print('- 正在向后走↓');
+ noAct = false
+ );
+ );
+ if(inner_move_vertical == null,
+ if(inner_move_transverse == 'right',
+ print('- 正在向右走→');
+ noAct = false
+ );
+ if(inner_move_transverse == 'left',
+ print('- 正在向左走←');
+ noAct = false
+ );
+ );
+ );
+ //乘坐
+ inner_mount = f_player~'mount';
+ if(inner_mount != null,
+ if(inner_mount == 'horse',
+ print('- 正在骑马');
+ );
+ if(inner_mount == 'donkey',
+ print('- 正在骑驴');
+ );
+ if(inner_mount == 'mule',
+ print('- 正在骑骡');
+ );
+ if(inner_mount == 'trader_llama',
+ print('- 正在骑羊驼');
+ );
+ if(inner_mount == 'pig',
+ print('- 正在骑猪');
+ );
+ if(inner_mount == 'skeleton_horse',
+ print('- 正在骑骷髅马');
+ );
+ if(inner_mount == 'zombie_horse',
+ print('- 正在骑僵尸马');
+ );
+ noAct = false
+ );
+ if(noAct == true,
+ print('- 无地毯动作');
+ );
+ return()
+);
+checkall() ->(
+ player_list = player('all');
+ c_for(i = 0, i < length(player_list), i += 1,
+ check(player_list:i);
+ );
+ return();
+);
\ No newline at end of file