mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-26 07:03:45 +01:00 
			
		
		
		
	Compare commits
	
		
			412 Commits
		
	
	
		
			fix/v6/fix
			...
			fix/chunk-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 8fff833e84 | ||
|   | f867867a42 | ||
|   | 59eefd6865 | ||
|   | 587a286d05 | ||
|   | e10caf6aa0 | ||
|   | 08b325e37d | ||
|   | c394108ba6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 31e89019f1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3a7075e28d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8373b7874e | ||
|   | fe13882b97 | ||
|   | f45064c4c4 | ||
|   | af32399dd2 | ||
|   | f3c03348d9 | ||
|   | a53330e39b | ||
|   | e2ba93dab9 | ||
|   | 9d43434e40 | ||
|   | 4f421167d1 | ||
|   | 94f4619c2c | ||
|   | 9885d3e506 | ||
|   | a54276d3b2 | ||
|   | cbb284b0fd | ||
|   | ed22b22e9c | ||
|   | 444ccda807 | ||
|   | db361cc420 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 079dc02cfe | ||
|   | e98791c865 | ||
|   | 7c3112f30f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c01f5f5c7d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 95caa19505 | ||
|   | b8055201df | ||
|   | 81daefae4a | ||
|   | 02437a8c72 | ||
|   | 958c66b28f | ||
|   | c656190e14 | ||
|   | e914cb210e | ||
|   | 94c6af74d2 | ||
|   | ebb82bd66d | ||
|   | 66f907eb5d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9ffede2c5c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 97172df0dc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c9746b182c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 10a2b80ffc | ||
|   | ca0f38255d | ||
|   | 0484ac73af | ||
|   | 1a712ad3c1 | ||
|   | 2d1f483469 | ||
|   | 91830e233b | ||
|   | 561edb83bf | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0e09cf223a | ||
|   | d78360d6eb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1464804c11 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8629eae5fc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7b8ba7c3ac | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 77c7466c17 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 82fe76fd37 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3f81ea4ef8 | ||
|   | 745b06a008 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 77b2bd166a | ||
|   | 8e02336c44 | ||
|   | 3adfbde45a | ||
|   | e6db8e2750 | ||
|   | 9cd0ee9b49 | ||
|   | d455d1fcd7 | ||
|   | ea19ff783f | ||
|   | 447e4c7d58 | ||
|   | 89031447f2 | ||
|   | 4210a3a555 | ||
|   | 42e146b8c7 | ||
|   | a5fdcda673 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 52823f5024 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1326c257a0 | ||
|   | fc3137cd96 | ||
|   | a5c53a96d1 | ||
|   | c46cc73f52 | ||
|   | 276e619caa | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f11acacedd | ||
|   | f636a5ec63 | ||
|   | d1bac90745 | ||
|   | 785362c576 | ||
|   | e98f628d34 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b2ab61559c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dd6eb8e74f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 97cdd03ea4 | ||
|   | f5118e6802 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 94ca5cf679 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5a55a1f602 | ||
|   | 1e7ba7d173 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ed33635a15 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 888682e5d0 | ||
|   | 72bb5f00b0 | ||
|   | 773fd6f59f | ||
|   | aa784e98f8 | ||
|   | 5cce86d924 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 84567bcb00 | ||
|   | d7c2ab1d16 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0d359ade0c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ffbec24290 | ||
|   | 586474c8e6 | ||
|   | 70b6636f50 | ||
|   | ab357deb48 | ||
|   | bd62d1a1c7 | ||
|   | 6130c3dfa5 | ||
|   | 26692d6633 | ||
|   | bb0f200429 | ||
|   | 5787588500 | ||
|   | bed62edc02 | ||
|   | ee0f389c78 | ||
|   | b40383b5a4 | ||
|   | be8903128d | ||
|   | 08800ec16d | ||
|   | 83e274ff9f | ||
|   | 0dd8b1053c | ||
|   | 0558fcf5d5 | ||
|   | 5af8be4293 | ||
|   | cbacdd67eb | ||
|   | c45bbe3ec5 | ||
|   | 746028afbc | ||
|   | b79537ebbc | ||
|   | 6efd581500 | ||
|   | 07e598e48f | ||
|   | f6f00dfcda | ||
|   | 63a6bdc1d6 | ||
|   | abbac057ed | ||
|   | c978322036 | ||
|   | 39d2f1a72c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 86919b8841 | ||
|   | 1448d8d4af | ||
|   | 8d9a387587 | ||
|   | 00722bc463 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6a34a1996f | ||
|   | 1d201b04ba | ||
|   | e887a59158 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d1b8f652a7 | ||
|   | 0707aa47c9 | ||
|   | 4aa7bc51bc | ||
|   | 0f0030916f | ||
|   | 8c57d616cf | ||
|   | 66660507e0 | ||
|   | a12490c3eb | ||
|   | bbf1e4fe61 | ||
|   | febac6fa40 | ||
|   | 99ee8a780d | ||
|   | 577a0d8ed9 | ||
|   | 02ae14894a | ||
|   | 36e5f36660 | ||
|   | 78dbe7fbbc | ||
|   | 669293566b | ||
|   | 350eae7813 | ||
|   | 12dc198a86 | ||
|   | fb2533d66a | ||
|   | 707c7be5bd | ||
|   | 37d6dcc7ea | ||
|   | becd8c4eaf | ||
|   | 530fcc0fea | ||
|   | 7135bdd6aa | ||
|   | 3198c3b081 | ||
|   | 339ca8e30f | ||
|   | 742d78a505 | ||
|   | 120bf37196 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2a40a6b35e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ea1f35b45a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 15e63378a7 | ||
|   | f3bc504a6f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3a8fae47a0 | ||
|   | 70cb1cd100 | ||
|   | 2067cc1670 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e6338976dd | ||
|   | 90ebd5d5ed | ||
|   | c973ee8649 | ||
|   | c1543f034c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6baf339ecb | ||
|   | 11906ef1c9 | ||
|   | ee8902154a | ||
|   | b5bc1988e5 | ||
|   | 2147012beb | ||
|   | 52bb561689 | ||
|   | 25ce7a83f1 | ||
|   | 55c8a590e7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 28bd993680 | ||
|   | 8330f37d8a | ||
|   | 985fae65b6 | ||
|   | db2d590e8e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c8d356783a | ||
|   | 4947450ff0 | ||
|   | de4e91ff62 | ||
|   | fe5e3d5f6d | ||
|   | b8b3098022 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0ae8fc46b8 | ||
|   | e0762f63a8 | ||
|   | 9f3850000c | ||
|   | 76c6be9ba7 | ||
|   | 308a5aa781 | ||
|   | e244527538 | ||
|   | 11dd013333 | ||
|   | b740d5854c | ||
|   | d5445cfbef | ||
|   | 3effaefda7 | ||
|   | 49b19e0eaf | ||
|   | caef3a923b | ||
|   | d4c3ceaf2b | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 25e6aecf13 | ||
|   | 33c11fdee9 | ||
|   | 316dd92667 | ||
|   | e53d2ac449 | ||
|   | 5786e8cc7a | ||
|   | 1b717c9b10 | ||
|   | 35abae99ca | ||
|   | d1a85982fb | ||
|   | 3446b913cd | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8b8fd6aab7 | ||
|   | 520bb64eca | ||
|   | 60d266b2d7 | ||
|   | 8deeef4f7d | ||
|   | 9b0b071c0c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 81a3f1098d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | efc248dcdb | ||
|   | 476f3d328d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 69f5f88183 | ||
|   | 6df63f7fc7 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 295b8a0135 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | fcc5bc5473 | ||
|   | 408b834376 | ||
|   | 986812b9e4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8d4333ad9d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9ff9097ff9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1ef424a2f1 | ||
|   | 9fd96dbaa2 | ||
|   | b0a4e11c46 | ||
|   | 77bce43ace | ||
|   | cba1927cc7 | ||
|   | 3d19c5c2ad | ||
|   | e0eff15694 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0bdeeea83b | ||
|   | 7669e79da1 | ||
|   | 6f96daae56 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d1021d19da | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ee589ac7f0 | ||
|   | 3b747ffecf | ||
|   | 4e5a2b9f96 | ||
|   | aeb4350ccb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9609990832 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0e4319b757 | ||
|   | c8f4907f77 | ||
|   | dcf98c2298 | ||
|   | ae59c7442f | ||
|   | 98708118d8 | ||
|   | 276d8f8e1e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 87f89541b5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 93f6de7029 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 73d2686b17 | ||
|   | c446a95b07 | ||
|   | 3676e1df35 | ||
|   | 12e2705260 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 31e777a03a | ||
|   | 7f436c405b | ||
|   | 4d4d2ab087 | ||
|   | 91017acce4 | ||
|   | c0bfa297bb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e90fd231d9 | ||
|   | cd9f0789de | ||
|   | 5f4c8d92df | ||
|   | 263cb47a21 | ||
|   | 005600c99e | ||
|   | 26bec7fe2f | ||
|   | f4b886d977 | ||
|   | 75fd9b2631 | ||
|   | c09d0d882e | ||
|   | 312cb2996c | ||
|   | f218902581 | ||
|   | f27009216c | ||
|   | 6b680fb2c0 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dda52ebc2e | ||
|   | 9ac8d38bab | ||
|   | 6a54328f7d | ||
|   | 7279862def | ||
|   | 08ce4c872c | ||
|   | 27ffe4fcdc | ||
|   | 8afcaccb8a | ||
|   | c83b13e374 | ||
|   | 2b0c5b1e21 | ||
|   | 3d5c694daa | ||
|   | 23360057b9 | ||
|   | d153232969 | ||
|   | bb0aa8d5cc | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d69f3b0893 | ||
|   | 565838ad43 | ||
|   | 8b52461271 | ||
|   | d08381dfed | ||
|   | b6c45f2df3 | ||
|   | b9479405e1 | ||
|   | a238ff19bf | ||
|   | c93b08d0c7 | ||
|   | 1470b7117a | ||
|   | 7cbc67f4fc | ||
|   | 0a76bbb2b0 | ||
|   | 09cc59a1c1 | ||
|   | 60f7113105 | ||
|   | 26c0c1b7cd | ||
|   | bf646be482 | ||
|   | cc7e17960b | ||
|   | 3c75b170f0 | ||
|   | 764c94c9cc | ||
|   | a79c474957 | ||
|   | 4bb480a238 | ||
|   | 9ffa935c0c | ||
|   | 3d87ee41b3 | ||
|   | 0a32268784 | ||
|   | ae3b8c06f6 | ||
|   | 713c4ad0d2 | ||
|   | fd8832ac98 | ||
|   | 48386c0828 | ||
|   | 625b3921e1 | ||
|   | 48aa37d173 | ||
|   | 228acc196c | ||
|   | 62197f3deb | ||
|   | 2c2314e95c | ||
|   | 5eb2fc3ad0 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 82cd9a092c | ||
|   | 62754362c2 | ||
|   | daa9348993 | ||
|   | 2e9dfd6f6f | ||
|   | 7e4499e092 | ||
|   | 396a1575d2 | ||
|   | fc9fe1462f | ||
|   | 41f546ca6b | ||
|   | d037da33cb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dc2d08c67e | ||
|   | 953d57d1b5 | ||
|   | 96dfc27411 | ||
|   | 171d2e5e99 | ||
|   | 4433892431 | ||
|   | b53d2d03a4 | ||
|   | c1431c0971 | ||
|   | 98a07dad1b | ||
|   | 0ffa22b7a6 | ||
|   | 60a0129fe9 | ||
|   | 62ee60a76c | ||
|   | d5f8a0842b | ||
|   | f7d55ce105 | ||
|   | 85911646f3 | ||
|   | 8b75dece69 | ||
|   | 7d6e515ba8 | ||
|   | 13d7357c85 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 16e26b910c | ||
|   | faadebd30e | ||
|   | 2aeacb3dcf | ||
|   | 9db7791835 | ||
|   | f49ddb819d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d71c62771e | ||
|   | a6aaa9538f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0974fb2834 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8982b33b6c | ||
|   | a7b3b3b7df | ||
|   | 888bb20e78 | ||
|   | b11bb6fa22 | ||
|   | e5764b958d | ||
|   | bfe3141ff1 | ||
|   | 73c82deeb0 | ||
|   | 38682ecff6 | ||
|   | 6a54dc7eff | ||
|   | 8454c29c91 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b2c9311a47 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | c4aa497a2b | ||
|   | c13f544390 | ||
|   | c28177d6af | ||
|   | 8a80f252cf | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 93571c72d1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6fd7379221 | ||
|   | dc5c80d812 | ||
|   | 96e9a61e7c | ||
|   | b9bd9b81e6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ec77812879 | ||
|   | efc2083798 | ||
|   | 3a6f845c01 | ||
|   | 7efd42ae45 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f43f4cbf5d | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 104cc4b7a4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 218be43143 | ||
|   | 308dba5601 | ||
|   | 5f233bb5d1 | ||
|   | 5e188d114f | ||
|   | 660e05d27f | ||
|   | 4c0ad148bf | ||
|   | 5c7bfb988c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b46f486680 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 05797d0c78 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 36ef2cf9ba | ||
|   | 26ec31a012 | ||
|   | fd4a542062 | ||
|   | dc13f2565f | ||
|   | 9f632af0ae | ||
|   | d698c6a1e5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 40e1bd9897 | ||
|   | 75f31c5bf6 | ||
|   | 954c813cef | ||
|   | 05e055e9cf | ||
|   | 2ea21c150f | ||
|   | c2fd4edad5 | ||
|   | 78b8696778 | ||
|   | e653961385 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b21d12fd52 | ||
|   | 7557df96c7 | ||
|   | 61797c3aff | ||
|   | 78125ff1e2 | ||
|   | d7c8715b25 | ||
|   | 34f005c244 | ||
|   | 6fbd1376ca | ||
|   | 951767dc64 | ||
|   | 16928b05f1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | fff14b05cb | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e619c867e9 | 
							
								
								
									
										630
									
								
								.editorconfig
									
									
									
									
									
								
							
							
						
						
									
										630
									
								
								.editorconfig
									
									
									
									
									
								
							| @@ -13,40 +13,6 @@ ij_formatter_tags_enabled = false | |||||||
| ij_smart_tabs = false | ij_smart_tabs = false | ||||||
| ij_wrap_on_typing = true | ij_wrap_on_typing = true | ||||||
|  |  | ||||||
| [*.conf] |  | ||||||
| indent_size = 2 |  | ||||||
| tab_width = 2 |  | ||||||
| ij_continuation_indent_size = 2 |  | ||||||
| ij_hocon_keep_blank_lines_before_right_brace = 2 |  | ||||||
| ij_hocon_keep_indents_on_empty_lines = false |  | ||||||
| ij_hocon_keep_line_breaks = true |  | ||||||
| ij_hocon_space_after_colon = true |  | ||||||
| ij_hocon_space_after_comma = true |  | ||||||
| ij_hocon_space_before_colon = true |  | ||||||
| ij_hocon_space_before_comma = false |  | ||||||
| ij_hocon_spaces_within_braces = false |  | ||||||
| ij_hocon_spaces_within_brackets = false |  | ||||||
| ij_hocon_spaces_within_method_call_parentheses = false |  | ||||||
|  |  | ||||||
| [*.css] |  | ||||||
| ij_css_align_closing_brace_with_properties = false |  | ||||||
| ij_css_blank_lines_around_nested_selector = 1 |  | ||||||
| ij_css_blank_lines_between_blocks = 1 |  | ||||||
| ij_css_brace_placement = end_of_line |  | ||||||
| ij_css_enforce_quotes_on_format = false |  | ||||||
| ij_css_hex_color_long_format = false |  | ||||||
| ij_css_hex_color_lower_case = false |  | ||||||
| ij_css_hex_color_short_format = false |  | ||||||
| ij_css_hex_color_upper_case = false |  | ||||||
| ij_css_keep_blank_lines_in_code = 2 |  | ||||||
| ij_css_keep_indents_on_empty_lines = false |  | ||||||
| ij_css_keep_single_line_blocks = false |  | ||||||
| ij_css_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow |  | ||||||
| ij_css_space_after_colon = true |  | ||||||
| ij_css_space_before_opening_brace = true |  | ||||||
| ij_css_use_double_quotes = true |  | ||||||
| ij_css_value_alignment = do_not_align |  | ||||||
|  |  | ||||||
| [*.java] | [*.java] | ||||||
| ij_java_align_consecutive_assignments = false | ij_java_align_consecutive_assignments = false | ||||||
| ij_java_align_consecutive_variable_declarations = false | ij_java_align_consecutive_variable_declarations = false | ||||||
| @@ -277,63 +243,12 @@ ij_java_wrap_comments = false | |||||||
| ij_java_wrap_first_method_in_call_chain = true | ij_java_wrap_first_method_in_call_chain = true | ||||||
| ij_java_wrap_long_lines = false | ij_java_wrap_long_lines = false | ||||||
|  |  | ||||||
| [*.nbtt] |  | ||||||
| max_line_length = 150 |  | ||||||
| ij_continuation_indent_size = 4 |  | ||||||
| ij_nbtt_keep_indents_on_empty_lines = false |  | ||||||
| ij_nbtt_space_after_colon = true |  | ||||||
| ij_nbtt_space_after_comma = true |  | ||||||
| ij_nbtt_space_before_colon = true |  | ||||||
| ij_nbtt_space_before_comma = false |  | ||||||
| ij_nbtt_spaces_within_brackets = false |  | ||||||
| ij_nbtt_spaces_within_parentheses = false |  | ||||||
|  |  | ||||||
| [*.properties] | [*.properties] | ||||||
| ij_properties_align_group_field_declarations = false | ij_properties_align_group_field_declarations = false | ||||||
| ij_properties_keep_blank_lines = false | ij_properties_keep_blank_lines = false | ||||||
| ij_properties_key_value_delimiter = equals | ij_properties_key_value_delimiter = equals | ||||||
| ij_properties_spaces_around_key_value_delimiter = false | ij_properties_spaces_around_key_value_delimiter = false | ||||||
|  |  | ||||||
| [*.sass] |  | ||||||
| indent_size = 2 |  | ||||||
| ij_sass_align_closing_brace_with_properties = false |  | ||||||
| ij_sass_blank_lines_around_nested_selector = 1 |  | ||||||
| ij_sass_blank_lines_between_blocks = 1 |  | ||||||
| ij_sass_brace_placement = 0 |  | ||||||
| ij_sass_enforce_quotes_on_format = false |  | ||||||
| ij_sass_hex_color_long_format = false |  | ||||||
| ij_sass_hex_color_lower_case = false |  | ||||||
| ij_sass_hex_color_short_format = false |  | ||||||
| ij_sass_hex_color_upper_case = false |  | ||||||
| ij_sass_keep_blank_lines_in_code = 2 |  | ||||||
| ij_sass_keep_indents_on_empty_lines = false |  | ||||||
| ij_sass_keep_single_line_blocks = false |  | ||||||
| ij_sass_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow |  | ||||||
| ij_sass_space_after_colon = true |  | ||||||
| ij_sass_space_before_opening_brace = true |  | ||||||
| ij_sass_use_double_quotes = true |  | ||||||
| ij_sass_value_alignment = 0 |  | ||||||
|  |  | ||||||
| [*.scss] |  | ||||||
| indent_size = 2 |  | ||||||
| ij_scss_align_closing_brace_with_properties = false |  | ||||||
| ij_scss_blank_lines_around_nested_selector = 1 |  | ||||||
| ij_scss_blank_lines_between_blocks = 1 |  | ||||||
| ij_scss_brace_placement = 0 |  | ||||||
| ij_scss_enforce_quotes_on_format = false |  | ||||||
| ij_scss_hex_color_long_format = false |  | ||||||
| ij_scss_hex_color_lower_case = false |  | ||||||
| ij_scss_hex_color_short_format = false |  | ||||||
| ij_scss_hex_color_upper_case = false |  | ||||||
| ij_scss_keep_blank_lines_in_code = 2 |  | ||||||
| ij_scss_keep_indents_on_empty_lines = false |  | ||||||
| ij_scss_keep_single_line_blocks = false |  | ||||||
| ij_scss_properties_order = font, font-family, font-size, font-weight, font-style, font-variant, font-size-adjust, font-stretch, line-height, position, z-index, top, right, bottom, left, display, visibility, float, clear, overflow, overflow-x, overflow-y, clip, zoom, align-content, align-items, align-self, flex, flex-flow, flex-basis, flex-direction, flex-grow, flex-shrink, flex-wrap, justify-content, order, box-sizing, width, min-width, max-width, height, min-height, max-height, margin, margin-top, margin-right, margin-bottom, margin-left, padding, padding-top, padding-right, padding-bottom, padding-left, table-layout, empty-cells, caption-side, border-spacing, border-collapse, list-style, list-style-position, list-style-type, list-style-image, content, quotes, counter-reset, counter-increment, resize, cursor, user-select, nav-index, nav-up, nav-right, nav-down, nav-left, transition, transition-delay, transition-timing-function, transition-duration, transition-property, transform, transform-origin, animation, animation-name, animation-duration, animation-play-state, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, text-align, text-align-last, vertical-align, white-space, text-decoration, text-emphasis, text-emphasis-color, text-emphasis-style, text-emphasis-position, text-indent, text-justify, letter-spacing, word-spacing, text-outline, text-transform, text-wrap, text-overflow, text-overflow-ellipsis, text-overflow-mode, word-wrap, word-break, tab-size, hyphens, pointer-events, opacity, color, border, border-width, border-style, border-color, border-top, border-top-width, border-top-style, border-top-color, border-right, border-right-width, border-right-style, border-right-color, border-bottom, border-bottom-width, border-bottom-style, border-bottom-color, border-left, border-left-width, border-left-style, border-left-color, border-radius, border-top-left-radius, border-top-right-radius, border-bottom-right-radius, border-bottom-left-radius, border-image, border-image-source, border-image-slice, border-image-width, border-image-outset, border-image-repeat, outline, outline-width, outline-style, outline-color, outline-offset, background, background-color, background-image, background-repeat, background-attachment, background-position, background-position-x, background-position-y, background-clip, background-origin, background-size, box-decoration-break, box-shadow, text-shadow |  | ||||||
| ij_scss_space_after_colon = true |  | ||||||
| ij_scss_space_before_opening_brace = true |  | ||||||
| ij_scss_use_double_quotes = true |  | ||||||
| ij_scss_value_alignment = 0 |  | ||||||
|  |  | ||||||
| [.editorconfig] | [.editorconfig] | ||||||
| ij_editorconfig_align_group_field_declarations = false | ij_editorconfig_align_group_field_declarations = false | ||||||
| ij_editorconfig_space_after_colon = false | ij_editorconfig_space_after_colon = false | ||||||
| @@ -342,548 +257,6 @@ ij_editorconfig_space_before_colon = false | |||||||
| ij_editorconfig_space_before_comma = false | ij_editorconfig_space_before_comma = false | ||||||
| ij_editorconfig_spaces_around_assignment_operators = true | ij_editorconfig_spaces_around_assignment_operators = true | ||||||
|  |  | ||||||
| [{*.ant, *.fxml, *.jhm, *.jnlp, *.jrxml, *.pom, *.rng, *.tld, *.wsdl, *.xml, *.xsd, *.xsl, *.xslt, *.xul}] |  | ||||||
| ij_xml_align_attributes = true |  | ||||||
| ij_xml_align_text = false |  | ||||||
| ij_xml_attribute_wrap = normal |  | ||||||
| ij_xml_block_comment_at_first_column = true |  | ||||||
| ij_xml_keep_blank_lines = 2 |  | ||||||
| ij_xml_keep_indents_on_empty_lines = false |  | ||||||
| ij_xml_keep_line_breaks = true |  | ||||||
| ij_xml_keep_line_breaks_in_text = true |  | ||||||
| ij_xml_keep_whitespaces = false |  | ||||||
| ij_xml_keep_whitespaces_around_cdata = preserve |  | ||||||
| ij_xml_keep_whitespaces_inside_cdata = false |  | ||||||
| ij_xml_line_comment_at_first_column = true |  | ||||||
| ij_xml_space_after_tag_name = false |  | ||||||
| ij_xml_space_around_equals_in_attribute = false |  | ||||||
| ij_xml_space_inside_empty_tag = false |  | ||||||
| ij_xml_text_wrap = normal |  | ||||||
|  |  | ||||||
| [{*.ats, *.ts}] |  | ||||||
| ij_continuation_indent_size = 4 |  | ||||||
| ij_typescript_align_imports = false |  | ||||||
| ij_typescript_align_multiline_array_initializer_expression = false |  | ||||||
| ij_typescript_align_multiline_binary_operation = false |  | ||||||
| ij_typescript_align_multiline_chained_methods = false |  | ||||||
| ij_typescript_align_multiline_extends_list = false |  | ||||||
| ij_typescript_align_multiline_for = true |  | ||||||
| ij_typescript_align_multiline_parameters = true |  | ||||||
| ij_typescript_align_multiline_parameters_in_calls = false |  | ||||||
| ij_typescript_align_multiline_ternary_operation = false |  | ||||||
| ij_typescript_align_object_properties = 0 |  | ||||||
| ij_typescript_align_union_types = false |  | ||||||
| ij_typescript_align_var_statements = 0 |  | ||||||
| ij_typescript_array_initializer_new_line_after_left_brace = false |  | ||||||
| ij_typescript_array_initializer_right_brace_on_new_line = false |  | ||||||
| ij_typescript_array_initializer_wrap = off |  | ||||||
| ij_typescript_assignment_wrap = off |  | ||||||
| ij_typescript_binary_operation_sign_on_next_line = false |  | ||||||
| ij_typescript_binary_operation_wrap = off |  | ||||||
| ij_typescript_blacklist_imports = rxjs/Rx, node_modules/**, **/node_modules/**, @angular/material, @angular/material/typings/** |  | ||||||
| ij_typescript_blank_lines_after_imports = 1 |  | ||||||
| ij_typescript_blank_lines_around_class = 1 |  | ||||||
| ij_typescript_blank_lines_around_field = 0 |  | ||||||
| ij_typescript_blank_lines_around_field_in_interface = 0 |  | ||||||
| ij_typescript_blank_lines_around_function = 1 |  | ||||||
| ij_typescript_blank_lines_around_method = 1 |  | ||||||
| ij_typescript_blank_lines_around_method_in_interface = 1 |  | ||||||
| ij_typescript_block_brace_style = end_of_line |  | ||||||
| ij_typescript_call_parameters_new_line_after_left_paren = false |  | ||||||
| ij_typescript_call_parameters_right_paren_on_new_line = false |  | ||||||
| ij_typescript_call_parameters_wrap = off |  | ||||||
| ij_typescript_catch_on_new_line = false |  | ||||||
| ij_typescript_chained_call_dot_on_new_line = true |  | ||||||
| ij_typescript_class_brace_style = end_of_line |  | ||||||
| ij_typescript_comma_on_new_line = false |  | ||||||
| ij_typescript_do_while_brace_force = never |  | ||||||
| ij_typescript_else_on_new_line = false |  | ||||||
| ij_typescript_enforce_trailing_comma = keep |  | ||||||
| ij_typescript_extends_keyword_wrap = off |  | ||||||
| ij_typescript_extends_list_wrap = off |  | ||||||
| ij_typescript_field_prefix = _ |  | ||||||
| ij_typescript_file_name_style = relaxed |  | ||||||
| ij_typescript_finally_on_new_line = false |  | ||||||
| ij_typescript_for_brace_force = never |  | ||||||
| ij_typescript_for_statement_new_line_after_left_paren = false |  | ||||||
| ij_typescript_for_statement_right_paren_on_new_line = false |  | ||||||
| ij_typescript_for_statement_wrap = off |  | ||||||
| ij_typescript_force_quote_style = false |  | ||||||
| ij_typescript_force_semicolon_style = false |  | ||||||
| ij_typescript_function_expression_brace_style = end_of_line |  | ||||||
| ij_typescript_if_brace_force = never |  | ||||||
| ij_typescript_import_merge_members = global |  | ||||||
| ij_typescript_import_prefer_absolute_path = global |  | ||||||
| ij_typescript_import_sort_members = true |  | ||||||
| ij_typescript_import_sort_module_name = false |  | ||||||
| ij_typescript_import_use_node_resolution = true |  | ||||||
| ij_typescript_imports_wrap = on_every_item |  | ||||||
| ij_typescript_indent_case_from_switch = true |  | ||||||
| ij_typescript_indent_chained_calls = true |  | ||||||
| ij_typescript_indent_package_children = 0 |  | ||||||
| ij_typescript_jsdoc_include_types = false |  | ||||||
| ij_typescript_jsx_attribute_value = braces |  | ||||||
| ij_typescript_keep_blank_lines_in_code = 2 |  | ||||||
| ij_typescript_keep_first_column_comment = true |  | ||||||
| ij_typescript_keep_indents_on_empty_lines = false |  | ||||||
| ij_typescript_keep_line_breaks = true |  | ||||||
| ij_typescript_keep_simple_blocks_in_one_line = false |  | ||||||
| ij_typescript_keep_simple_methods_in_one_line = false |  | ||||||
| ij_typescript_line_comment_add_space = true |  | ||||||
| ij_typescript_line_comment_at_first_column = false |  | ||||||
| ij_typescript_method_brace_style = end_of_line |  | ||||||
| ij_typescript_method_call_chain_wrap = off |  | ||||||
| ij_typescript_method_parameters_new_line_after_left_paren = false |  | ||||||
| ij_typescript_method_parameters_right_paren_on_new_line = false |  | ||||||
| ij_typescript_method_parameters_wrap = off |  | ||||||
| ij_typescript_object_literal_wrap = on_every_item |  | ||||||
| ij_typescript_parentheses_expression_new_line_after_left_paren = false |  | ||||||
| ij_typescript_parentheses_expression_right_paren_on_new_line = false |  | ||||||
| ij_typescript_place_assignment_sign_on_next_line = false |  | ||||||
| ij_typescript_prefer_as_type_cast = false |  | ||||||
| ij_typescript_prefer_explicit_types_function_expression_returns = false |  | ||||||
| ij_typescript_prefer_explicit_types_function_returns = false |  | ||||||
| ij_typescript_prefer_explicit_types_vars_fields = false |  | ||||||
| ij_typescript_prefer_parameters_wrap = false |  | ||||||
| ij_typescript_reformat_c_style_comments = false |  | ||||||
| ij_typescript_space_after_colon = true |  | ||||||
| ij_typescript_space_after_comma = true |  | ||||||
| ij_typescript_space_after_dots_in_rest_parameter = false |  | ||||||
| ij_typescript_space_after_generator_mult = true |  | ||||||
| ij_typescript_space_after_property_colon = true |  | ||||||
| ij_typescript_space_after_quest = true |  | ||||||
| ij_typescript_space_after_type_colon = true |  | ||||||
| ij_typescript_space_after_unary_not = false |  | ||||||
| ij_typescript_space_before_async_arrow_lparen = true |  | ||||||
| ij_typescript_space_before_catch_keyword = true |  | ||||||
| ij_typescript_space_before_catch_left_brace = true |  | ||||||
| ij_typescript_space_before_catch_parentheses = true |  | ||||||
| ij_typescript_space_before_class_lbrace = true |  | ||||||
| ij_typescript_space_before_class_left_brace = true |  | ||||||
| ij_typescript_space_before_colon = true |  | ||||||
| ij_typescript_space_before_comma = false |  | ||||||
| ij_typescript_space_before_do_left_brace = true |  | ||||||
| ij_typescript_space_before_else_keyword = true |  | ||||||
| ij_typescript_space_before_else_left_brace = true |  | ||||||
| ij_typescript_space_before_finally_keyword = true |  | ||||||
| ij_typescript_space_before_finally_left_brace = true |  | ||||||
| ij_typescript_space_before_for_left_brace = true |  | ||||||
| ij_typescript_space_before_for_parentheses = true |  | ||||||
| ij_typescript_space_before_for_semicolon = false |  | ||||||
| ij_typescript_space_before_function_left_parenth = true |  | ||||||
| ij_typescript_space_before_generator_mult = false |  | ||||||
| ij_typescript_space_before_if_left_brace = true |  | ||||||
| ij_typescript_space_before_if_parentheses = true |  | ||||||
| ij_typescript_space_before_method_call_parentheses = false |  | ||||||
| ij_typescript_space_before_method_left_brace = true |  | ||||||
| ij_typescript_space_before_method_parentheses = false |  | ||||||
| ij_typescript_space_before_property_colon = false |  | ||||||
| ij_typescript_space_before_quest = true |  | ||||||
| ij_typescript_space_before_switch_left_brace = true |  | ||||||
| ij_typescript_space_before_switch_parentheses = true |  | ||||||
| ij_typescript_space_before_try_left_brace = true |  | ||||||
| ij_typescript_space_before_type_colon = false |  | ||||||
| ij_typescript_space_before_unary_not = false |  | ||||||
| ij_typescript_space_before_while_keyword = true |  | ||||||
| ij_typescript_space_before_while_left_brace = true |  | ||||||
| ij_typescript_space_before_while_parentheses = true |  | ||||||
| ij_typescript_spaces_around_additive_operators = true |  | ||||||
| ij_typescript_spaces_around_arrow_function_operator = true |  | ||||||
| ij_typescript_spaces_around_assignment_operators = true |  | ||||||
| ij_typescript_spaces_around_bitwise_operators = true |  | ||||||
| ij_typescript_spaces_around_equality_operators = true |  | ||||||
| ij_typescript_spaces_around_logical_operators = true |  | ||||||
| ij_typescript_spaces_around_multiplicative_operators = true |  | ||||||
| ij_typescript_spaces_around_relational_operators = true |  | ||||||
| ij_typescript_spaces_around_shift_operators = true |  | ||||||
| ij_typescript_spaces_around_unary_operator = false |  | ||||||
| ij_typescript_spaces_within_array_initializer_brackets = false |  | ||||||
| ij_typescript_spaces_within_brackets = false |  | ||||||
| ij_typescript_spaces_within_catch_parentheses = false |  | ||||||
| ij_typescript_spaces_within_for_parentheses = false |  | ||||||
| ij_typescript_spaces_within_if_parentheses = false |  | ||||||
| ij_typescript_spaces_within_imports = false |  | ||||||
| ij_typescript_spaces_within_interpolation_expressions = false |  | ||||||
| ij_typescript_spaces_within_method_call_parentheses = false |  | ||||||
| ij_typescript_spaces_within_method_parentheses = false |  | ||||||
| ij_typescript_spaces_within_object_literal_braces = false |  | ||||||
| ij_typescript_spaces_within_object_type_braces = true |  | ||||||
| ij_typescript_spaces_within_parentheses = false |  | ||||||
| ij_typescript_spaces_within_switch_parentheses = false |  | ||||||
| ij_typescript_spaces_within_type_assertion = false |  | ||||||
| ij_typescript_spaces_within_union_types = true |  | ||||||
| ij_typescript_spaces_within_while_parentheses = false |  | ||||||
| ij_typescript_special_else_if_treatment = true |  | ||||||
| ij_typescript_ternary_operation_signs_on_next_line = false |  | ||||||
| ij_typescript_ternary_operation_wrap = off |  | ||||||
| ij_typescript_union_types_wrap = on_every_item |  | ||||||
| ij_typescript_use_chained_calls_group_indents = false |  | ||||||
| ij_typescript_use_double_quotes = true |  | ||||||
| ij_typescript_use_explicit_js_extension = global |  | ||||||
| ij_typescript_use_path_mapping = always |  | ||||||
| ij_typescript_use_public_modifier = false |  | ||||||
| ij_typescript_use_semicolon_after_statement = true |  | ||||||
| ij_typescript_var_declaration_wrap = normal |  | ||||||
| ij_typescript_while_brace_force = never |  | ||||||
| ij_typescript_while_on_new_line = false |  | ||||||
| ij_typescript_wrap_comments = false |  | ||||||
|  |  | ||||||
| [{*.bash, *.sh, *.zsh}] |  | ||||||
| indent_size = 2 |  | ||||||
| tab_width = 2 |  | ||||||
| ij_shell_binary_ops_start_line = false |  | ||||||
| ij_shell_keep_column_alignment_padding = false |  | ||||||
| ij_shell_minify_program = false |  | ||||||
| ij_shell_redirect_followed_by_space = false |  | ||||||
| ij_shell_switch_cases_indented = false |  | ||||||
|  |  | ||||||
| [{*.cjs, *.js}] |  | ||||||
| ij_continuation_indent_size = 4 |  | ||||||
| ij_javascript_align_imports = false |  | ||||||
| ij_javascript_align_multiline_array_initializer_expression = false |  | ||||||
| ij_javascript_align_multiline_binary_operation = false |  | ||||||
| ij_javascript_align_multiline_chained_methods = false |  | ||||||
| ij_javascript_align_multiline_extends_list = false |  | ||||||
| ij_javascript_align_multiline_for = true |  | ||||||
| ij_javascript_align_multiline_parameters = true |  | ||||||
| ij_javascript_align_multiline_parameters_in_calls = false |  | ||||||
| ij_javascript_align_multiline_ternary_operation = false |  | ||||||
| ij_javascript_align_object_properties = 0 |  | ||||||
| ij_javascript_align_union_types = false |  | ||||||
| ij_javascript_align_var_statements = 0 |  | ||||||
| ij_javascript_array_initializer_new_line_after_left_brace = false |  | ||||||
| ij_javascript_array_initializer_right_brace_on_new_line = false |  | ||||||
| ij_javascript_array_initializer_wrap = off |  | ||||||
| ij_javascript_assignment_wrap = off |  | ||||||
| ij_javascript_binary_operation_sign_on_next_line = false |  | ||||||
| ij_javascript_binary_operation_wrap = off |  | ||||||
| ij_javascript_blacklist_imports = rxjs/Rx, node_modules/**, **/node_modules/**, @angular/material, @angular/material/typings/** |  | ||||||
| ij_javascript_blank_lines_after_imports = 1 |  | ||||||
| ij_javascript_blank_lines_around_class = 1 |  | ||||||
| ij_javascript_blank_lines_around_field = 0 |  | ||||||
| ij_javascript_blank_lines_around_function = 1 |  | ||||||
| ij_javascript_blank_lines_around_method = 1 |  | ||||||
| ij_javascript_block_brace_style = end_of_line |  | ||||||
| ij_javascript_call_parameters_new_line_after_left_paren = false |  | ||||||
| ij_javascript_call_parameters_right_paren_on_new_line = false |  | ||||||
| ij_javascript_call_parameters_wrap = off |  | ||||||
| ij_javascript_catch_on_new_line = false |  | ||||||
| ij_javascript_chained_call_dot_on_new_line = true |  | ||||||
| ij_javascript_class_brace_style = end_of_line |  | ||||||
| ij_javascript_comma_on_new_line = false |  | ||||||
| ij_javascript_do_while_brace_force = never |  | ||||||
| ij_javascript_else_on_new_line = false |  | ||||||
| ij_javascript_enforce_trailing_comma = keep |  | ||||||
| ij_javascript_extends_keyword_wrap = off |  | ||||||
| ij_javascript_extends_list_wrap = off |  | ||||||
| ij_javascript_field_prefix = _ |  | ||||||
| ij_javascript_file_name_style = relaxed |  | ||||||
| ij_javascript_finally_on_new_line = false |  | ||||||
| ij_javascript_for_brace_force = never |  | ||||||
| ij_javascript_for_statement_new_line_after_left_paren = false |  | ||||||
| ij_javascript_for_statement_right_paren_on_new_line = false |  | ||||||
| ij_javascript_for_statement_wrap = off |  | ||||||
| ij_javascript_force_quote_style = false |  | ||||||
| ij_javascript_force_semicolon_style = false |  | ||||||
| ij_javascript_function_expression_brace_style = end_of_line |  | ||||||
| ij_javascript_if_brace_force = never |  | ||||||
| ij_javascript_import_merge_members = global |  | ||||||
| ij_javascript_import_prefer_absolute_path = global |  | ||||||
| ij_javascript_import_sort_members = true |  | ||||||
| ij_javascript_import_sort_module_name = false |  | ||||||
| ij_javascript_import_use_node_resolution = true |  | ||||||
| ij_javascript_imports_wrap = on_every_item |  | ||||||
| ij_javascript_indent_case_from_switch = true |  | ||||||
| ij_javascript_indent_chained_calls = true |  | ||||||
| ij_javascript_indent_package_children = 0 |  | ||||||
| ij_javascript_jsx_attribute_value = braces |  | ||||||
| ij_javascript_keep_blank_lines_in_code = 2 |  | ||||||
| ij_javascript_keep_first_column_comment = true |  | ||||||
| ij_javascript_keep_indents_on_empty_lines = false |  | ||||||
| ij_javascript_keep_line_breaks = true |  | ||||||
| ij_javascript_keep_simple_blocks_in_one_line = false |  | ||||||
| ij_javascript_keep_simple_methods_in_one_line = false |  | ||||||
| ij_javascript_line_comment_add_space = true |  | ||||||
| ij_javascript_line_comment_at_first_column = false |  | ||||||
| ij_javascript_method_brace_style = end_of_line |  | ||||||
| ij_javascript_method_call_chain_wrap = off |  | ||||||
| ij_javascript_method_parameters_new_line_after_left_paren = false |  | ||||||
| ij_javascript_method_parameters_right_paren_on_new_line = false |  | ||||||
| ij_javascript_method_parameters_wrap = off |  | ||||||
| ij_javascript_object_literal_wrap = on_every_item |  | ||||||
| ij_javascript_parentheses_expression_new_line_after_left_paren = false |  | ||||||
| ij_javascript_parentheses_expression_right_paren_on_new_line = false |  | ||||||
| ij_javascript_place_assignment_sign_on_next_line = false |  | ||||||
| ij_javascript_prefer_as_type_cast = false |  | ||||||
| ij_javascript_prefer_explicit_types_function_expression_returns = false |  | ||||||
| ij_javascript_prefer_explicit_types_function_returns = false |  | ||||||
| ij_javascript_prefer_explicit_types_vars_fields = false |  | ||||||
| ij_javascript_prefer_parameters_wrap = false |  | ||||||
| ij_javascript_reformat_c_style_comments = false |  | ||||||
| ij_javascript_space_after_colon = true |  | ||||||
| ij_javascript_space_after_comma = true |  | ||||||
| ij_javascript_space_after_dots_in_rest_parameter = false |  | ||||||
| ij_javascript_space_after_generator_mult = true |  | ||||||
| ij_javascript_space_after_property_colon = true |  | ||||||
| ij_javascript_space_after_quest = true |  | ||||||
| ij_javascript_space_after_type_colon = true |  | ||||||
| ij_javascript_space_after_unary_not = false |  | ||||||
| ij_javascript_space_before_async_arrow_lparen = true |  | ||||||
| ij_javascript_space_before_catch_keyword = true |  | ||||||
| ij_javascript_space_before_catch_left_brace = true |  | ||||||
| ij_javascript_space_before_catch_parentheses = true |  | ||||||
| ij_javascript_space_before_class_lbrace = true |  | ||||||
| ij_javascript_space_before_class_left_brace = true |  | ||||||
| ij_javascript_space_before_colon = true |  | ||||||
| ij_javascript_space_before_comma = false |  | ||||||
| ij_javascript_space_before_do_left_brace = true |  | ||||||
| ij_javascript_space_before_else_keyword = true |  | ||||||
| ij_javascript_space_before_else_left_brace = true |  | ||||||
| ij_javascript_space_before_finally_keyword = true |  | ||||||
| ij_javascript_space_before_finally_left_brace = true |  | ||||||
| ij_javascript_space_before_for_left_brace = true |  | ||||||
| ij_javascript_space_before_for_parentheses = true |  | ||||||
| ij_javascript_space_before_for_semicolon = false |  | ||||||
| ij_javascript_space_before_function_left_parenth = true |  | ||||||
| ij_javascript_space_before_generator_mult = false |  | ||||||
| ij_javascript_space_before_if_left_brace = true |  | ||||||
| ij_javascript_space_before_if_parentheses = true |  | ||||||
| ij_javascript_space_before_method_call_parentheses = false |  | ||||||
| ij_javascript_space_before_method_left_brace = true |  | ||||||
| ij_javascript_space_before_method_parentheses = false |  | ||||||
| ij_javascript_space_before_property_colon = false |  | ||||||
| ij_javascript_space_before_quest = true |  | ||||||
| ij_javascript_space_before_switch_left_brace = true |  | ||||||
| ij_javascript_space_before_switch_parentheses = true |  | ||||||
| ij_javascript_space_before_try_left_brace = true |  | ||||||
| ij_javascript_space_before_type_colon = false |  | ||||||
| ij_javascript_space_before_unary_not = false |  | ||||||
| ij_javascript_space_before_while_keyword = true |  | ||||||
| ij_javascript_space_before_while_left_brace = true |  | ||||||
| ij_javascript_space_before_while_parentheses = true |  | ||||||
| ij_javascript_spaces_around_additive_operators = true |  | ||||||
| ij_javascript_spaces_around_arrow_function_operator = true |  | ||||||
| ij_javascript_spaces_around_assignment_operators = true |  | ||||||
| ij_javascript_spaces_around_bitwise_operators = true |  | ||||||
| ij_javascript_spaces_around_equality_operators = true |  | ||||||
| ij_javascript_spaces_around_logical_operators = true |  | ||||||
| ij_javascript_spaces_around_multiplicative_operators = true |  | ||||||
| ij_javascript_spaces_around_relational_operators = true |  | ||||||
| ij_javascript_spaces_around_shift_operators = true |  | ||||||
| ij_javascript_spaces_around_unary_operator = false |  | ||||||
| ij_javascript_spaces_within_array_initializer_brackets = false |  | ||||||
| ij_javascript_spaces_within_brackets = false |  | ||||||
| ij_javascript_spaces_within_catch_parentheses = false |  | ||||||
| ij_javascript_spaces_within_for_parentheses = false |  | ||||||
| ij_javascript_spaces_within_if_parentheses = false |  | ||||||
| ij_javascript_spaces_within_imports = false |  | ||||||
| ij_javascript_spaces_within_interpolation_expressions = false |  | ||||||
| ij_javascript_spaces_within_method_call_parentheses = false |  | ||||||
| ij_javascript_spaces_within_method_parentheses = false |  | ||||||
| ij_javascript_spaces_within_object_literal_braces = false |  | ||||||
| ij_javascript_spaces_within_object_type_braces = true |  | ||||||
| ij_javascript_spaces_within_parentheses = false |  | ||||||
| ij_javascript_spaces_within_switch_parentheses = false |  | ||||||
| ij_javascript_spaces_within_type_assertion = false |  | ||||||
| ij_javascript_spaces_within_union_types = true |  | ||||||
| ij_javascript_spaces_within_while_parentheses = false |  | ||||||
| ij_javascript_special_else_if_treatment = true |  | ||||||
| ij_javascript_ternary_operation_signs_on_next_line = false |  | ||||||
| ij_javascript_ternary_operation_wrap = off |  | ||||||
| ij_javascript_union_types_wrap = on_every_item |  | ||||||
| ij_javascript_use_chained_calls_group_indents = false |  | ||||||
| ij_javascript_use_double_quotes = true |  | ||||||
| ij_javascript_use_explicit_js_extension = global |  | ||||||
| ij_javascript_use_path_mapping = always |  | ||||||
| ij_javascript_use_public_modifier = false |  | ||||||
| ij_javascript_use_semicolon_after_statement = true |  | ||||||
| ij_javascript_var_declaration_wrap = normal |  | ||||||
| ij_javascript_while_brace_force = never |  | ||||||
| ij_javascript_while_on_new_line = false |  | ||||||
| ij_javascript_wrap_comments = false |  | ||||||
|  |  | ||||||
| [{*.ft, *.vm, *.vsl}] |  | ||||||
| ij_vtl_keep_indents_on_empty_lines = false |  | ||||||
|  |  | ||||||
| [{*.gant, *.gradle, *.groovy, *.gy}] |  | ||||||
| ij_groovy_align_group_field_declarations = false |  | ||||||
| ij_groovy_align_multiline_array_initializer_expression = false |  | ||||||
| ij_groovy_align_multiline_assignment = false |  | ||||||
| ij_groovy_align_multiline_binary_operation = false |  | ||||||
| ij_groovy_align_multiline_chained_methods = false |  | ||||||
| ij_groovy_align_multiline_extends_list = false |  | ||||||
| ij_groovy_align_multiline_for = true |  | ||||||
| ij_groovy_align_multiline_list_or_map = true |  | ||||||
| ij_groovy_align_multiline_method_parentheses = false |  | ||||||
| ij_groovy_align_multiline_parameters = true |  | ||||||
| ij_groovy_align_multiline_parameters_in_calls = false |  | ||||||
| ij_groovy_align_multiline_resources = true |  | ||||||
| ij_groovy_align_multiline_ternary_operation = false |  | ||||||
| ij_groovy_align_multiline_throws_list = false |  | ||||||
| ij_groovy_align_named_args_in_map = true |  | ||||||
| ij_groovy_align_throws_keyword = false |  | ||||||
| ij_groovy_array_initializer_new_line_after_left_brace = false |  | ||||||
| ij_groovy_array_initializer_right_brace_on_new_line = false |  | ||||||
| ij_groovy_array_initializer_wrap = off |  | ||||||
| ij_groovy_assert_statement_wrap = off |  | ||||||
| ij_groovy_assignment_wrap = off |  | ||||||
| ij_groovy_binary_operation_wrap = off |  | ||||||
| ij_groovy_blank_lines_after_class_header = 0 |  | ||||||
| ij_groovy_blank_lines_after_imports = 1 |  | ||||||
| ij_groovy_blank_lines_after_package = 1 |  | ||||||
| ij_groovy_blank_lines_around_class = 1 |  | ||||||
| ij_groovy_blank_lines_around_field = 0 |  | ||||||
| ij_groovy_blank_lines_around_field_in_interface = 0 |  | ||||||
| ij_groovy_blank_lines_around_method = 1 |  | ||||||
| ij_groovy_blank_lines_around_method_in_interface = 1 |  | ||||||
| ij_groovy_blank_lines_before_imports = 1 |  | ||||||
| ij_groovy_blank_lines_before_method_body = 0 |  | ||||||
| ij_groovy_blank_lines_before_package = 0 |  | ||||||
| ij_groovy_block_brace_style = end_of_line |  | ||||||
| ij_groovy_block_comment_at_first_column = true |  | ||||||
| ij_groovy_call_parameters_new_line_after_left_paren = false |  | ||||||
| ij_groovy_call_parameters_right_paren_on_new_line = false |  | ||||||
| ij_groovy_call_parameters_wrap = off |  | ||||||
| ij_groovy_catch_on_new_line = false |  | ||||||
| ij_groovy_class_annotation_wrap = split_into_lines |  | ||||||
| ij_groovy_class_brace_style = end_of_line |  | ||||||
| ij_groovy_class_count_to_use_import_on_demand = 5 |  | ||||||
| ij_groovy_do_while_brace_force = never |  | ||||||
| ij_groovy_else_on_new_line = false |  | ||||||
| ij_groovy_enum_constants_wrap = off |  | ||||||
| ij_groovy_extends_keyword_wrap = off |  | ||||||
| ij_groovy_extends_list_wrap = off |  | ||||||
| ij_groovy_field_annotation_wrap = split_into_lines |  | ||||||
| ij_groovy_finally_on_new_line = false |  | ||||||
| ij_groovy_for_brace_force = never |  | ||||||
| ij_groovy_for_statement_new_line_after_left_paren = false |  | ||||||
| ij_groovy_for_statement_right_paren_on_new_line = false |  | ||||||
| ij_groovy_for_statement_wrap = off |  | ||||||
| ij_groovy_if_brace_force = never |  | ||||||
| ij_groovy_import_annotation_wrap = 2 |  | ||||||
| ij_groovy_imports_layout = *, |, javax.**, java.**, |, $* |  | ||||||
| ij_groovy_indent_case_from_switch = true |  | ||||||
| ij_groovy_indent_label_blocks = true |  | ||||||
| ij_groovy_insert_inner_class_imports = false |  | ||||||
| ij_groovy_keep_blank_lines_before_right_brace = 2 |  | ||||||
| ij_groovy_keep_blank_lines_in_code = 2 |  | ||||||
| ij_groovy_keep_blank_lines_in_declarations = 2 |  | ||||||
| ij_groovy_keep_control_statement_in_one_line = true |  | ||||||
| ij_groovy_keep_first_column_comment = true |  | ||||||
| ij_groovy_keep_indents_on_empty_lines = false |  | ||||||
| ij_groovy_keep_line_breaks = true |  | ||||||
| ij_groovy_keep_multiple_expressions_in_one_line = false |  | ||||||
| ij_groovy_keep_simple_blocks_in_one_line = false |  | ||||||
| ij_groovy_keep_simple_classes_in_one_line = true |  | ||||||
| ij_groovy_keep_simple_lambdas_in_one_line = true |  | ||||||
| ij_groovy_keep_simple_methods_in_one_line = true |  | ||||||
| ij_groovy_label_indent_absolute = false |  | ||||||
| ij_groovy_label_indent_size = 0 |  | ||||||
| ij_groovy_lambda_brace_style = end_of_line |  | ||||||
| ij_groovy_layout_static_imports_separately = true |  | ||||||
| ij_groovy_line_comment_add_space = false |  | ||||||
| ij_groovy_line_comment_at_first_column = true |  | ||||||
| ij_groovy_method_annotation_wrap = split_into_lines |  | ||||||
| ij_groovy_method_brace_style = end_of_line |  | ||||||
| ij_groovy_method_call_chain_wrap = off |  | ||||||
| ij_groovy_method_parameters_new_line_after_left_paren = false |  | ||||||
| ij_groovy_method_parameters_right_paren_on_new_line = false |  | ||||||
| ij_groovy_method_parameters_wrap = off |  | ||||||
| ij_groovy_modifier_list_wrap = false |  | ||||||
| ij_groovy_names_count_to_use_import_on_demand = 3 |  | ||||||
| ij_groovy_parameter_annotation_wrap = off |  | ||||||
| ij_groovy_parentheses_expression_new_line_after_left_paren = false |  | ||||||
| ij_groovy_parentheses_expression_right_paren_on_new_line = false |  | ||||||
| ij_groovy_prefer_parameters_wrap = false |  | ||||||
| ij_groovy_resource_list_new_line_after_left_paren = false |  | ||||||
| ij_groovy_resource_list_right_paren_on_new_line = false |  | ||||||
| ij_groovy_resource_list_wrap = off |  | ||||||
| ij_groovy_space_after_assert_separator = true |  | ||||||
| ij_groovy_space_after_colon = true |  | ||||||
| ij_groovy_space_after_comma = true |  | ||||||
| ij_groovy_space_after_comma_in_type_arguments = true |  | ||||||
| ij_groovy_space_after_for_semicolon = true |  | ||||||
| ij_groovy_space_after_quest = true |  | ||||||
| ij_groovy_space_after_type_cast = true |  | ||||||
| ij_groovy_space_before_annotation_parameter_list = false |  | ||||||
| ij_groovy_space_before_array_initializer_left_brace = false |  | ||||||
| ij_groovy_space_before_assert_separator = false |  | ||||||
| ij_groovy_space_before_catch_keyword = true |  | ||||||
| ij_groovy_space_before_catch_left_brace = true |  | ||||||
| ij_groovy_space_before_catch_parentheses = true |  | ||||||
| ij_groovy_space_before_class_left_brace = true |  | ||||||
| ij_groovy_space_before_closure_left_brace = true |  | ||||||
| ij_groovy_space_before_colon = true |  | ||||||
| ij_groovy_space_before_comma = false |  | ||||||
| ij_groovy_space_before_do_left_brace = true |  | ||||||
| ij_groovy_space_before_else_keyword = true |  | ||||||
| ij_groovy_space_before_else_left_brace = true |  | ||||||
| ij_groovy_space_before_finally_keyword = true |  | ||||||
| ij_groovy_space_before_finally_left_brace = true |  | ||||||
| ij_groovy_space_before_for_left_brace = true |  | ||||||
| ij_groovy_space_before_for_parentheses = true |  | ||||||
| ij_groovy_space_before_for_semicolon = false |  | ||||||
| ij_groovy_space_before_if_left_brace = true |  | ||||||
| ij_groovy_space_before_if_parentheses = true |  | ||||||
| ij_groovy_space_before_method_call_parentheses = false |  | ||||||
| ij_groovy_space_before_method_left_brace = true |  | ||||||
| ij_groovy_space_before_method_parentheses = false |  | ||||||
| ij_groovy_space_before_quest = true |  | ||||||
| ij_groovy_space_before_switch_left_brace = true |  | ||||||
| ij_groovy_space_before_switch_parentheses = true |  | ||||||
| ij_groovy_space_before_synchronized_left_brace = true |  | ||||||
| ij_groovy_space_before_synchronized_parentheses = true |  | ||||||
| ij_groovy_space_before_try_left_brace = true |  | ||||||
| ij_groovy_space_before_try_parentheses = true |  | ||||||
| ij_groovy_space_before_while_keyword = true |  | ||||||
| ij_groovy_space_before_while_left_brace = true |  | ||||||
| ij_groovy_space_before_while_parentheses = true |  | ||||||
| ij_groovy_space_in_named_argument = true |  | ||||||
| ij_groovy_space_in_named_argument_before_colon = false |  | ||||||
| ij_groovy_space_within_empty_array_initializer_braces = false |  | ||||||
| ij_groovy_space_within_empty_method_call_parentheses = false |  | ||||||
| ij_groovy_spaces_around_additive_operators = true |  | ||||||
| ij_groovy_spaces_around_assignment_operators = true |  | ||||||
| ij_groovy_spaces_around_bitwise_operators = true |  | ||||||
| ij_groovy_spaces_around_equality_operators = true |  | ||||||
| ij_groovy_spaces_around_lambda_arrow = true |  | ||||||
| ij_groovy_spaces_around_logical_operators = true |  | ||||||
| ij_groovy_spaces_around_multiplicative_operators = true |  | ||||||
| ij_groovy_spaces_around_regex_operators = true |  | ||||||
| ij_groovy_spaces_around_relational_operators = true |  | ||||||
| ij_groovy_spaces_around_shift_operators = true |  | ||||||
| ij_groovy_spaces_within_annotation_parentheses = false |  | ||||||
| ij_groovy_spaces_within_array_initializer_braces = false |  | ||||||
| ij_groovy_spaces_within_braces = true |  | ||||||
| ij_groovy_spaces_within_brackets = false |  | ||||||
| ij_groovy_spaces_within_cast_parentheses = false |  | ||||||
| ij_groovy_spaces_within_catch_parentheses = false |  | ||||||
| ij_groovy_spaces_within_for_parentheses = false |  | ||||||
| ij_groovy_spaces_within_gstring_injection_braces = false |  | ||||||
| ij_groovy_spaces_within_if_parentheses = false |  | ||||||
| ij_groovy_spaces_within_list_or_map = false |  | ||||||
| ij_groovy_spaces_within_method_call_parentheses = false |  | ||||||
| ij_groovy_spaces_within_method_parentheses = false |  | ||||||
| ij_groovy_spaces_within_parentheses = false |  | ||||||
| ij_groovy_spaces_within_switch_parentheses = false |  | ||||||
| ij_groovy_spaces_within_synchronized_parentheses = false |  | ||||||
| ij_groovy_spaces_within_try_parentheses = false |  | ||||||
| ij_groovy_spaces_within_tuple_expression = false |  | ||||||
| ij_groovy_spaces_within_while_parentheses = false |  | ||||||
| ij_groovy_special_else_if_treatment = true |  | ||||||
| ij_groovy_ternary_operation_wrap = off |  | ||||||
| ij_groovy_throws_keyword_wrap = off |  | ||||||
| ij_groovy_throws_list_wrap = off |  | ||||||
| ij_groovy_use_flying_geese_braces = false |  | ||||||
| ij_groovy_use_fq_class_names = false |  | ||||||
| ij_groovy_use_fq_class_names_in_javadoc = true |  | ||||||
| ij_groovy_use_relative_indents = false |  | ||||||
| ij_groovy_use_single_class_imports = true |  | ||||||
| ij_groovy_variable_annotation_wrap = off |  | ||||||
| ij_groovy_while_brace_force = never |  | ||||||
| ij_groovy_while_on_new_line = false |  | ||||||
| ij_groovy_wrap_long_lines = false |  | ||||||
|  |  | ||||||
| [{*.gradle.kts, *.kt, *.kts, *.main.kts}] | [{*.gradle.kts, *.kt, *.kts, *.main.kts}] | ||||||
| ij_kotlin_align_in_columns_case_branch = false | ij_kotlin_align_in_columns_case_branch = false | ||||||
| ij_kotlin_align_multiline_binary_operation = false | ij_kotlin_align_multiline_binary_operation = false | ||||||
| @@ -963,7 +336,8 @@ ij_kotlin_wrap_elvis_expressions = 1 | |||||||
| ij_kotlin_wrap_expression_body_functions = 0 | ij_kotlin_wrap_expression_body_functions = 0 | ||||||
| ij_kotlin_wrap_first_method_in_call_chain = false | ij_kotlin_wrap_first_method_in_call_chain = false | ||||||
|  |  | ||||||
| [{*.har, *.jsb2, *.jsb3, *.json, .babelrc, .eslintrc, .stylelintrc, bowerrc, jest.config, mcmod.info}] |  | ||||||
|  | [*.json] | ||||||
| indent_size = 2 | indent_size = 2 | ||||||
| ij_json_keep_blank_lines_in_code = 0 | ij_json_keep_blank_lines_in_code = 0 | ||||||
| ij_json_keep_indents_on_empty_lines = false | ij_json_keep_indents_on_empty_lines = false | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | * text=auto | ||||||
|  |  | ||||||
|  | *.java text | ||||||
|  | *.jar binary | ||||||
							
								
								
									
										14
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,7 +8,7 @@ body: | |||||||
|       value: | |       value: | | ||||||
|         Thanks for taking the time to fill out this bug report for PlotSquared! Fill out the following form to your best ability to help us fix the problem. |         Thanks for taking the time to fill out this bug report for PlotSquared! Fill out the following form to your best ability to help us fix the problem. | ||||||
|         Only use this if you're absolutely sure that you found a bug and can reproduce it. For anything else, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.github.io/plotsquared-documentation/). |         Only use this if you're absolutely sure that you found a bug and can reproduce it. For anything else, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.github.io/plotsquared-documentation/). | ||||||
|         Do NOT use the public issue tracker to report security vulnerabilities! They are disclosed using [this](https://forms.gle/btgdRn9yhGtzEiGW8) form! |         Do NOT use the public issue tracker to report security vulnerabilities! They are disclosed using [this](https://github.com/IntellectualSites/PlotSquared/security/policy) GitHub form! | ||||||
|  |  | ||||||
|   - type: dropdown |   - type: dropdown | ||||||
|     attributes: |     attributes: | ||||||
| @@ -27,13 +27,17 @@ body: | |||||||
|       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. |       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. | ||||||
|       multiple: false |       multiple: false | ||||||
|       options: |       options: | ||||||
|  |         - '1.20.1' | ||||||
|  |         - '1.20' | ||||||
|  |         - '1.19.4' | ||||||
|  |         - '1.19.3' | ||||||
|  |         - '1.19.2' | ||||||
|  |         - '1.19.1' | ||||||
|  |         - '1.19' | ||||||
|  |         - '1.18.2' | ||||||
|         - '1.18.1' |         - '1.18.1' | ||||||
|         - '1.18' |  | ||||||
|         - '1.17.1' |         - '1.17.1' | ||||||
|         - '1.16.5' |         - '1.16.5' | ||||||
|         - '1.15.2' |  | ||||||
|         - '1.14.4' |  | ||||||
|         - '1.13.2' |  | ||||||
|     validations: |     validations: | ||||||
|       required: true |       required: true | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | { | ||||||
|  |   "$schema": "https://docs.renovatebot.com/renovate-schema.json", | ||||||
|  |   "extends": [ | ||||||
|  |     "config:base", | ||||||
|  |     ":semanticCommitsDisabled" | ||||||
|  |   ], | ||||||
|  |   "automerge": true, | ||||||
|  |   "labels": [ | ||||||
|  |     "dependencies" | ||||||
|  |   ], | ||||||
|  |   "rebaseWhen": "conflicted", | ||||||
|  |   "schedule": ["on the first day of the month"] | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								.github/workflows/announce-release-on-discord.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/announce-release-on-discord.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | name: Announce release on discord | ||||||
|  | on: | ||||||
|  |   release: | ||||||
|  |     types: [ published ] | ||||||
|  | jobs: | ||||||
|  |   send_announcement: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: send custom message with args | ||||||
|  |         env: | ||||||
|  |           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||||
|  |           DISCORD_USERNAME: PlotSquared Release | ||||||
|  |           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png | ||||||
|  |         uses: Ilshidur/action-discord@0.3.2 | ||||||
|  |         with: | ||||||
|  |           args: | | ||||||
|  |             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||||
|  |             "" | ||||||
|  |             "<:plotsquared:730750385886593039> **PlotSquared ${{ github.event.release.tag_name }} has been released!**" | ||||||
|  |             "" | ||||||
|  |             "Click here to view changelog: https://github.com/IntellectualSites/PlotSquared/releases/tag/${{ github.event.release.tag_name }}" | ||||||
|  |             "" | ||||||
|  |             "The download is available at:" | ||||||
|  |             "- Spigot: <https://www.spigotmc.org/resources/77506/>" | ||||||
							
								
								
									
										21
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | name: Build PR | ||||||
|  | on: [ pull_request ] | ||||||
|  | jobs: | ||||||
|  |   build_pr: | ||||||
|  |     if: github.repository_owner == 'IntellectualSites' | ||||||
|  |     runs-on: ${{ matrix.os }} | ||||||
|  |     strategy: | ||||||
|  |       matrix: | ||||||
|  |         os: [ ubuntu-latest, windows-latest, macos-latest ] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout Repository | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Validate Gradle Wrapper | ||||||
|  |         uses: gradle/wrapper-validation-action@v1 | ||||||
|  |       - name: Setup Java | ||||||
|  |         uses: actions/setup-java@v3 | ||||||
|  |         with: | ||||||
|  |           distribution: temurin | ||||||
|  |           java-version: 17 | ||||||
|  |       - name: Clean Build | ||||||
|  |         run: ./gradlew clean build | ||||||
							
								
								
									
										45
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										45
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,18 +1,19 @@ | |||||||
| name: build | name: build | ||||||
|  | on: | ||||||
| on: [ pull_request, push ] |   push: | ||||||
|  |     branches: | ||||||
|  |       - main | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} |     if: github.repository_owner == 'IntellectualSites' | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v2.4.0 |         uses: actions/checkout@v3 | ||||||
|       - name: Validate Gradle Wrapper" |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/wrapper-validation-action@v1.0.4 |         uses: gradle/wrapper-validation-action@v1 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v2.5.0 |         uses: actions/setup-java@v3 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 17 |           java-version: 17 | ||||||
| @@ -27,7 +28,7 @@ jobs: | |||||||
|             echo "STATUS=release" >> $GITHUB_ENV |             echo "STATUS=release" >> $GITHUB_ENV | ||||||
|           fi |           fi | ||||||
|       - name: Publish Release |       - name: Publish Release | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository |         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
| @@ -35,8 +36,32 @@ jobs: | |||||||
|           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} |           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} | ||||||
|           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} |           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} | ||||||
|       - name: Publish Snapshot |       - name: Publish Snapshot | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6' }} |         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||||||
|         run: ./gradlew publishToSonatype |         run: ./gradlew publishToSonatype | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
|           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} |           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | ||||||
|  |       - name: Publish core javadoc | ||||||
|  |        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|  |         uses: cpina/github-action-push-to-another-repository@main | ||||||
|  |         env: | ||||||
|  |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
|  |         with: | ||||||
|  |           source-directory: 'Core/build/docs/javadoc' | ||||||
|  |           destination-github-username: 'IntellectualSites' | ||||||
|  |           destination-repository-name: 'plotsquared-javadocs' | ||||||
|  |           user-email: ${{ secrets.USER_EMAIL }} | ||||||
|  |           target-branch: main | ||||||
|  |           target-directory: v7/core | ||||||
|  |       - name: Publish bukkit javadoc | ||||||
|  |       #  if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|  |         uses: cpina/github-action-push-to-another-repository@main | ||||||
|  |         env: | ||||||
|  |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
|  |         with: | ||||||
|  |           source-directory: 'Bukkit/build/docs/javadoc' | ||||||
|  |           destination-github-username: 'IntellectualSites' | ||||||
|  |           destination-repository-name: 'plotsquared-javadocs' | ||||||
|  |           user-email: ${{ secrets.USER_EMAIL }} | ||||||
|  |           target-branch: main | ||||||
|  |           target-directory: v7/bukkit | ||||||
|   | |||||||
							
								
								
									
										36
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | name: "CodeQL" | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: [ main ] | ||||||
|  |   pull_request: | ||||||
|  |     # The branches below must be a subset of the branches above | ||||||
|  |     branches: [ main ] | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   analyze: | ||||||
|  |     name: Analyze | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       actions: read | ||||||
|  |       contents: read | ||||||
|  |       security-events: write | ||||||
|  |     strategy: | ||||||
|  |       fail-fast: false | ||||||
|  |       matrix: | ||||||
|  |         language: [ 'java' ] | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout repository | ||||||
|  |         uses: actions/checkout@v3 | ||||||
|  |       - name: Setup Java | ||||||
|  |         uses: actions/setup-java@v3 | ||||||
|  |         with: | ||||||
|  |           distribution: temurin | ||||||
|  |           java-version: 17 | ||||||
|  |       - name: Initialize CodeQL | ||||||
|  |         uses: github/codeql-action/init@v2 | ||||||
|  |         with: | ||||||
|  |           languages: ${{ matrix.language }} | ||||||
|  |       - name: Autobuild | ||||||
|  |         uses: github/codeql-action/autobuild@v2 | ||||||
|  |       - name: Perform CodeQL Analysis | ||||||
|  |         uses: github/codeql-action/analyze@v2 | ||||||
							
								
								
									
										20
									
								
								.github/workflows/rebase.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/rebase.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,20 +0,0 @@ | |||||||
| name: Rebase Pull Request |  | ||||||
| on: |  | ||||||
|   issue_comment: |  | ||||||
|     types: [created] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   rebase: |  | ||||||
|     name: Rebase |  | ||||||
|     if: github.event.issue.pull_request != '' && contains(github.event.comment.body, '/rebase') && github.event.comment.author_association == 'MEMBER' |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout Repository |  | ||||||
|         uses: actions/checkout@v2.4.0 |  | ||||||
|         with: |  | ||||||
|           token: ${{ secrets.REBASE_TOKEN }} |  | ||||||
|           fetch-depth: 0 |  | ||||||
|       - name: Automatic Rebase |  | ||||||
|         uses: cirrus-actions/rebase@1.5 |  | ||||||
|         env: |  | ||||||
|           GITHUB_TOKEN: ${{ secrets.REBASE_TOKEN }} |  | ||||||
							
								
								
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,19 +1,17 @@ | |||||||
| name: draft release | name: draft release | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - v6 |       - main | ||||||
|   pull_request: |   pull_request: | ||||||
|     types: [ opened, reopened, synchronize ] |     types: [ opened, reopened, synchronize ] | ||||||
|   pull_request_target: |   pull_request_target: | ||||||
|     types: [ opened, reopened, synchronize ] |     types: [ opened, reopened, synchronize ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   update_release_draft: |   update_release_draft: | ||||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} |     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: release-drafter/release-drafter@v5.17.6 |       - uses: release-drafter/release-drafter@v5 | ||||||
|         env: |         env: | ||||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -41,7 +41,8 @@ hs_err_pid* | |||||||
| *.iml | *.iml | ||||||
|  |  | ||||||
| ## Directory-based project format: | ## Directory-based project format: | ||||||
| .idea/ | /.idea/* | ||||||
|  | !/.idea/icon.svg | ||||||
| # if you remove the above rule, at least ignore the following: | # if you remove the above rule, at least ignore the following: | ||||||
|  |  | ||||||
| # User-specific stuff: | # User-specific stuff: | ||||||
| @@ -74,9 +75,6 @@ hs_err_pid* | |||||||
| # IntelliJ | # IntelliJ | ||||||
| /out/ | /out/ | ||||||
|  |  | ||||||
| # mpeltonen/sbt-idea plugin |  | ||||||
| .idea_modules/ |  | ||||||
|  |  | ||||||
| # JIRA plugin | # JIRA plugin | ||||||
| atlassian-ide-plugin.xml | atlassian-ide-plugin.xml | ||||||
|  |  | ||||||
| @@ -133,5 +131,13 @@ local.properties | |||||||
| checkstyle.xml | checkstyle.xml | ||||||
| classes/ | classes/ | ||||||
| *.bat | *.bat | ||||||
|  |  | ||||||
|  | # Other | ||||||
| docs/ | docs/ | ||||||
| build/ | build/ | ||||||
|  |  | ||||||
|  | .DS_Store | ||||||
|  | # Ignore run folders | ||||||
|  | run-[0-0].[0-9]/ | ||||||
|  | run-[0-0].[0-9].[0-9]/ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										146
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <svg | ||||||
|  |    version="1.1" | ||||||
|  |    id="svg2" | ||||||
|  |    xml:space="preserve" | ||||||
|  |    width="512" | ||||||
|  |    height="512" | ||||||
|  |    viewBox="0 0 512 512.00001" | ||||||
|  |    sodipodi:docname="icon.svg" | ||||||
|  |    inkscape:version="1.1.2 (b8e25be8, 2022-02-05)" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:cc="http://creativecommons.org/ns#" | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/"> | ||||||
|  | 		<metadata | ||||||
|  |    id="metadata8"> | ||||||
|  | 			<rdf:RDF> | ||||||
|  | 				<cc:Work | ||||||
|  |    rdf:about=""> | ||||||
|  | 					<dc:format>image/svg+xml</dc:format> | ||||||
|  |                     <dc:type | ||||||
|  |    rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||||
|  | 				</cc:Work> | ||||||
|  | 			</rdf:RDF> | ||||||
|  | 		</metadata> | ||||||
|  |     <defs | ||||||
|  |    id="defs6"> | ||||||
|  | 			<clipPath | ||||||
|  |    clipPathUnits="userSpaceOnUse" | ||||||
|  |    id="clipPath18"> | ||||||
|  | 				<path | ||||||
|  |    d="M 0,2500 H 3000 V 0 H 0 Z" | ||||||
|  |    id="path16" /> | ||||||
|  | 			</clipPath> | ||||||
|  | 		</defs> | ||||||
|  |     <sodipodi:namedview | ||||||
|  |    pagecolor="#ffffff" | ||||||
|  |    bordercolor="#666666" | ||||||
|  |    borderopacity="1" | ||||||
|  |    objecttolerance="10" | ||||||
|  |    gridtolerance="10" | ||||||
|  |    guidetolerance="10" | ||||||
|  |    inkscape:pageopacity="0" | ||||||
|  |    inkscape:pageshadow="2" | ||||||
|  |    inkscape:window-width="1440" | ||||||
|  |    inkscape:window-height="900" | ||||||
|  |    id="namedview4" | ||||||
|  |    inkscape:pagecheckerboard="0" | ||||||
|  |    showgrid="false" | ||||||
|  |    inkscape:zoom="0.1632" | ||||||
|  |    inkscape:cx="1087.6225" | ||||||
|  |    inkscape:cy="1666.6666" | ||||||
|  |    inkscape:window-x="0" | ||||||
|  |    inkscape:window-y="0" | ||||||
|  |    inkscape:window-maximized="0" | ||||||
|  |    inkscape:current-layer="g10" /> | ||||||
|  |     <g | ||||||
|  |    id="g10" | ||||||
|  |    inkscape:groupmode="layer" | ||||||
|  |    inkscape:label="PlotSquared" | ||||||
|  |    transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)"> | ||||||
|  | 			<g | ||||||
|  |    id="g12" | ||||||
|  |    transform="matrix(0.16955078,0,0,0.16955078,-68.456969,2101.8529)"> | ||||||
|  | 				<g | ||||||
|  |    id="g14" | ||||||
|  |    clip-path="url(#clipPath18)"> | ||||||
|  | 					<g | ||||||
|  |    id="g20" | ||||||
|  |    transform="translate(1486.1511,2242.6453)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0" | ||||||
|  |    style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path22" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g24" | ||||||
|  |    transform="translate(1201.7948,1741.5303)"> | ||||||
|  | 						<path | ||||||
|  |    d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z" | ||||||
|  |    style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path26" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g28" | ||||||
|  |    transform="translate(919.3342,1429.7462)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0" | ||||||
|  |    style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path30" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g32" | ||||||
|  |    transform="translate(1649.134,1700.6166)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0" | ||||||
|  |    style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path34" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g36" | ||||||
|  |    transform="translate(1262.7214,1613.126)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667" | ||||||
|  |    style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path38" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g40" | ||||||
|  |    transform="translate(1966.3174,1675.6364)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0" | ||||||
|  |    style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path42" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g44" | ||||||
|  |    transform="translate(1499.3971,1669.1094)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0" | ||||||
|  |    style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path46" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g48" | ||||||
|  |    transform="translate(1748.0469,1601.6797)"> | ||||||
|  | 						<path | ||||||
|  |    d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0" | ||||||
|  |    style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path50" /> | ||||||
|  | 					</g> | ||||||
|  |                     <g | ||||||
|  |    id="g52" | ||||||
|  |    transform="translate(1262.7214,1613.126)"> | ||||||
|  | 						<path | ||||||
|  |    d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z" | ||||||
|  |    style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" | ||||||
|  |    id="path54" /> | ||||||
|  | 					</g> | ||||||
|  | 				</g> | ||||||
|  | 			</g> | ||||||
|  | 		</g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 12 KiB | 
| @@ -1,4 +0,0 @@ | |||||||
| jdkVersion = "17" |  | ||||||
| build = "gradle clean build -x test" |  | ||||||
| tools = ["findsecbugs", "ErrorProne", "Semgrep", "Detekt", "Infer"] |  | ||||||
| ignoreRules = ["CatchAndPrintStackTrace", "ReferenceEquality", "FallThrough", "FutureReturnValueIgnored", "MixedMutabilityReturnType", "EmptyCatch", "MissingCasesInEnumSwitch", "OperatorPrecedence", "StaticAssignmentInConstructor", "ReferenceEquality", "EqualsHashCode", "EqualsGetClass", "TypeParameterUnusedInFormals", "StringSplitter", "InlineMeSuggester", "NULL_DEREFERENCE"] |  | ||||||
| @@ -8,7 +8,7 @@ repositories { | |||||||
|  |  | ||||||
|     maven { |     maven { | ||||||
|         name = "PaperMC" |         name = "PaperMC" | ||||||
|         url = uri("https://papermc.io/repo/repository/maven-public/") |         url = uri("https://repo.papermc.io/repository/maven-public/") | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     maven { |     maven { | ||||||
| @@ -18,23 +18,23 @@ repositories { | |||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     api(projects.plotSquaredCore) |     api(projects.plotsquaredCore) | ||||||
|  |  | ||||||
|     // Metrics |     // Metrics | ||||||
|     implementation(libs.bstats) |     implementation("org.bstats:bstats-bukkit") | ||||||
|  |  | ||||||
|     // Paper |     // Paper | ||||||
|     compileOnly(libs.paper) |     compileOnly("io.papermc.paper:paper-api") | ||||||
|     implementation(libs.paperlib) |     implementation("io.papermc:paperlib") | ||||||
|  |  | ||||||
|     // Plugins |     // Plugins | ||||||
|     compileOnly(libs.worldeditBukkit) { |     compileOnly(libs.worldeditBukkit) { | ||||||
|         exclude(group = "org.bukkit") |         exclude(group = "org.bukkit") | ||||||
|         exclude(group = "org.spigotmc") |         exclude(group = "org.spigotmc") | ||||||
|     } |     } | ||||||
|     compileOnly(libs.fastasyncworldeditBukkit) { isTransitive = false } |     compileOnly("com.fastasyncworldedit:FastAsyncWorldEdit-Bukkit") { isTransitive = false } | ||||||
|     testImplementation(libs.fastasyncworldeditBukkit) { isTransitive = false } |     testImplementation("com.fastasyncworldedit:FastAsyncWorldEdit-Bukkit") { isTransitive = false } | ||||||
|     compileOnly(libs.vault) { |     compileOnly("com.github.MilkBowl:VaultAPI") { | ||||||
|         exclude(group = "org.bukkit") |         exclude(group = "org.bukkit") | ||||||
|     } |     } | ||||||
|     compileOnly(libs.placeholderapi) |     compileOnly(libs.placeholderapi) | ||||||
| @@ -44,15 +44,15 @@ dependencies { | |||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|     implementation(libs.squirrelid) { isTransitive = false } |     implementation(libs.squirrelid) { isTransitive = false } | ||||||
|     implementation(libs.serverlib) |     implementation("dev.notmyfault.serverlib:ServerLib") | ||||||
|  |  | ||||||
|     // Our libraries |     // Our libraries | ||||||
|     implementation(libs.arkitektonika) |     implementation(libs.arkitektonika) | ||||||
|     implementation(libs.http4j) |     implementation("com.intellectualsites.paster:Paster") | ||||||
|     implementation(libs.paster) |     implementation("com.intellectualsites.informative-annotations:informative-annotations") | ||||||
|  |  | ||||||
|     // Adventure |     // Adventure | ||||||
|     implementation(libs.adventurePlatformBukkit) |     implementation("net.kyori:adventure-platform-bukkit") | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks.processResources { | tasks.processResources { | ||||||
| @@ -62,6 +62,7 @@ tasks.processResources { | |||||||
| } | } | ||||||
|  |  | ||||||
| tasks.named<ShadowJar>("shadowJar") { | tasks.named<ShadowJar>("shadowJar") { | ||||||
|  |     dependsOn(":plotsquared-core:shadowJar") | ||||||
|     dependencies { |     dependencies { | ||||||
|         exclude(dependency("org.checkerframework:")) |         exclude(dependency("org.checkerframework:")) | ||||||
|     } |     } | ||||||
| @@ -83,8 +84,11 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|     relocate("org.jetbrains", "com.plotsquared.core.annotations") |     relocate("org.jetbrains", "com.plotsquared.core.annotations") | ||||||
|     relocate("org.intellij.lang", "com.plotsquared.core.intellij.annotations") |     relocate("org.intellij.lang", "com.plotsquared.core.intellij.annotations") | ||||||
|     relocate("javax.annotation", "com.plotsquared.core.annotation") |     relocate("javax.annotation", "com.plotsquared.core.annotation") | ||||||
|     relocate("com.google.code.findbugs", "com.plotsquared.core.findbugs") |     relocate("com.github.spotbugs", "com.plotsquared.core.spotbugs") | ||||||
|     relocate("javax.inject", "com.plotsquared.core.annotation.inject") |     relocate("javax.inject", "com.plotsquared.core.annotation.inject") | ||||||
|  |     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") | ||||||
|  |     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") | ||||||
|  |     relocate("com.intellectualsites.annotations", "com.plotsquared.core.annotations.informative") | ||||||
|  |  | ||||||
|     // Get rid of all the libs which are 100% unused. |     // Get rid of all the libs which are 100% unused. | ||||||
|     minimize() |     minimize() | ||||||
| @@ -94,12 +98,19 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|  |  | ||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|  |         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://papermc.io/javadocs/paper/1.18/") |         opt.links("https://jd.papermc.io/paper/1.19/") | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) | ||||||
|         opt.links("https://javadoc.io/doc/com.plotsquared/PlotSquared-Core/latest/") |         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/" + libs.adventure.get().versionConstraint.toString()) |         opt.links("https://jd.advntr.dev/api/4.14.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|  |         opt.isLinkSource = true | ||||||
|  |         opt.bottom(File("$rootDir/javadocfooter.html").readText()) | ||||||
|  |         opt.isUse = true | ||||||
|  |         opt.encoding("UTF-8") | ||||||
|  |         opt.keyWords() | ||||||
|  |         opt.addStringOption("-since", isRelease) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -43,11 +36,11 @@ import com.plotsquared.bukkit.listener.ChunkListener; | |||||||
| import com.plotsquared.bukkit.listener.EntityEventListener; | import com.plotsquared.bukkit.listener.EntityEventListener; | ||||||
| import com.plotsquared.bukkit.listener.EntitySpawnListener; | import com.plotsquared.bukkit.listener.EntitySpawnListener; | ||||||
| import com.plotsquared.bukkit.listener.PaperListener; | import com.plotsquared.bukkit.listener.PaperListener; | ||||||
| import com.plotsquared.bukkit.listener.PaperListener113; |  | ||||||
| import com.plotsquared.bukkit.listener.PlayerEventListener; | import com.plotsquared.bukkit.listener.PlayerEventListener; | ||||||
| import com.plotsquared.bukkit.listener.ProjectileEventListener; | import com.plotsquared.bukkit.listener.ProjectileEventListener; | ||||||
| import com.plotsquared.bukkit.listener.ServerListener; | import com.plotsquared.bukkit.listener.ServerListener; | ||||||
| import com.plotsquared.bukkit.listener.SingleWorldListener; | import com.plotsquared.bukkit.listener.SingleWorldListener; | ||||||
|  | import com.plotsquared.bukkit.listener.SpigotListener; | ||||||
| import com.plotsquared.bukkit.listener.WorldEvents; | import com.plotsquared.bukkit.listener.WorldEvents; | ||||||
| import com.plotsquared.bukkit.placeholder.PAPIPlaceholders; | import com.plotsquared.bukkit.placeholder.PAPIPlaceholders; | ||||||
| import com.plotsquared.bukkit.placeholder.PlaceholderFormatter; | import com.plotsquared.bukkit.placeholder.PlaceholderFormatter; | ||||||
| @@ -56,7 +49,7 @@ import com.plotsquared.bukkit.player.BukkitPlayerManager; | |||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitWorld; | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.bukkit.util.SetGenCB; | import com.plotsquared.bukkit.util.SetGenCB; | ||||||
| import com.plotsquared.bukkit.util.UpdateUtility; | import com.plotsquared.bukkit.util.TranslationUpdateManager; | ||||||
| import com.plotsquared.bukkit.util.task.BukkitTaskManager; | import com.plotsquared.bukkit.util.task.BukkitTaskManager; | ||||||
| import com.plotsquared.bukkit.util.task.PaperTimeConverter; | import com.plotsquared.bukkit.util.task.PaperTimeConverter; | ||||||
| import com.plotsquared.bukkit.util.task.SpigotTimeConverter; | import com.plotsquared.bukkit.util.task.SpigotTimeConverter; | ||||||
| @@ -78,6 +71,8 @@ import com.plotsquared.core.configuration.Storage; | |||||||
| import com.plotsquared.core.configuration.caption.ChatFormatter; | import com.plotsquared.core.configuration.caption.ChatFormatter; | ||||||
| import com.plotsquared.core.configuration.file.YamlConfiguration; | import com.plotsquared.core.configuration.file.YamlConfiguration; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.events.RemoveRoadEntityEvent; | ||||||
|  | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.generator.SingleWorldGenerator; | import com.plotsquared.core.generator.SingleWorldGenerator; | ||||||
| @@ -116,6 +111,7 @@ import com.plotsquared.core.uuid.CacheUUIDService; | |||||||
| import com.plotsquared.core.uuid.UUIDPipeline; | import com.plotsquared.core.uuid.UUIDPipeline; | ||||||
| import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.audience.Audience; | import net.kyori.adventure.audience.Audience; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -144,6 +140,7 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
| import org.incendo.serverlib.ServerLib; | import org.incendo.serverlib.ServerLib; | ||||||
|  |  | ||||||
| import java.io.File; | import java.io.File; | ||||||
|  | import java.io.IOException; | ||||||
| import java.lang.reflect.Method; | import java.lang.reflect.Method; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| @@ -238,6 +235,16 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         return this.version; |         return this.version; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int versionMinHeight() { | ||||||
|  |         return serverVersion()[1] >= 18 ? -64 : 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int versionMaxHeight() { | ||||||
|  |         return serverVersion()[1] >= 18 ? 319 : 255; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull String serverImplementation() { |     public @NonNull String serverImplementation() { | ||||||
|         return Bukkit.getVersion(); |         return Bukkit.getVersion(); | ||||||
| @@ -260,7 +267,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|         final PlotSquared plotSquared = new PlotSquared(this, "Bukkit"); |         final PlotSquared plotSquared = new PlotSquared(this, "Bukkit"); | ||||||
|  |  | ||||||
|         // FAWE |         // FastAsyncWorldEdit | ||||||
|         if (Settings.FAWE_Components.FAWE_HOOK) { |         if (Settings.FAWE_Components.FAWE_HOOK) { | ||||||
|             Plugin fawe = getServer().getPluginManager().getPlugin("FastAsyncWorldEdit"); |             Plugin fawe = getServer().getPluginManager().getPlugin("FastAsyncWorldEdit"); | ||||||
|             if (fawe != null) { |             if (fawe != null) { | ||||||
| @@ -268,7 +275,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                     Class.forName("com.fastasyncworldedit.bukkit.regions.plotsquared.FaweQueueCoordinator"); |                     Class.forName("com.fastasyncworldedit.bukkit.regions.plotsquared.FaweQueueCoordinator"); | ||||||
|                     faweHook = true; |                     faweHook = true; | ||||||
|                 } catch (Exception ignored) { |                 } catch (Exception ignored) { | ||||||
|                     LOGGER.error("Incompatible version of FAWE to enable hook, please upgrade: https://ci.athion" + |                     LOGGER.error("Incompatible version of FastAsyncWorldEdit to enable hook, please upgrade: https://ci.athion" + | ||||||
|                             ".net/job/FastAsyncWorldEdit/"); |                             ".net/job/FastAsyncWorldEdit/"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -287,11 +294,19 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                 ); |                 ); | ||||||
|         this.injector.injectMembers(this); |         this.injector.injectMembers(this); | ||||||
|  |  | ||||||
|  |         try { | ||||||
|  |             this.injector.getInstance(TranslationUpdateManager.class).upgradeTranslationFile(); | ||||||
|  |         } catch (IOException e) { | ||||||
|  |             throw new RuntimeException(e); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); |         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); | ||||||
|  |  | ||||||
|  |         /* TODO Enable update checker before v7 is released to GA | ||||||
|         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { |         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { | ||||||
|             injector.getInstance(UpdateUtility.class).updateChecker(); |             injector.getInstance(UpdateUtility.class).updateChecker(); | ||||||
|         } |         } | ||||||
|  |          */ | ||||||
|  |  | ||||||
|         if (PremiumVerification.isPremium()) { |         if (PremiumVerification.isPremium()) { | ||||||
|             LOGGER.info("PlotSquared version licensed to Spigot user {}", getUserID()); |             LOGGER.info("PlotSquared version licensed to Spigot user {}", getUserID()); | ||||||
| @@ -352,11 +367,9 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); | ||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); | ||||||
|             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { |             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { | ||||||
|                 if (serverVersion()[1] == 13) { |  | ||||||
|                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener113.class), this); |  | ||||||
|                 } else { |  | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); |                 getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); | ||||||
|                 } |             } else { | ||||||
|  |                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); | ||||||
|             } |             } | ||||||
|             this.plotListener.startRunnable(); |             this.plotListener.startRunnable(); | ||||||
|         } |         } | ||||||
| @@ -422,7 +435,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|         plotSquared.startExpiryTasks(); |         plotSquared.startExpiryTasks(); | ||||||
|  |  | ||||||
|         // Once the server has loaded force updating all generators known to P2 |         // Once the server has loaded force updating all generators known to PlotSquared | ||||||
|         TaskManager.runTaskLater(() -> PlotSquared.platform().setupUtils().updateGenerators(true), TaskTime.ticks(1L)); |         TaskManager.runTaskLater(() -> PlotSquared.platform().setupUtils().updateGenerators(true), TaskTime.ticks(1L)); | ||||||
|  |  | ||||||
|         // Services are accessed in order |         // Services are accessed in order | ||||||
| @@ -503,8 +516,10 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                 this.backgroundPipeline.registerService(essentialsUUIDService); |                 this.backgroundPipeline.registerService(essentialsUUIDService); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             if (Settings.UUID.IMPROMPTU_SERVICE_MOJANG_API) { | ||||||
|                 final SquirrelIdUUIDService impromptuMojangService = new SquirrelIdUUIDService(Settings.UUID.IMPROMPTU_LIMIT); |                 final SquirrelIdUUIDService impromptuMojangService = new SquirrelIdUUIDService(Settings.UUID.IMPROMPTU_LIMIT); | ||||||
|                 this.impromptuPipeline.registerService(impromptuMojangService); |                 this.impromptuPipeline.registerService(impromptuMojangService); | ||||||
|  |             } | ||||||
|             final SquirrelIdUUIDService backgroundMojangService = new SquirrelIdUUIDService(Settings.UUID.BACKGROUND_LIMIT); |             final SquirrelIdUUIDService backgroundMojangService = new SquirrelIdUUIDService(Settings.UUID.BACKGROUND_LIMIT); | ||||||
|             this.backgroundPipeline.registerService(backgroundMojangService); |             this.backgroundPipeline.registerService(backgroundMojangService); | ||||||
|         } else { |         } else { | ||||||
| @@ -651,20 +666,15 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             final @NonNull SQLiteUUIDService sqLiteUUIDService, |             final @NonNull SQLiteUUIDService sqLiteUUIDService, | ||||||
|             final @NonNull CacheUUIDService cacheUUIDService |             final @NonNull CacheUUIDService cacheUUIDService | ||||||
|     ) { |     ) { | ||||||
|         // Load all uuids into a big chunky boi queue |         // Record all unique UUID's and put them into a queue | ||||||
|         final Queue<UUID> uuidQueue = new LinkedBlockingQueue<>(); |         final Set<UUID> uuidSet = new HashSet<>(); | ||||||
|         PlotSquared.get().forEachPlotRaw(plot -> { |         PlotSquared.get().forEachPlotRaw(plot -> { | ||||||
|             final Set<UUID> uuids = new HashSet<>(); |             uuidSet.add(plot.getOwnerAbs()); | ||||||
|             uuids.add(plot.getOwnerAbs()); |             uuidSet.addAll(plot.getMembers()); | ||||||
|             uuids.addAll(plot.getMembers()); |             uuidSet.addAll(plot.getTrusted()); | ||||||
|             uuids.addAll(plot.getTrusted()); |             uuidSet.addAll(plot.getDenied()); | ||||||
|             uuids.addAll(plot.getDenied()); |  | ||||||
|             for (final UUID uuid : uuids) { |  | ||||||
|                 if (!uuidQueue.contains(uuid)) { |  | ||||||
|                     uuidQueue.add(uuid); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }); |         }); | ||||||
|  |         final Queue<UUID> uuidQueue = new LinkedBlockingQueue<>(uuidSet); | ||||||
|  |  | ||||||
|         LOGGER.info("(UUID) {} UUIDs will be cached", uuidQueue.size()); |         LOGGER.info("(UUID) {} UUIDs will be cached", uuidQueue.size()); | ||||||
|  |  | ||||||
| @@ -727,6 +737,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         this.getServer().getPluginManager().disablePlugin(this); |         this.getServer().getPluginManager().disablePlugin(this); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void shutdownServer() { | ||||||
|  |         getServer().shutdown(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private void registerCommands() { |     private void registerCommands() { | ||||||
|         final BukkitCommand bukkitCommand = new BukkitCommand(); |         final BukkitCommand bukkitCommand = new BukkitCommand(); | ||||||
|         final PluginCommand plotCommand = getCommand("plots"); |         final PluginCommand plotCommand = getCommand("plots"); | ||||||
| @@ -807,8 +822,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                         if (entity.hasMetadata("ps-tmp-teleport")) { |                                         if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                             continue; |                                             continue; | ||||||
|                                         } |                                         } | ||||||
|                                         iterator.remove(); |                                         this.removeRoadEntity(entity, iterator); | ||||||
|                                         entity.remove(); |  | ||||||
|                                     } |                                     } | ||||||
|                                     continue; |                                     continue; | ||||||
|                                 } |                                 } | ||||||
| @@ -821,8 +835,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                     if (entity.hasMetadata("ps-tmp-teleport")) { |                                     if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                         continue; |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|                                     iterator.remove(); |                                     this.removeRoadEntity(entity, iterator); | ||||||
|                                     entity.remove(); |  | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                             continue; |                             continue; | ||||||
| @@ -832,7 +845,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                         case "DROPPED_ITEM": |                         case "DROPPED_ITEM": | ||||||
|                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS |                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS | ||||||
|                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { |                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { | ||||||
|                                 entity.remove(); |                                 this.removeRoadEntity(entity, iterator); | ||||||
|                             } |                             } | ||||||
|                             // dropped item |                             // dropped item | ||||||
|                             continue; |                             continue; | ||||||
| @@ -841,11 +854,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                             // managed elsewhere |                             // managed elsewhere | ||||||
|                             continue; |                             continue; | ||||||
|                         case "SHULKER": |                         case "SHULKER": | ||||||
|                             if (Settings.Enabled_Components.KILL_ROAD_MOBS) { |                             if (Settings.Enabled_Components.KILL_ROAD_MOBS && (Settings.Enabled_Components.KILL_NAMED_ROAD_MOBS || entity.getCustomName() == null)) { | ||||||
|                                 LivingEntity livingEntity = (LivingEntity) entity; |                                 LivingEntity livingEntity = (LivingEntity) entity; | ||||||
|                                 List<MetadataValue> meta = entity.getMetadata("shulkerPlot"); |                                 List<MetadataValue> meta = entity.getMetadata("shulkerPlot"); | ||||||
|                                 if (!meta.isEmpty()) { |                                 if (!meta.isEmpty()) { | ||||||
|                                     if (livingEntity.isLeashed()) { |                                     if (livingEntity.isLeashed() && !Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS) { | ||||||
|                                         continue; |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|                                     List<MetadataValue> keep = entity.getMetadata("keep"); |                                     List<MetadataValue> keep = entity.getMetadata("keep"); | ||||||
| @@ -858,15 +871,12 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                         com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); |                                         com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); | ||||||
|                                         PlotArea area = pLoc.getPlotArea(); |                                         PlotArea area = pLoc.getPlotArea(); | ||||||
|                                         if (area != null) { |                                         if (area != null) { | ||||||
|                                             PlotId currentPlotId = area.getPlotAbs(pLoc).getId(); |                                             Plot currentPlot = area.getPlotAbs(pLoc); | ||||||
|                                             if (!originalPlotId.equals(currentPlotId) && (currentPlotId == null || !area.getPlot( |                                             if (currentPlot == null || !originalPlotId.equals(currentPlot.getId())) { | ||||||
|                                                             originalPlotId) |  | ||||||
|                                                     .equals(area.getPlot(currentPlotId)))) { |  | ||||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { |                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                     continue; |                                                     continue; | ||||||
|                                                 } |                                                 } | ||||||
|                                                 iterator.remove(); |                                                 this.removeRoadEntity(entity, iterator); | ||||||
|                                                 entity.remove(); |  | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
| @@ -875,11 +885,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                     com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); |                                     com.plotsquared.core.location.Location pLoc = BukkitUtil.adapt(entity.getLocation()); | ||||||
|                                     PlotArea area = pLoc.getPlotArea(); |                                     PlotArea area = pLoc.getPlotArea(); | ||||||
|                                     if (area != null) { |                                     if (area != null) { | ||||||
|                                         PlotId currentPlotId = area.getPlotAbs(pLoc).getId(); |                                         Plot currentPlot = area.getPlotAbs(pLoc); | ||||||
|                                         if (currentPlotId != null) { |                                         if (currentPlot != null) { | ||||||
|                                             entity.setMetadata( |                                             entity.setMetadata( | ||||||
|                                                     "shulkerPlot", |                                                     "shulkerPlot", | ||||||
|                                                     new FixedMetadataValue((Plugin) PlotSquared.platform(), currentPlotId) |                                                     new FixedMetadataValue((Plugin) PlotSquared.platform(), currentPlot.getId()) | ||||||
|                                             ); |                                             ); | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
| @@ -965,23 +975,24 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                                 || !entity.hasMetadata("keep")) { |                                                 || !entity.hasMetadata("keep")) { | ||||||
|                                             Entity passenger = entity.getPassenger(); |                                             Entity passenger = entity.getPassenger(); | ||||||
|                                             if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS |                                             if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS | ||||||
|                                                     || !(passenger instanceof Player)) && entity.getMetadata("keep").isEmpty()) { |                                                     || !((passenger instanceof Player) || livingEntity.isLeashed())) | ||||||
|  |                                                     && (Settings.Enabled_Components.KILL_NAMED_ROAD_MOBS || entity.getCustomName() == null) | ||||||
|  |                                                     && entity.getMetadata("keep").isEmpty()) { | ||||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { |                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                     continue; |                                                     continue; | ||||||
|                                                 } |                                                 } | ||||||
|                                                 iterator.remove(); |                                                 this.removeRoadEntity(entity, iterator); | ||||||
|                                                 entity.remove(); |  | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                     } else { |                                     } else { | ||||||
|                                         Entity passenger = entity.getPassenger(); |                                         Entity passenger = entity.getPassenger(); | ||||||
|                                         if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS |                                         if ((Settings.Enabled_Components.KILL_OWNED_ROAD_MOBS || !(passenger instanceof Player)) | ||||||
|                                                 || !(passenger instanceof Player)) && entity.getMetadata("keep").isEmpty()) { |                                                 && (Settings.Enabled_Components.KILL_NAMED_ROAD_MOBS && entity.getCustomName() != null) | ||||||
|  |                                                 && entity.getMetadata("keep").isEmpty()) { | ||||||
|                                             if (entity.hasMetadata("ps-tmp-teleport")) { |                                             if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                 continue; |                                                 continue; | ||||||
|                                             } |                                             } | ||||||
|                                             iterator.remove(); |                                             this.removeRoadEntity(entity, iterator); | ||||||
|                                             entity.remove(); |  | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
| @@ -995,6 +1006,17 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         }), TaskTime.seconds(1L)); |         }), TaskTime.seconds(1L)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private void removeRoadEntity(Entity entity, Iterator<Entity> entityIterator) { | ||||||
|  |         RemoveRoadEntityEvent event = eventDispatcher.callRemoveRoadEntity(BukkitAdapter.adapt(entity)); | ||||||
|  |  | ||||||
|  |         if (event.getEventResult() == Result.DENY) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         entityIterator.remove(); | ||||||
|  |         entity.remove(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @Nullable |     public @Nullable | ||||||
|     final ChunkGenerator getDefaultWorldGenerator( |     final ChunkGenerator getDefaultWorldGenerator( | ||||||
| @@ -1164,9 +1186,17 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|     public @NonNull String worldEditImplementations() { |     public @NonNull String worldEditImplementations() { | ||||||
|         StringBuilder msg = new StringBuilder(); |         StringBuilder msg = new StringBuilder(); | ||||||
|         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { |         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { | ||||||
|             msg.append("FastAsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit").getDescription().getVersion()); |             msg.append("FastAsyncWorldEdit: ").append(Bukkit | ||||||
|  |                     .getPluginManager() | ||||||
|  |                     .getPlugin("FastAsyncWorldEdit") | ||||||
|  |                     .getDescription() | ||||||
|  |                     .getVersion()); | ||||||
|         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { |         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { | ||||||
|             msg.append("AsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("AsyncWorldEdit").getDescription().getVersion()).append("\n"); |             msg.append("AsyncWorldEdit: ").append(Bukkit | ||||||
|  |                     .getPluginManager() | ||||||
|  |                     .getPlugin("AsyncWorldEdit") | ||||||
|  |                     .getDescription() | ||||||
|  |                     .getVersion()).append("\n"); | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|         } else { |         } else { | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -108,50 +101,26 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|             this.noGravity = true; |             this.noGravity = true; | ||||||
|         } |         } | ||||||
|         switch (entity.getType().toString()) { |         switch (entity.getType().toString()) { | ||||||
|             case "BOAT": |             case "BOAT" -> { | ||||||
|                 Boat boat = (Boat) entity; |                 Boat boat = (Boat) entity; | ||||||
|                 this.dataByte = getOrdinal(TreeSpecies.values(), boat.getWoodType()); |                 this.dataByte = getOrdinal(TreeSpecies.values(), boat.getWoodType()); | ||||||
|                 return; |                 return; | ||||||
|             case "ARROW": |             } | ||||||
|             case "EGG": |             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", | ||||||
|             case "ENDER_CRYSTAL": |                     "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", "MINECART_MOB_SPAWNER", | ||||||
|             case "ENDER_PEARL": |                     "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SLIME", "SMALL_FIREBALL", "SNOWBALL", "MINECART_FURNACE", "SPLASH_POTION", | ||||||
|             case "ENDER_SIGNAL": |                     "THROWN_EXP_BOTTLE", "WITHER_SKULL", "UNKNOWN", "SPECTRAL_ARROW", "SHULKER_BULLET", "DRAGON_FIREBALL", "AREA_EFFECT_CLOUD", | ||||||
|             case "EXPERIENCE_ORB": |                     "TRIDENT", "LLAMA_SPIT" -> { | ||||||
|             case "FALLING_BLOCK": |  | ||||||
|             case "FIREBALL": |  | ||||||
|             case "FIREWORK": |  | ||||||
|             case "FISHING_HOOK": |  | ||||||
|             case "LEASH_HITCH": |  | ||||||
|             case "LIGHTNING": |  | ||||||
|             case "MINECART": |  | ||||||
|             case "MINECART_COMMAND": |  | ||||||
|             case "MINECART_MOB_SPAWNER": |  | ||||||
|             case "MINECART_TNT": |  | ||||||
|             case "PLAYER": |  | ||||||
|             case "PRIMED_TNT": |  | ||||||
|             case "SLIME": |  | ||||||
|             case "SMALL_FIREBALL": |  | ||||||
|             case "SNOWBALL": |  | ||||||
|             case "MINECART_FURNACE": |  | ||||||
|             case "SPLASH_POTION": |  | ||||||
|             case "THROWN_EXP_BOTTLE": |  | ||||||
|             case "WITHER_SKULL": |  | ||||||
|             case "UNKNOWN": |  | ||||||
|             case "SPECTRAL_ARROW": |  | ||||||
|             case "SHULKER_BULLET": |  | ||||||
|             case "DRAGON_FIREBALL": |  | ||||||
|             case "AREA_EFFECT_CLOUD": |  | ||||||
|             case "TRIDENT": |  | ||||||
|             case "LLAMA_SPIT": |  | ||||||
|                 // Do this stuff later |                 // Do this stuff later | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // MISC // |             // MISC // | ||||||
|             case "DROPPED_ITEM": |             case "DROPPED_ITEM" -> { | ||||||
|                 Item item = (Item) entity; |                 Item item = (Item) entity; | ||||||
|                 this.stack = item.getItemStack(); |                 this.stack = item.getItemStack(); | ||||||
|                 return; |                 return; | ||||||
|             case "ITEM_FRAME": |             } | ||||||
|  |             case "ITEM_FRAME" -> { | ||||||
|                 this.x = Math.floor(this.getX()); |                 this.x = Math.floor(this.getX()); | ||||||
|                 this.y = Math.floor(this.getY()); |                 this.y = Math.floor(this.getY()); | ||||||
|                 this.z = Math.floor(this.getZ()); |                 this.z = Math.floor(this.getZ()); | ||||||
| @@ -159,7 +128,8 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 this.dataByte = getOrdinal(Rotation.values(), itemFrame.getRotation()); |                 this.dataByte = getOrdinal(Rotation.values(), itemFrame.getRotation()); | ||||||
|                 this.stack = itemFrame.getItem().clone(); |                 this.stack = itemFrame.getItem().clone(); | ||||||
|                 return; |                 return; | ||||||
|             case "PAINTING": |             } | ||||||
|  |             case "PAINTING" -> { | ||||||
|                 this.x = Math.floor(this.getX()); |                 this.x = Math.floor(this.getX()); | ||||||
|                 this.y = Math.floor(this.getY()); |                 this.y = Math.floor(this.getY()); | ||||||
|                 this.z = Math.floor(this.getZ()); |                 this.z = Math.floor(this.getZ()); | ||||||
| @@ -172,20 +142,17 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 } |                 } | ||||||
|                 this.dataString = art.name(); |                 this.dataString = art.name(); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END MISC // |             // END MISC // | ||||||
|             // INVENTORY HOLDER // |             // INVENTORY HOLDER // | ||||||
|             case "MINECART_CHEST": |             case "MINECART_CHEST", "MINECART_HOPPER" -> { | ||||||
|             case "MINECART_HOPPER": |  | ||||||
|                 storeInventory((InventoryHolder) entity); |                 storeInventory((InventoryHolder) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // START LIVING ENTITY // |             // START LIVING ENTITY // | ||||||
|             // START AGEABLE // |             // START AGEABLE // | ||||||
|             // START TAMEABLE // |             // START TAMEABLE // | ||||||
|             case "HORSE": |             case "HORSE", "DONKEY", "LLAMA", "MULE", "SKELETON_HORSE" -> { | ||||||
|             case "DONKEY": |  | ||||||
|             case "LLAMA": |  | ||||||
|             case "MULE": |  | ||||||
|             case "SKELETON_HORSE": |  | ||||||
|                 AbstractHorse horse = (AbstractHorse) entity; |                 AbstractHorse horse = (AbstractHorse) entity; | ||||||
|                 this.horse = new HorseStats(); |                 this.horse = new HorseStats(); | ||||||
|                 this.horse.jump = horse.getJumpStrength(); |                 this.horse.jump = horse.getJumpStrength(); | ||||||
| @@ -201,16 +168,17 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 storeLiving(horse); |                 storeLiving(horse); | ||||||
|                 storeInventory(horse); |                 storeInventory(horse); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END INVENTORY HOLDER // |             // END INVENTORY HOLDER // | ||||||
|             case "WOLF": |             case "WOLF", "OCELOT" -> { | ||||||
|             case "OCELOT": |  | ||||||
|                 storeTameable((Tameable) entity); |                 storeTameable((Tameable) entity); | ||||||
|                 storeAgeable((Ageable) entity); |                 storeAgeable((Ageable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END TAMEABLE // |             // END TAMEABLE // | ||||||
|             //todo fix sheep |             //todo fix sheep | ||||||
|             case "SHEEP": |             case "SHEEP" -> { | ||||||
|                 Sheep sheep = (Sheep) entity; |                 Sheep sheep = (Sheep) entity; | ||||||
|                 if (sheep.isSheared()) { |                 if (sheep.isSheared()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
| @@ -221,23 +189,20 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 storeAgeable(sheep); |                 storeAgeable(sheep); | ||||||
|                 storeLiving(sheep); |                 storeLiving(sheep); | ||||||
|                 return; |                 return; | ||||||
|             case "VILLAGER": |             } | ||||||
|             case "CHICKEN": |             case "VILLAGER", "CHICKEN", "COW", "MUSHROOM_COW", "PIG", "TURTLE", "POLAR_BEAR" -> { | ||||||
|             case "COW": |  | ||||||
|             case "MUSHROOM_COW": |  | ||||||
|             case "PIG": |  | ||||||
|             case "TURTLE": |  | ||||||
|             case "POLAR_BEAR": |  | ||||||
|                 storeAgeable((Ageable) entity); |                 storeAgeable((Ageable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|             case "RABBIT": |             } | ||||||
|  |             case "RABBIT" -> { | ||||||
|                 this.dataByte = getOrdinal(Rabbit.Type.values(), ((Rabbit) entity).getRabbitType()); |                 this.dataByte = getOrdinal(Rabbit.Type.values(), ((Rabbit) entity).getRabbitType()); | ||||||
|                 storeAgeable((Ageable) entity); |                 storeAgeable((Ageable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "ARMOR_STAND": |             case "ARMOR_STAND" -> { | ||||||
|                 ArmorStand stand = (ArmorStand) entity; |                 ArmorStand stand = (ArmorStand) entity; | ||||||
|                 this.inventory = |                 this.inventory = | ||||||
|                         new ItemStack[]{stand.getItemInHand().clone(), stand.getHelmet().clone(), |                         new ItemStack[]{stand.getItemInHand().clone(), stand.getHelmet().clone(), | ||||||
| @@ -245,37 +210,30 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                                 stand.getBoots().clone()}; |                                 stand.getBoots().clone()}; | ||||||
|                 storeLiving(stand); |                 storeLiving(stand); | ||||||
|                 this.stand = new ArmorStandStats(); |                 this.stand = new ArmorStandStats(); | ||||||
|  |  | ||||||
|                 EulerAngle head = stand.getHeadPose(); |                 EulerAngle head = stand.getHeadPose(); | ||||||
|                 this.stand.head[0] = (float) head.getX(); |                 this.stand.head[0] = (float) head.getX(); | ||||||
|                 this.stand.head[1] = (float) head.getY(); |                 this.stand.head[1] = (float) head.getY(); | ||||||
|                 this.stand.head[2] = (float) head.getZ(); |                 this.stand.head[2] = (float) head.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle body = stand.getBodyPose(); |                 EulerAngle body = stand.getBodyPose(); | ||||||
|                 this.stand.body[0] = (float) body.getX(); |                 this.stand.body[0] = (float) body.getX(); | ||||||
|                 this.stand.body[1] = (float) body.getY(); |                 this.stand.body[1] = (float) body.getY(); | ||||||
|                 this.stand.body[2] = (float) body.getZ(); |                 this.stand.body[2] = (float) body.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle leftLeg = stand.getLeftLegPose(); |                 EulerAngle leftLeg = stand.getLeftLegPose(); | ||||||
|                 this.stand.leftLeg[0] = (float) leftLeg.getX(); |                 this.stand.leftLeg[0] = (float) leftLeg.getX(); | ||||||
|                 this.stand.leftLeg[1] = (float) leftLeg.getY(); |                 this.stand.leftLeg[1] = (float) leftLeg.getY(); | ||||||
|                 this.stand.leftLeg[2] = (float) leftLeg.getZ(); |                 this.stand.leftLeg[2] = (float) leftLeg.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle rightLeg = stand.getRightLegPose(); |                 EulerAngle rightLeg = stand.getRightLegPose(); | ||||||
|                 this.stand.rightLeg[0] = (float) rightLeg.getX(); |                 this.stand.rightLeg[0] = (float) rightLeg.getX(); | ||||||
|                 this.stand.rightLeg[1] = (float) rightLeg.getY(); |                 this.stand.rightLeg[1] = (float) rightLeg.getY(); | ||||||
|                 this.stand.rightLeg[2] = (float) rightLeg.getZ(); |                 this.stand.rightLeg[2] = (float) rightLeg.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle leftArm = stand.getLeftArmPose(); |                 EulerAngle leftArm = stand.getLeftArmPose(); | ||||||
|                 this.stand.leftArm[0] = (float) leftArm.getX(); |                 this.stand.leftArm[0] = (float) leftArm.getX(); | ||||||
|                 this.stand.leftArm[1] = (float) leftArm.getY(); |                 this.stand.leftArm[1] = (float) leftArm.getY(); | ||||||
|                 this.stand.leftArm[2] = (float) leftArm.getZ(); |                 this.stand.leftArm[2] = (float) leftArm.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle rightArm = stand.getRightArmPose(); |                 EulerAngle rightArm = stand.getRightArmPose(); | ||||||
|                 this.stand.rightArm[0] = (float) rightArm.getX(); |                 this.stand.rightArm[0] = (float) rightArm.getX(); | ||||||
|                 this.stand.rightArm[1] = (float) rightArm.getY(); |                 this.stand.rightArm[1] = (float) rightArm.getY(); | ||||||
|                 this.stand.rightArm[2] = (float) rightArm.getZ(); |                 this.stand.rightArm[2] = (float) rightArm.getZ(); | ||||||
|  |  | ||||||
|                 if (stand.hasArms()) { |                 if (stand.hasArms()) { | ||||||
|                     this.stand.arms = true; |                     this.stand.arms = true; | ||||||
|                 } |                 } | ||||||
| @@ -289,52 +247,37 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                     this.stand.small = true; |                     this.stand.small = true; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             case "ENDERMITE": |             } | ||||||
|  |             case "ENDERMITE" -> { | ||||||
|                 return; |                 return; | ||||||
|             case "BAT": |             } | ||||||
|  |             case "BAT" -> { | ||||||
|                 if (((Bat) entity).isAwake()) { |                 if (((Bat) entity).isAwake()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
|                 } else { |                 } else { | ||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             case "ENDER_DRAGON": |             } | ||||||
|  |             case "ENDER_DRAGON" -> { | ||||||
|                 EnderDragon entity1 = (EnderDragon) entity; |                 EnderDragon entity1 = (EnderDragon) entity; | ||||||
|                 this.dataByte = (byte) entity1.getPhase().ordinal(); |                 this.dataByte = (byte) entity1.getPhase().ordinal(); | ||||||
|                 return; |                 return; | ||||||
|             case "SKELETON": |             } | ||||||
|             case "WITHER_SKELETON": |             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", | ||||||
|             case "GUARDIAN": |                     "ZOMBIFIED_PIGLIN", "PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", | ||||||
|             case "ELDER_GUARDIAN": |                     "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SHULKER", "SNOWMAN" -> { | ||||||
|             case "GHAST": |  | ||||||
|             case "MAGMA_CUBE": |  | ||||||
|             case "SQUID": |  | ||||||
|             case "PIG_ZOMBIE": |  | ||||||
|             case "HOGLIN": |  | ||||||
|             case "ZOMBIFIED_PIGLIN": |  | ||||||
|             case "PIGLIN": |  | ||||||
|             case "PIGLIN_BRUTE": |  | ||||||
|             case "ZOMBIE": |  | ||||||
|             case "WITHER": |  | ||||||
|             case "WITCH": |  | ||||||
|             case "SPIDER": |  | ||||||
|             case "CAVE_SPIDER": |  | ||||||
|             case "SILVERFISH": |  | ||||||
|             case "GIANT": |  | ||||||
|             case "ENDERMAN": |  | ||||||
|             case "CREEPER": |  | ||||||
|             case "BLAZE": |  | ||||||
|             case "SHULKER": |  | ||||||
|             case "SNOWMAN": |  | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|             case "IRON_GOLEM": |             } | ||||||
|  |             case "IRON_GOLEM" -> { | ||||||
|                 if (((IronGolem) entity).isPlayerCreated()) { |                 if (((IronGolem) entity).isPlayerCreated()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
|                 } else { |                 } else { | ||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|  |             } | ||||||
|             // END LIVING // |             // END LIVING // | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -472,20 +415,15 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|         } |         } | ||||||
|         Entity entity; |         Entity entity; | ||||||
|         switch (this.getType().toString()) { |         switch (this.getType().toString()) { | ||||||
|             case "DROPPED_ITEM": |             case "DROPPED_ITEM" -> { | ||||||
|                 return world.dropItem(location, this.stack); |                 return world.dropItem(location, this.stack); | ||||||
|             case "PLAYER": |             } | ||||||
|             case "LEASH_HITCH": |             case "PLAYER", "LEASH_HITCH" -> { | ||||||
|                 return null; |                 return null; | ||||||
|             case "ITEM_FRAME": |             } | ||||||
|                 entity = world.spawn(location, ItemFrame.class); |             case "ITEM_FRAME" -> entity = world.spawn(location, ItemFrame.class); | ||||||
|                 break; |             case "PAINTING" -> entity = world.spawn(location, Painting.class); | ||||||
|             case "PAINTING": |             default -> entity = world.spawnEntity(location, this.getType()); | ||||||
|                 entity = world.spawn(location, Painting.class); |  | ||||||
|                 break; |  | ||||||
|             default: |  | ||||||
|                 entity = world.spawnEntity(location, this.getType()); |  | ||||||
|                 break; |  | ||||||
|         } |         } | ||||||
|         if (this.depth == 0) { |         if (this.depth == 0) { | ||||||
|             return entity; |             return entity; | ||||||
| @@ -513,72 +451,46 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|             entity.setGravity(false); |             entity.setGravity(false); | ||||||
|         } |         } | ||||||
|         switch (entity.getType().toString()) { |         switch (entity.getType().toString()) { | ||||||
|             case "BOAT": |             case "BOAT" -> { | ||||||
|                 Boat boat = (Boat) entity; |                 Boat boat = (Boat) entity; | ||||||
|                 boat.setWoodType(TreeSpecies.values()[dataByte]); |                 boat.setWoodType(TreeSpecies.values()[dataByte]); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "SLIME": |             } | ||||||
|  |             case "SLIME" -> { | ||||||
|                 ((Slime) entity).setSize(this.dataByte); |                 ((Slime) entity).setSize(this.dataByte); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ARROW": |             } | ||||||
|             case "EGG": |             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", | ||||||
|             case "ENDER_CRYSTAL": |                     "FIREBALL", "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", | ||||||
|             case "ENDER_PEARL": |                     "MINECART_MOB_SPAWNER", "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SMALL_FIREBALL", "SNOWBALL", | ||||||
|             case "ENDER_SIGNAL": |                     "SPLASH_POTION", "THROWN_EXP_BOTTLE", "SPECTRAL_ARROW", "SHULKER_BULLET", "AREA_EFFECT_CLOUD", | ||||||
|             case "DROPPED_ITEM": |                     "DRAGON_FIREBALL", "WITHER_SKULL", "MINECART_FURNACE", "LLAMA_SPIT", "TRIDENT", "UNKNOWN" -> { | ||||||
|             case "EXPERIENCE_ORB": |  | ||||||
|             case "FALLING_BLOCK": |  | ||||||
|             case "FIREBALL": |  | ||||||
|             case "FIREWORK": |  | ||||||
|             case "FISHING_HOOK": |  | ||||||
|             case "LEASH_HITCH": |  | ||||||
|             case "LIGHTNING": |  | ||||||
|             case "MINECART": |  | ||||||
|             case "MINECART_COMMAND": |  | ||||||
|             case "MINECART_MOB_SPAWNER": |  | ||||||
|             case "MINECART_TNT": |  | ||||||
|             case "PLAYER": |  | ||||||
|             case "PRIMED_TNT": |  | ||||||
|             case "SMALL_FIREBALL": |  | ||||||
|             case "SNOWBALL": |  | ||||||
|             case "SPLASH_POTION": |  | ||||||
|             case "THROWN_EXP_BOTTLE": |  | ||||||
|             case "SPECTRAL_ARROW": |  | ||||||
|             case "SHULKER_BULLET": |  | ||||||
|             case "AREA_EFFECT_CLOUD": |  | ||||||
|             case "DRAGON_FIREBALL": |  | ||||||
|             case "WITHER_SKULL": |  | ||||||
|             case "MINECART_FURNACE": |  | ||||||
|             case "LLAMA_SPIT": |  | ||||||
|             case "TRIDENT": |  | ||||||
|             case "UNKNOWN": |  | ||||||
|                 // Do this stuff later |                 // Do this stuff later | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // MISC // |             // MISC // | ||||||
|             case "ITEM_FRAME": |             case "ITEM_FRAME" -> { | ||||||
|                 ItemFrame itemframe = (ItemFrame) entity; |                 ItemFrame itemframe = (ItemFrame) entity; | ||||||
|                 itemframe.setRotation(Rotation.values()[this.dataByte]); |                 itemframe.setRotation(Rotation.values()[this.dataByte]); | ||||||
|                 itemframe.setItem(this.stack); |                 itemframe.setItem(this.stack); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "PAINTING": |             } | ||||||
|  |             case "PAINTING" -> { | ||||||
|                 Painting painting = (Painting) entity; |                 Painting painting = (Painting) entity; | ||||||
|                 painting.setFacingDirection(BlockFace.values()[this.dataByte], true); |                 painting.setFacingDirection(BlockFace.values()[this.dataByte], true); | ||||||
|                 painting.setArt(Art.getByName(this.dataString), true); |                 painting.setArt(Art.getByName(this.dataString), true); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END MISC // |             // END MISC // | ||||||
|             // INVENTORY HOLDER // |             // INVENTORY HOLDER // | ||||||
|             case "MINECART_CHEST": |             case "MINECART_CHEST", "MINECART_HOPPER" -> { | ||||||
|             case "MINECART_HOPPER": |  | ||||||
|                 restoreInventory((InventoryHolder) entity); |                 restoreInventory((InventoryHolder) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // START LIVING ENTITY // |             // START LIVING ENTITY // | ||||||
|             // START AGEABLE // |             // START AGEABLE // | ||||||
|             // START TAMEABLE // |             // START TAMEABLE // | ||||||
|             case "HORSE": |             case "HORSE", "LLAMA", "SKELETON_HORSE", "DONKEY", "MULE" -> { | ||||||
|             case "LLAMA": |  | ||||||
|             case "SKELETON_HORSE": |  | ||||||
|             case "DONKEY": |  | ||||||
|             case "MULE": |  | ||||||
|                 AbstractHorse horse = (AbstractHorse) entity; |                 AbstractHorse horse = (AbstractHorse) entity; | ||||||
|                 horse.setJumpStrength(this.horse.jump); |                 horse.setJumpStrength(this.horse.jump); | ||||||
|                 if (horse instanceof ChestedHorse) { |                 if (horse instanceof ChestedHorse) { | ||||||
| @@ -593,15 +505,16 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 restoreLiving(horse); |                 restoreLiving(horse); | ||||||
|                 restoreInventory(horse); |                 restoreInventory(horse); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END INVENTORY HOLDER // |             // END INVENTORY HOLDER // | ||||||
|             case "WOLF": |             case "WOLF", "OCELOT" -> { | ||||||
|             case "OCELOT": |  | ||||||
|                 restoreTameable((Tameable) entity); |                 restoreTameable((Tameable) entity); | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreAgeable((Ageable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "SHEEP": |             case "SHEEP" -> { | ||||||
|                 Sheep sheep = (Sheep) entity; |                 Sheep sheep = (Sheep) entity; | ||||||
|                 if (this.dataByte == 1) { |                 if (this.dataByte == 1) { | ||||||
|                     sheep.setSheared(true); |                     sheep.setSheared(true); | ||||||
| @@ -612,25 +525,22 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 restoreAgeable(sheep); |                 restoreAgeable(sheep); | ||||||
|                 restoreLiving(sheep); |                 restoreLiving(sheep); | ||||||
|                 return sheep; |                 return sheep; | ||||||
|             case "VILLAGER": |             } | ||||||
|             case "CHICKEN": |             case "VILLAGER", "CHICKEN", "COW", "TURTLE", "POLAR_BEAR", "MUSHROOM_COW", "PIG" -> { | ||||||
|             case "COW": |  | ||||||
|             case "TURTLE": |  | ||||||
|             case "POLAR_BEAR": |  | ||||||
|             case "MUSHROOM_COW": |  | ||||||
|             case "PIG": |  | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreAgeable((Ageable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "RABBIT": |             case "RABBIT" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((Rabbit) entity).setRabbitType(Rabbit.Type.values()[this.dataByte]); |                     ((Rabbit) entity).setRabbitType(Rabbit.Type.values()[this.dataByte]); | ||||||
|                 } |                 } | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreAgeable((Ageable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ARMOR_STAND": |             } | ||||||
|  |             case "ARMOR_STAND" -> { | ||||||
|                 // CHECK positions |                 // CHECK positions | ||||||
|                 ArmorStand stand = (ArmorStand) entity; |                 ArmorStand stand = (ArmorStand) entity; | ||||||
|                 if (this.inventory[0] != null) { |                 if (this.inventory[0] != null) { | ||||||
| @@ -700,56 +610,38 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 } |                 } | ||||||
|                 restoreLiving(stand); |                 restoreLiving(stand); | ||||||
|                 return stand; |                 return stand; | ||||||
|             case "BAT": |             } | ||||||
|  |             case "BAT" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((Bat) entity).setAwake(true); |                     ((Bat) entity).setAwake(true); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ENDER_DRAGON": |             } | ||||||
|  |             case "ENDER_DRAGON" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((EnderDragon) entity).setPhase(EnderDragon.Phase.values()[this.dataByte]); |                     ((EnderDragon) entity).setPhase(EnderDragon.Phase.values()[this.dataByte]); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ENDERMITE": |             } | ||||||
|             case "GHAST": |             case "ENDERMITE", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { | ||||||
|             case "MAGMA_CUBE": |  | ||||||
|             case "SQUID": |  | ||||||
|             case "PIG_ZOMBIE": |  | ||||||
|             case "HOGLIN": |  | ||||||
|             case "PIGLIN": |  | ||||||
|             case "ZOMBIFIED_PIGLIN": |  | ||||||
|             case "PIGLIN_BRUTE": |  | ||||||
|             case "ZOMBIE": |  | ||||||
|             case "WITHER": |  | ||||||
|             case "WITCH": |  | ||||||
|             case "SPIDER": |  | ||||||
|             case "CAVE_SPIDER": |  | ||||||
|             case "SILVERFISH": |  | ||||||
|             case "GIANT": |  | ||||||
|             case "ENDERMAN": |  | ||||||
|             case "CREEPER": |  | ||||||
|             case "BLAZE": |  | ||||||
|             case "SNOWMAN": |  | ||||||
|             case "SHULKER": |  | ||||||
|             case "GUARDIAN": |  | ||||||
|             case "ELDER_GUARDIAN": |  | ||||||
|             case "SKELETON": |  | ||||||
|             case "WITHER_SKELETON": |  | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "IRON_GOLEM": |             } | ||||||
|  |             case "IRON_GOLEM" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((IronGolem) entity).setPlayerCreated(true); |                     ((IronGolem) entity).setPlayerCreated(true); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 if (Settings.DEBUG) { |                 if (Settings.DEBUG) { | ||||||
|                     LOGGER.info("Could not identify entity: {}", entity.getType()); |                     LOGGER.info("Could not identify entity: {}", entity.getType()); | ||||||
|                 } |                 } | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END LIVING |             // END LIVING | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -25,17 +18,17 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.generator; | package com.plotsquared.bukkit.generator; | ||||||
|  |  | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.bukkit.queue.LimitedRegionWrapperQueue; | ||||||
|  | import com.plotsquared.core.generator.HybridPlotWorld; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.location.UncheckedWorldLocation; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; |  | ||||||
| import com.sk89q.worldedit.bukkit.BukkitWorld; |  | ||||||
| import org.bukkit.Chunk; |  | ||||||
| import org.bukkit.World; |  | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
|  | import org.bukkit.generator.LimitedRegion; | ||||||
|  | import org.bukkit.generator.WorldInfo; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
| @@ -43,32 +36,40 @@ import java.util.Random; | |||||||
| final class BlockStatePopulator extends BlockPopulator { | final class BlockStatePopulator extends BlockPopulator { | ||||||
|  |  | ||||||
|     private final IndependentPlotGenerator plotGenerator; |     private final IndependentPlotGenerator plotGenerator; | ||||||
|     private final PlotAreaManager plotAreaManager; |  | ||||||
|  |  | ||||||
|     private QueueCoordinator queue; |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @since 6.9.0 | ||||||
|  |      */ | ||||||
|     public BlockStatePopulator( |     public BlockStatePopulator( | ||||||
|             final @NonNull IndependentPlotGenerator plotGenerator, |             final @NonNull IndependentPlotGenerator plotGenerator | ||||||
|             final @NonNull PlotAreaManager plotAreaManager |  | ||||||
|     ) { |     ) { | ||||||
|         this.plotGenerator = plotGenerator; |         this.plotGenerator = plotGenerator; | ||||||
|         this.plotAreaManager = plotAreaManager; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void populate(final @NonNull World world, final @NonNull Random random, final @NonNull Chunk source) { |     public void populate( | ||||||
|         if (this.queue == null) { |             @NonNull final WorldInfo worldInfo, | ||||||
|             this.queue = PlotSquared.platform().globalBlockQueue().getNewQueue(new BukkitWorld(world)); |             @NonNull final Random random, | ||||||
|         } |             final int chunkX, | ||||||
|         final PlotArea area = this.plotAreaManager.getPlotArea(world.getName(), null); |             final int chunkZ, | ||||||
|         if (area == null) { |             @NonNull final LimitedRegion limitedRegion | ||||||
|  |     ) { | ||||||
|  |         PlotArea area = UncheckedWorldLocation.at(worldInfo.getName(), chunkX << 4, 0, chunkZ << 4).getPlotArea(); | ||||||
|  |         if (area == null || (area instanceof HybridPlotWorld hpw && !hpw.populationNeeded()) || area instanceof SinglePlotArea) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         final ChunkWrapper wrap = new ChunkWrapper(area.getWorldName(), source.getX(), source.getZ()); |         LimitedRegionWrapperQueue wrapped = new LimitedRegionWrapperQueue(limitedRegion); | ||||||
|         final ScopedQueueCoordinator chunk = this.queue.getForChunk(wrap.x, wrap.z); |         // It is possible for the region to be larger than the chunk, but there is no reason for P2 to need to populate | ||||||
|         if (this.plotGenerator.populateChunk(chunk, area)) { |         // outside of the actual chunk area. | ||||||
|             this.queue.enqueue(); |         Location min = UncheckedWorldLocation.at(worldInfo.getName(), chunkX << 4, worldInfo.getMinHeight(), chunkZ << 4); | ||||||
|         } |         Location max = UncheckedWorldLocation.at( | ||||||
|  |                 worldInfo.getName(), | ||||||
|  |                 (chunkX << 4) + 15, | ||||||
|  |                 worldInfo.getMaxHeight(), | ||||||
|  |                 (chunkZ << 4) + 15 | ||||||
|  |         ); | ||||||
|  |         ZeroedDelegateScopedQueueCoordinator offsetChunkQueue = new ZeroedDelegateScopedQueueCoordinator(wrapped, min, max); | ||||||
|  |         this.plotGenerator.populateChunk(offsetChunkQueue, area); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -25,7 +18,11 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.generator; | package com.plotsquared.bukkit.generator; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.generator.AugmentedUtils; | import com.plotsquared.core.generator.AugmentedUtils; | ||||||
|  | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
|  | import com.sk89q.worldedit.util.SideEffectSet; | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| @@ -52,7 +49,14 @@ public class BukkitAugmentedGenerator extends BlockPopulator { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void populate(@NonNull World world, @NonNull Random random, @NonNull Chunk source) { |     public void populate(@NonNull World world, @NonNull Random random, @NonNull Chunk source) { | ||||||
|         AugmentedUtils.generate(source, world.getName(), source.getX(), source.getZ(), null); |         QueueCoordinator queue = PlotSquared.platform().globalBlockQueue().getNewQueue(BukkitAdapter.adapt(world)); | ||||||
|  |         // The chunk is already loaded and we do not want to load the chunk in "fully" by using any PaperLib methods. | ||||||
|  |         queue.setForceSync(true); | ||||||
|  |         queue.setSideEffectSet(SideEffectSet.none()); | ||||||
|  |         queue.setBiomesEnabled(false); | ||||||
|  |         queue.setChunkObject(source); | ||||||
|  |         AugmentedUtils.generateChunk(world.getName(), source.getX(), source.getZ(), queue); | ||||||
|  |         queue.enqueue(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -27,29 +20,48 @@ package com.plotsquared.bukkit.generator; | |||||||
|  |  | ||||||
| import com.plotsquared.bukkit.queue.GenChunk; | import com.plotsquared.bukkit.queue.GenChunk; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
|  | import com.plotsquared.core.generator.ClassicPlotWorld; | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.generator.SingleWorldGenerator; | import com.plotsquared.core.generator.SingleWorldGenerator; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
|  | import com.plotsquared.core.location.UncheckedWorldLocation; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
|  | import com.sk89q.worldedit.math.BlockVector3; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
|  | import org.bukkit.HeightMap; | ||||||
|  | import org.bukkit.NamespacedKey; | ||||||
|  | import org.bukkit.Registry; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; | import org.bukkit.block.Biome; | ||||||
|  | import org.bukkit.generator.BiomeProvider; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| import org.bukkit.generator.ChunkGenerator; | import org.bukkit.generator.ChunkGenerator; | ||||||
|  | import org.bukkit.generator.WorldInfo; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  | import org.jetbrains.annotations.NotNull; | ||||||
|  | import org.jetbrains.annotations.Nullable; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.EnumSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
| public class BukkitPlotGenerator extends ChunkGenerator | import static java.util.function.Predicate.not; | ||||||
|         implements GeneratorWrapper<ChunkGenerator> { |  | ||||||
|  | public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | ||||||
|  |  | ||||||
|  |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + BukkitPlotGenerator.class.getSimpleName()); | ||||||
|  |  | ||||||
|     @SuppressWarnings("unused") |     @SuppressWarnings("unused") | ||||||
|     public final boolean PAPER_ASYNC_SAFE = true; |     public final boolean PAPER_ASYNC_SAFE = true; | ||||||
| @@ -59,9 +71,15 @@ public class BukkitPlotGenerator extends ChunkGenerator | |||||||
|     private final ChunkGenerator platformGenerator; |     private final ChunkGenerator platformGenerator; | ||||||
|     private final boolean full; |     private final boolean full; | ||||||
|     private final String levelName; |     private final String levelName; | ||||||
|  |     private final boolean useNewGenerationMethods; | ||||||
|  |     private final BiomeProvider biomeProvider; | ||||||
|     private List<BlockPopulator> populators; |     private List<BlockPopulator> populators; | ||||||
|     private boolean loaded = false; |     private boolean loaded = false; | ||||||
|  |  | ||||||
|  |     private PlotArea lastPlotArea; | ||||||
|  |     private int lastChunkX = Integer.MIN_VALUE; | ||||||
|  |     private int lastChunkZ = Integer.MIN_VALUE; | ||||||
|  |  | ||||||
|     public BukkitPlotGenerator( |     public BukkitPlotGenerator( | ||||||
|             final @NonNull String name, |             final @NonNull String name, | ||||||
|             final @NonNull IndependentPlotGenerator generator, |             final @NonNull IndependentPlotGenerator generator, | ||||||
| @@ -72,20 +90,30 @@ public class BukkitPlotGenerator extends ChunkGenerator | |||||||
|         this.plotGenerator = generator; |         this.plotGenerator = generator; | ||||||
|         this.platformGenerator = this; |         this.platformGenerator = this; | ||||||
|         this.populators = new ArrayList<>(); |         this.populators = new ArrayList<>(); | ||||||
|         this.populators.add(new BlockStatePopulator(this.plotGenerator, this.plotAreaManager)); |         int minecraftMinorVersion = PlotSquared.platform().serverVersion()[1]; | ||||||
|  |         if (minecraftMinorVersion >= 17) { | ||||||
|  |             this.populators.add(new BlockStatePopulator(this.plotGenerator)); | ||||||
|  |         } else { | ||||||
|  |             this.populators.add(new LegacyBlockStatePopulator(this.plotGenerator)); | ||||||
|  |         } | ||||||
|         this.full = true; |         this.full = true; | ||||||
|  |         this.useNewGenerationMethods = PlotSquared.platform().serverVersion()[1] >= 19; | ||||||
|  |         this.biomeProvider = new BukkitPlotBiomeProvider(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public BukkitPlotGenerator(final String world, final ChunkGenerator cg, final @NonNull PlotAreaManager plotAreaManager) { |     public BukkitPlotGenerator(final String world, final ChunkGenerator cg, final @NonNull PlotAreaManager plotAreaManager) { | ||||||
|         if (cg instanceof BukkitPlotGenerator) { |         if (cg instanceof BukkitPlotGenerator) { | ||||||
|             throw new IllegalArgumentException("ChunkGenerator: " + cg.getClass().getName() |             throw new IllegalArgumentException("ChunkGenerator: " + cg | ||||||
|                     + " is already a BukkitPlotGenerator!"); |                     .getClass() | ||||||
|  |                     .getName() + " is already a BukkitPlotGenerator!"); | ||||||
|         } |         } | ||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|         this.levelName = world; |         this.levelName = world; | ||||||
|         this.full = false; |         this.full = false; | ||||||
|         this.platformGenerator = cg; |         this.platformGenerator = cg; | ||||||
|         this.plotGenerator = new DelegatePlotGenerator(cg, world); |         this.plotGenerator = new DelegatePlotGenerator(cg, world); | ||||||
|  |         this.useNewGenerationMethods = PlotSquared.platform().serverVersion()[1] >= 19; | ||||||
|  |         this.biomeProvider = null; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -111,32 +139,9 @@ public class BukkitPlotGenerator extends ChunkGenerator | |||||||
|     @Override |     @Override | ||||||
|     public @NonNull List<BlockPopulator> getDefaultPopulators(@NonNull World world) { |     public @NonNull List<BlockPopulator> getDefaultPopulators(@NonNull World world) { | ||||||
|         try { |         try { | ||||||
|             if (!this.loaded) { |             checkLoaded(world); | ||||||
|                 String name = world.getName(); |  | ||||||
|                 PlotSquared.get().loadWorld(name, this); |  | ||||||
|                 final Set<PlotArea> areas = this.plotAreaManager.getPlotAreasSet(name); |  | ||||||
|                 if (!areas.isEmpty()) { |  | ||||||
|                     PlotArea area = areas.iterator().next(); |  | ||||||
|                     if (!area.isMobSpawning()) { |  | ||||||
|                         if (!area.isSpawnEggs()) { |  | ||||||
|                             world.setSpawnFlags(false, false); |  | ||||||
|                         } |  | ||||||
|                         world.setAmbientSpawnLimit(0); |  | ||||||
|                         world.setAnimalSpawnLimit(0); |  | ||||||
|                         world.setMonsterSpawnLimit(0); |  | ||||||
|                         world.setWaterAnimalSpawnLimit(0); |  | ||||||
|                     } else { |  | ||||||
|                         world.setSpawnFlags(true, true); |  | ||||||
|                         world.setAmbientSpawnLimit(-1); |  | ||||||
|                         world.setAnimalSpawnLimit(-1); |  | ||||||
|                         world.setMonsterSpawnLimit(-1); |  | ||||||
|                         world.setWaterAnimalSpawnLimit(-1); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|                 this.loaded = true; |  | ||||||
|             } |  | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error attempting to load world into PlotSquared.", e); | ||||||
|         } |         } | ||||||
|         ArrayList<BlockPopulator> toAdd = new ArrayList<>(); |         ArrayList<BlockPopulator> toAdd = new ArrayList<>(); | ||||||
|         List<BlockPopulator> existing = world.getPopulators(); |         List<BlockPopulator> existing = world.getPopulators(); | ||||||
| @@ -153,20 +158,161 @@ public class BukkitPlotGenerator extends ChunkGenerator | |||||||
|         return toAdd; |         return toAdd; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     // Extracted to synchronized method for thread-safety, preventing multiple internal world load calls | ||||||
|     public @NonNull ChunkData generateChunkData( |     private synchronized void checkLoaded(@NonNull World world) { | ||||||
|             @NonNull World world, @NonNull Random random, int x, int z, |         // Do not attempt to load configurations until WorldEdit has a platform ready. | ||||||
|             @NonNull BiomeGrid biome |         if (!PlotSquared.get().isWeInitialised()) { | ||||||
|     ) { |             return; | ||||||
|  |         } | ||||||
|  |         if (!this.loaded) { | ||||||
|  |             String name = world.getName(); | ||||||
|  |             PlotSquared.get().loadWorld(name, this); | ||||||
|  |             final Set<PlotArea> areas = this.plotAreaManager.getPlotAreasSet(name); | ||||||
|  |             if (!areas.isEmpty()) { | ||||||
|  |                 PlotArea area = areas.iterator().next(); | ||||||
|  |                 if (!area.isMobSpawning()) { | ||||||
|  |                     if (!area.isSpawnEggs()) { | ||||||
|  |                         world.setSpawnFlags(false, false); | ||||||
|  |                     } | ||||||
|  |                     setSpawnLimits(world, 0); | ||||||
|  |                 } else { | ||||||
|  |                     world.setSpawnFlags(true, true); | ||||||
|  |                     setSpawnLimits(world, -1); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             this.loaded = true; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|         GenChunk result = new GenChunk(); |     @SuppressWarnings("deprecation") // Kept for compatibility with <=1.17.1 | ||||||
|  |     private void setSpawnLimits(@NonNull World world, int limit) { | ||||||
|  |         world.setAmbientSpawnLimit(limit); | ||||||
|  |         world.setAnimalSpawnLimit(limit); | ||||||
|  |         world.setMonsterSpawnLimit(limit); | ||||||
|  |         world.setWaterAnimalSpawnLimit(limit); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void generateNoise( | ||||||
|  |             @NotNull final WorldInfo worldInfo, | ||||||
|  |             @NotNull final Random random, | ||||||
|  |             final int chunkX, | ||||||
|  |             final int chunkZ, | ||||||
|  |             @NotNull final ChunkData chunkData | ||||||
|  |     ) { | ||||||
|  |         if (this.platformGenerator != this) { | ||||||
|  |             this.platformGenerator.generateNoise(worldInfo, random, chunkX, chunkZ, chunkData); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         int minY = chunkData.getMinHeight(); | ||||||
|  |         int maxY = chunkData.getMaxHeight(); | ||||||
|  |         GenChunk result = new GenChunk(minY, maxY); | ||||||
|  |         // Set the chunk location | ||||||
|  |         result.setChunk(new ChunkWrapper(worldInfo.getName(), chunkX, chunkZ)); | ||||||
|  |         // Set the result data | ||||||
|  |         result.setChunkData(chunkData); | ||||||
|  |         result.result = null; | ||||||
|  |  | ||||||
|  |         // Catch any exceptions (as exceptions usually thrown) | ||||||
|  |         try { | ||||||
|  |             generate(BlockVector2.at(chunkX, chunkZ), worldInfo.getName(), result, false); | ||||||
|  |         } catch (Throwable e) { | ||||||
|  |             LOGGER.error("Error attempting to generate chunk.", e); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void generateSurface( | ||||||
|  |             @NotNull final WorldInfo worldInfo, | ||||||
|  |             @NotNull final Random random, | ||||||
|  |             final int chunkX, | ||||||
|  |             final int chunkZ, | ||||||
|  |             @NotNull final ChunkData chunkData | ||||||
|  |     ) { | ||||||
|  |         if (platformGenerator != this) { | ||||||
|  |             platformGenerator.generateSurface(worldInfo, random, chunkX, chunkZ, chunkData); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void generateBedrock( | ||||||
|  |             @NotNull final WorldInfo worldInfo, | ||||||
|  |             @NotNull final Random random, | ||||||
|  |             final int chunkX, | ||||||
|  |             final int chunkZ, | ||||||
|  |             @NotNull final ChunkData chunkData | ||||||
|  |     ) { | ||||||
|  |         if (platformGenerator != this) { | ||||||
|  |             platformGenerator.generateBedrock(worldInfo, random, chunkX, chunkZ, chunkData); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void generateCaves( | ||||||
|  |             @NotNull final WorldInfo worldInfo, | ||||||
|  |             @NotNull final Random random, | ||||||
|  |             final int chunkX, | ||||||
|  |             final int chunkZ, | ||||||
|  |             @NotNull final ChunkData chunkData | ||||||
|  |     ) { | ||||||
|  |         if (platformGenerator != this) { | ||||||
|  |             platformGenerator.generateCaves(worldInfo, random, chunkX, chunkZ, chunkData); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public @Nullable BiomeProvider getDefaultBiomeProvider(@NotNull final WorldInfo worldInfo) { | ||||||
|  |         if (platformGenerator != this) { | ||||||
|  |             return platformGenerator.getDefaultBiomeProvider(worldInfo); | ||||||
|  |         } | ||||||
|  |         return biomeProvider; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int getBaseHeight( | ||||||
|  |             @NotNull final WorldInfo worldInfo, | ||||||
|  |             @NotNull final Random random, | ||||||
|  |             final int x, | ||||||
|  |             final int z, | ||||||
|  |             @NotNull final HeightMap heightMap | ||||||
|  |     ) { | ||||||
|  |         PlotArea area = getPlotArea(worldInfo.getName(), x, z); | ||||||
|  |         if (area instanceof ClassicPlotWorld cpw) { | ||||||
|  |             // Default to plot height being the heighest point before decoration (i.e. roads, walls etc.) | ||||||
|  |             return cpw.PLOT_HEIGHT; | ||||||
|  |         } | ||||||
|  |         return super.getBaseHeight(worldInfo, random, x, z, heightMap); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The entire method is deprecated, but kept for compatibility with versions lower than or equal to 1.16.2. | ||||||
|  |      * The method will be removed in future versions, because WorldEdit and FastAsyncWorldEdit only support the latest point | ||||||
|  |      * release. | ||||||
|  |      */ | ||||||
|  |     @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2 | ||||||
|  |     @Override | ||||||
|  |     @Deprecated(since = "7.0.0") | ||||||
|  |     public @NonNull ChunkData generateChunkData( | ||||||
|  |             @NonNull World world, @NonNull Random random, int x, int z, @NonNull BiomeGrid biome | ||||||
|  |     ) { | ||||||
|  |         if (useNewGenerationMethods) { | ||||||
|  |             if (this.platformGenerator != this) { | ||||||
|  |                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); | ||||||
|  |             } else { | ||||||
|  |                 // Throw exception to be caught by the server that indicates the new generation API is being used. | ||||||
|  |                 throw new UnsupportedOperationException("Using new generation methods. This method is unsupported."); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         int minY = BukkitWorld.getMinWorldHeight(world); | ||||||
|  |         int maxY = BukkitWorld.getMaxWorldHeight(world); | ||||||
|  |         GenChunk result = new GenChunk(minY, maxY); | ||||||
|         if (this.getPlotGenerator() instanceof SingleWorldGenerator) { |         if (this.getPlotGenerator() instanceof SingleWorldGenerator) { | ||||||
|             if (result.getChunkData() != null) { |             if (result.getChunkData() != null) { | ||||||
|                 for (int chunkX = 0; chunkX < 16; chunkX++) { |                 for (int chunkX = 0; chunkX < 16; chunkX++) { | ||||||
|                     for (int chunkZ = 0; chunkZ < 16; chunkZ++) { |                     for (int chunkZ = 0; chunkZ < 16; chunkZ++) { | ||||||
|                         for (int y = 0; y < world.getMaxHeight(); y++) { |                         for (int y = minY; y < maxY; y++) { | ||||||
|                             biome.setBiome(chunkX, y, chunkZ, Biome.PLAINS); |                             biome.setBiome(chunkX, y, chunkZ, Biome.PLAINS); | ||||||
|  |  | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -186,37 +332,32 @@ public class BukkitPlotGenerator extends ChunkGenerator | |||||||
|             if (this.platformGenerator != this) { |             if (this.platformGenerator != this) { | ||||||
|                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); |                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); | ||||||
|             } else { |             } else { | ||||||
|                 generate(BlockVector2.at(x, z), world, result); |                 generate(BlockVector2.at(x, z), world.getName(), result, true); | ||||||
|             } |             } | ||||||
|         } catch (Throwable e) { |         } catch (Throwable e) { | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error attempting to load world into PlotSquared.", e); | ||||||
|         } |         } | ||||||
|         // Return the result data |         // Return the result data | ||||||
|         return result.getChunkData(); |         return result.getChunkData(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void generate(BlockVector2 loc, World world, ScopedQueueCoordinator result) { |     private void generate(BlockVector2 loc, String world, ZeroedDelegateScopedQueueCoordinator result, boolean biomes) { | ||||||
|         // Load if improperly loaded |         // Load if improperly loaded | ||||||
|         if (!this.loaded) { |         if (!this.loaded) { | ||||||
|             String name = world.getName(); |             synchronized (this) { | ||||||
|             PlotSquared.get().loadWorld(name, this); |                 PlotSquared.get().loadWorld(world, this); | ||||||
|             this.loaded = true; |             } | ||||||
|         } |         } | ||||||
|         // Process the chunk |         // Process the chunk | ||||||
|         if (ChunkManager.preProcessChunk(loc, result)) { |         if (ChunkManager.preProcessChunk(loc, result)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         PlotArea area = this.plotAreaManager.getPlotArea(world.getName(), null); |         PlotArea area = getPlotArea(world, loc.getX(), loc.getZ()); | ||||||
|         if (area == null && (area = this.plotAreaManager.getPlotArea(this.levelName, null)) == null) { |  | ||||||
|             throw new IllegalStateException( |  | ||||||
|                     "Cannot regenerate chunk that does not belong to a plot area." + " Location: " + loc |  | ||||||
|                             + ", world: " + world); |  | ||||||
|         } |  | ||||||
|         try { |         try { | ||||||
|             this.plotGenerator.generateChunk(result, area); |             this.plotGenerator.generateChunk(result, area, biomes); | ||||||
|         } catch (Throwable e) { |         } catch (Throwable e) { | ||||||
|             // Recover from generator error |             // Recover from generator error | ||||||
|             e.printStackTrace(); |             LOGGER.error("Error attempting to generate chunk.", e); | ||||||
|         } |         } | ||||||
|         ChunkManager.postProcessChunk(loc, result); |         ChunkManager.postProcessChunk(loc, result); | ||||||
|     } |     } | ||||||
| @@ -270,4 +411,63 @@ public class BukkitPlotGenerator extends ChunkGenerator | |||||||
|         return this.levelName; |         return this.levelName; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private synchronized PlotArea getPlotArea(String name, int chunkX, int chunkZ) { | ||||||
|  |         // Load if improperly loaded | ||||||
|  |         if (!this.loaded) { | ||||||
|  |             PlotSquared.get().loadWorld(name, this); | ||||||
|  |             // Do not set loaded to true as we want to ensure spawn limits are set when "loading" is actually able to be | ||||||
|  |             // completed properly. | ||||||
|  |         } | ||||||
|  |         if (lastPlotArea != null && name.equals(this.levelName) && chunkX == lastChunkX && chunkZ == lastChunkZ) { | ||||||
|  |             return lastPlotArea; | ||||||
|  |         } | ||||||
|  |         BlockVector3 loc = BlockVector3.at(chunkX << 4, 0, chunkZ << 4); | ||||||
|  |         if (lastPlotArea != null && lastPlotArea.getRegion().contains(loc) && lastPlotArea.getRegion().contains(loc)) { | ||||||
|  |             return lastPlotArea; | ||||||
|  |         } | ||||||
|  |         PlotArea area = UncheckedWorldLocation.at(name, loc).getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             throw new IllegalStateException(String.format( | ||||||
|  |                     "Cannot generate chunk that does not belong to a plot area. World: %s", | ||||||
|  |                     name | ||||||
|  |             )); | ||||||
|  |         } | ||||||
|  |         this.lastChunkX = chunkX; | ||||||
|  |         this.lastChunkZ = chunkZ; | ||||||
|  |         return this.lastPlotArea = area; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Biome provider should never need to be accessed outside of this class. | ||||||
|  |      */ | ||||||
|  |     private final class BukkitPlotBiomeProvider extends BiomeProvider { | ||||||
|  |  | ||||||
|  |         private static final List<Biome> BIOMES; | ||||||
|  |  | ||||||
|  |         static { | ||||||
|  |             Set<Biome> disabledBiomes = EnumSet.of(Biome.CUSTOM); | ||||||
|  |             if (PlotSquared.platform().serverVersion()[1] <= 19) { | ||||||
|  |                 final Biome cherryGrove = Registry.BIOME.get(NamespacedKey.minecraft("cherry_grove")); | ||||||
|  |                 if (cherryGrove != null) { | ||||||
|  |                     disabledBiomes.add(cherryGrove); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             BIOMES = Arrays.stream(Biome.values()) | ||||||
|  |                     .filter(not(disabledBiomes::contains)) | ||||||
|  |                     .toList(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public @NotNull Biome getBiome(@NotNull final WorldInfo worldInfo, final int x, final int y, final int z) { | ||||||
|  |             PlotArea area = getPlotArea(worldInfo.getName(), x >> 4, z >> 4); | ||||||
|  |             return BukkitAdapter.adapt(plotGenerator.getBiome(area, x, y, z)); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         @Override | ||||||
|  |         public @NotNull List<Biome> getBiomes(@NotNull final WorldInfo worldInfo) { | ||||||
|  |             return BIOMES; // Allow all biomes | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -31,9 +24,10 @@ import com.plotsquared.core.generator.IndependentPlotGenerator; | |||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
|  | import com.sk89q.worldedit.world.biome.BiomeType; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; | import org.bukkit.block.Biome; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| @@ -56,6 +50,11 @@ final class DelegatePlotGenerator extends IndependentPlotGenerator { | |||||||
|     public void initialize(PlotArea area) { |     public void initialize(PlotArea area) { | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public BiomeType getBiome(final PlotArea settings, final int x, final int y, final int z) { | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String getName() { |     public String getName() { | ||||||
|         return this.chunkGenerator.getClass().getName(); |         return this.chunkGenerator.getClass().getName(); | ||||||
| @@ -67,7 +66,7 @@ final class DelegatePlotGenerator extends IndependentPlotGenerator { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void generateChunk(final ScopedQueueCoordinator result, PlotArea settings) { |     public void generateChunk(final ZeroedDelegateScopedQueueCoordinator result, PlotArea settings, boolean biomes) { | ||||||
|         World world = BukkitUtil.getWorld(this.world); |         World world = BukkitUtil.getWorld(this.world); | ||||||
|         Location min = result.getMin(); |         Location min = result.getMin(); | ||||||
|         int chunkX = min.getX() >> 4; |         int chunkX = min.getX() >> 4; | ||||||
| @@ -80,7 +79,8 @@ final class DelegatePlotGenerator extends IndependentPlotGenerator { | |||||||
|                     result.setBiome(x, z, BukkitAdapter.adapt(biome)); |                     result.setBiome(x, z, BukkitAdapter.adapt(biome)); | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 //do not annotate with Override until we discontinue support for 1.4.4 |                 //do not annotate with Override until we discontinue support for 1.4.4 (we no longer support 1.4.4) | ||||||
|  |                 @Override | ||||||
|                 public void setBiome(int x, int y, int z, @NonNull Biome biome) { |                 public void setBiome(int x, int y, int z, @NonNull Biome biome) { | ||||||
|                     result.setBiome(x, z, BukkitAdapter.adapt(biome)); |                     result.setBiome(x, z, BukkitAdapter.adapt(biome)); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,73 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.generator; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
|  | import com.plotsquared.core.generator.HybridPlotWorld; | ||||||
|  | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.location.UncheckedWorldLocation; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
|  | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
|  | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitWorld; | ||||||
|  | import com.sk89q.worldedit.util.SideEffectSet; | ||||||
|  | import org.bukkit.Chunk; | ||||||
|  | import org.bukkit.World; | ||||||
|  | import org.bukkit.generator.BlockPopulator; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.util.Random; | ||||||
|  |  | ||||||
|  | final class LegacyBlockStatePopulator extends BlockPopulator { | ||||||
|  |  | ||||||
|  |     private final IndependentPlotGenerator plotGenerator; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @since 6.9.0 | ||||||
|  |      */ | ||||||
|  |     public LegacyBlockStatePopulator( | ||||||
|  |             final @NonNull IndependentPlotGenerator plotGenerator | ||||||
|  |     ) { | ||||||
|  |         this.plotGenerator = plotGenerator; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void populate(@NonNull final World world, @NonNull final Random random, @NonNull final Chunk source) { | ||||||
|  |         int chunkMinX = source.getX() << 4; | ||||||
|  |         int chunkMinZ = source.getZ() << 4; | ||||||
|  |         PlotArea area = Location.at(world.getName(), chunkMinX, 0, chunkMinZ).getPlotArea(); | ||||||
|  |         if (area == null || (area instanceof HybridPlotWorld hpw && !hpw.populationNeeded()) || area instanceof SinglePlotArea) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         QueueCoordinator queue = PlotSquared.platform().globalBlockQueue().getNewQueue(new BukkitWorld(world)); | ||||||
|  |         queue.setForceSync(true); | ||||||
|  |         queue.setSideEffectSet(SideEffectSet.none()); | ||||||
|  |         queue.setBiomesEnabled(false); | ||||||
|  |         queue.setChunkObject(source); | ||||||
|  |         Location min = UncheckedWorldLocation.at(world.getName(), chunkMinX, world.getMinHeight(), chunkMinZ); | ||||||
|  |         Location max = UncheckedWorldLocation.at(world.getName(), chunkMinX + 15, world.getMaxHeight(), chunkMinZ + 15); | ||||||
|  |         ZeroedDelegateScopedQueueCoordinator offsetChunkQueue = new ZeroedDelegateScopedQueueCoordinator(queue, min, max); | ||||||
|  |         this.plotGenerator.populateChunk(offsetChunkQueue, area); | ||||||
|  |         queue.enqueue(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -62,19 +55,24 @@ import com.plotsquared.core.plot.flag.implementations.VineGrowFlag; | |||||||
| import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.util.task.TaskTime; | import com.plotsquared.core.util.task.TaskTime; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.Component; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| import org.bukkit.GameMode; | import org.bukkit.GameMode; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
|  | import org.bukkit.block.BlockState; | ||||||
| import org.bukkit.block.data.BlockData; | import org.bukkit.block.data.BlockData; | ||||||
|  | import org.bukkit.block.data.type.Dispenser; | ||||||
|  | import org.bukkit.block.data.type.Farmland; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Fireball; | import org.bukkit.entity.Fireball; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -92,6 +90,7 @@ import org.bukkit.event.block.BlockFormEvent; | |||||||
| import org.bukkit.event.block.BlockFromToEvent; | import org.bukkit.event.block.BlockFromToEvent; | ||||||
| import org.bukkit.event.block.BlockGrowEvent; | import org.bukkit.event.block.BlockGrowEvent; | ||||||
| import org.bukkit.event.block.BlockIgniteEvent; | import org.bukkit.event.block.BlockIgniteEvent; | ||||||
|  | import org.bukkit.event.block.BlockMultiPlaceEvent; | ||||||
| import org.bukkit.event.block.BlockPhysicsEvent; | import org.bukkit.event.block.BlockPhysicsEvent; | ||||||
| import org.bukkit.event.block.BlockPistonExtendEvent; | import org.bukkit.event.block.BlockPistonExtendEvent; | ||||||
| import org.bukkit.event.block.BlockPistonRetractEvent; | import org.bukkit.event.block.BlockPistonRetractEvent; | ||||||
| @@ -101,9 +100,9 @@ import org.bukkit.event.block.BlockSpreadEvent; | |||||||
| import org.bukkit.event.block.CauldronLevelChangeEvent; | import org.bukkit.event.block.CauldronLevelChangeEvent; | ||||||
| import org.bukkit.event.block.EntityBlockFormEvent; | import org.bukkit.event.block.EntityBlockFormEvent; | ||||||
| import org.bukkit.event.block.LeavesDecayEvent; | import org.bukkit.event.block.LeavesDecayEvent; | ||||||
|  | import org.bukkit.event.block.MoistureChangeEvent; | ||||||
| import org.bukkit.event.block.SpongeAbsorbEvent; | import org.bukkit.event.block.SpongeAbsorbEvent; | ||||||
| import org.bukkit.event.world.StructureGrowEvent; | import org.bukkit.event.world.StructureGrowEvent; | ||||||
| import org.bukkit.material.Directional; |  | ||||||
| import org.bukkit.projectiles.BlockProjectileSource; | import org.bukkit.projectiles.BlockProjectileSource; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -111,11 +110,31 @@ import org.checkerframework.checker.nullness.qual.NonNull; | |||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
|  | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  | import java.util.stream.Stream; | ||||||
|  |  | ||||||
|  | import static org.bukkit.Tag.CORALS; | ||||||
|  | import static org.bukkit.Tag.CORAL_BLOCKS; | ||||||
|  | import static org.bukkit.Tag.WALL_CORALS; | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener implements Listener { | public class BlockEventListener implements Listener { | ||||||
|  |  | ||||||
|  |     private static final Set<Material> PISTONS = Set.of( | ||||||
|  |             Material.PISTON, | ||||||
|  |             Material.STICKY_PISTON | ||||||
|  |     ); | ||||||
|  |     private static final Set<Material> PHYSICS_BLOCKS = Set.of( | ||||||
|  |             Material.TURTLE_EGG, | ||||||
|  |             Material.TURTLE_SPAWN_EGG | ||||||
|  |     ); | ||||||
|  |     private static final Set<Material> SNOW = Stream.of(Material.values()) // needed as Tag.SNOW isn't present in 1.16.5 | ||||||
|  |             .filter(material -> material.name().contains("SNOW")) | ||||||
|  |             .filter(Material::isBlock) | ||||||
|  |             .collect(Collectors.toUnmodifiableSet()); | ||||||
|  |  | ||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final WorldEdit worldEdit; |     private final WorldEdit worldEdit; | ||||||
|  |  | ||||||
| @@ -154,7 +173,7 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && !area.getRoadFlag(RedstoneFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, RedstoneFlag.class, false)) { | ||||||
|                 event.setNewCurrent(0); |                 event.setNewCurrent(0); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
| @@ -221,50 +240,33 @@ public class BlockEventListener implements Listener { | |||||||
|             plot.debug("Prevented block physics and resent block change because disable-physics = true"); |             plot.debug("Prevented block physics and resent block change because disable-physics = true"); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         switch (event.getChangedType()) { |         if (event.getChangedType() == Material.COMPARATOR) { | ||||||
|             case COMPARATOR: { |  | ||||||
|             if (!plot.getFlag(RedstoneFlag.class)) { |             if (!plot.getFlag(RedstoneFlag.class)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 plot.debug("Prevented comparator update because redstone = false"); |                 plot.debug("Prevented comparator update because redstone = false"); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|             case ANVIL: |         if (PHYSICS_BLOCKS.contains(event.getChangedType())) { | ||||||
|             case DRAGON_EGG: |  | ||||||
|             case GRAVEL: |  | ||||||
|             case SAND: |  | ||||||
|             case TURTLE_EGG: |  | ||||||
|             case TURTLE_HELMET: |  | ||||||
|             case TURTLE_SPAWN_EGG: { |  | ||||||
|             if (plot.getFlag(DisablePhysicsFlag.class)) { |             if (plot.getFlag(DisablePhysicsFlag.class)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 plot.debug("Prevented block physics because disable-physics = true"); |                 plot.debug("Prevented block physics because disable-physics = true"); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|             default: |  | ||||||
|         if (Settings.Redstone.DETECT_INVALID_EDGE_PISTONS) { |         if (Settings.Redstone.DETECT_INVALID_EDGE_PISTONS) { | ||||||
|                     switch (block.getType()) { |             if (PISTONS.contains(block.getType())) { | ||||||
|                         case PISTON, STICKY_PISTON -> { |  | ||||||
|                 org.bukkit.block.data.Directional piston = (org.bukkit.block.data.Directional) block.getBlockData(); |                 org.bukkit.block.data.Directional piston = (org.bukkit.block.data.Directional) block.getBlockData(); | ||||||
|                             switch (piston.getFacing()) { |                 final BlockFace facing = piston.getFacing(); | ||||||
|                                 case EAST -> location = location.add(1, 0, 0); |                 location = location.add(facing.getModX(), facing.getModY(), facing.getModZ()); | ||||||
|                                 case SOUTH -> location = location.add(-1, 0, 0); |  | ||||||
|                                 case WEST -> location = location.add(0, 0, 1); |  | ||||||
|                                 case NORTH -> location = location.add(0, 0, -1); |  | ||||||
|                             } |  | ||||||
|                 Plot newPlot = area.getOwnedPlotAbs(location); |                 Plot newPlot = area.getOwnedPlotAbs(location); | ||||||
|                 if (!plot.equals(newPlot)) { |                 if (!plot.equals(newPlot)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     plot.debug("Prevented piston update because of invalid edge piston detection"); |                     plot.debug("Prevented piston update because of invalid edge piston detection"); | ||||||
|                                 return; |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|                 break; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void blockCreate(BlockPlaceEvent event) { |     public void blockCreate(BlockPlaceEvent event) { | ||||||
| @@ -277,21 +279,25 @@ public class BlockEventListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             if ((location.getY() > area.getMaxBuildHeight() || location.getY() < area |             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { | ||||||
|                     .getMinBuildHeight()) && !Permissions |  | ||||||
|                     .hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("height.height_limit"), |                         TranslatableCaption.of("height.height_limit"), | ||||||
|                         Template.of("minHeight", String.valueOf(area.getMinBuildHeight())), |                         TagResolver.builder() | ||||||
|                         Template.of("maxHeight", String.valueOf(area.getMaxBuildHeight())) |                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) | ||||||
|  |                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) | ||||||
|  |                                 .build() | ||||||
|                 ); |                 ); | ||||||
|  |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
| @@ -305,10 +311,13 @@ public class BlockEventListener implements Listener { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     plot.debug(player.getName() + " could not place " + event.getBlock().getType() |                     plot.debug(player.getName() + " could not place " + event.getBlock().getType() | ||||||
| @@ -316,7 +325,7 @@ public class BlockEventListener implements Listener { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("done.building_restricted") |                             TranslatableCaption.of("done.building_restricted") | ||||||
|                     ); |                     ); | ||||||
| @@ -332,10 +341,13 @@ public class BlockEventListener implements Listener { | |||||||
|                             + " did not fall because of disable-physics = true"); |                             + " did not fall because of disable-physics = true"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } else if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |         } else if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|             pp.sendMessage( |             pp.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.no_permission_event"), |                     TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                     Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) |                     TagResolver.resolver( | ||||||
|  |                             "node", | ||||||
|  |                             Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD) | ||||||
|  |                     ) | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
| @@ -352,29 +364,32 @@ public class BlockEventListener implements Listener { | |||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |             BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|             if (event.getBlock().getY() == 0) { |             // == rather than <= as we only care about the "ground level" not being destroyed | ||||||
|                 if (!Permissions |             if (event.getBlock().getY() == area.getMinGenHeight()) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_GROUNDLEVEL) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if ((location.getY() > area.getMaxBuildHeight() || location.getY() < area |             } else if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { | ||||||
|                     .getMinBuildHeight()) && !Permissions |  | ||||||
|                     .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 plotPlayer.sendMessage( |                 plotPlayer.sendMessage( | ||||||
|                         TranslatableCaption.of("height.height_limit"), |                         TranslatableCaption.of("height.height_limit"), | ||||||
|                         Template.of("minHeight", String.valueOf(area.getMinBuildHeight())), |                         TagResolver.builder() | ||||||
|                         Template.of("maxHeight", String.valueOf(area.getMaxBuildHeight())) |                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) | ||||||
|  |                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) | ||||||
|  |                                 .build() | ||||||
|                 ); |                 ); | ||||||
|  |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED, true)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED, true)) { |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
| @@ -388,17 +403,19 @@ public class BlockEventListener implements Listener { | |||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (Permissions |                 if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 plotPlayer.sendMessage( |                 plotPlayer.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) |                         TagResolver.resolver( | ||||||
|  |                                 "node", | ||||||
|  |                                 Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_OTHER) | ||||||
|  |                         ) | ||||||
|                 ); |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |             } else if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("done.building_restricted") |                             TranslatableCaption.of("done.building_restricted") | ||||||
|                     ); |                     ); | ||||||
| @@ -409,7 +426,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|         if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |         if (pp.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (this.worldEdit != null && pp.getAttribute("worldedit")) { |         if (this.worldEdit != null && pp.getAttribute("worldedit")) { | ||||||
| @@ -420,7 +437,10 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         pp.sendMessage( |         pp.sendMessage( | ||||||
|                 TranslatableCaption.of("permission.no_permission_event"), |                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) |                 TagResolver.resolver( | ||||||
|  |                         "node", | ||||||
|  |                         Tag.inserting(Permission.PERMISSION_ADMIN_DESTROY_ROAD) | ||||||
|  |                 ) | ||||||
|         ); |         ); | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
|     } |     } | ||||||
| @@ -458,6 +478,7 @@ public class BlockEventListener implements Listener { | |||||||
|             case "TWISTING_VINES": |             case "TWISTING_VINES": | ||||||
|             case "CAVE_VINES": |             case "CAVE_VINES": | ||||||
|             case "VINE": |             case "VINE": | ||||||
|  |             case "GLOW_BERRIES": | ||||||
|                 if (!plot.getFlag(VineGrowFlag.class)) { |                 if (!plot.getFlag(VineGrowFlag.class)) { | ||||||
|                     plot.debug("Vine could not grow because vine-grow = false"); |                     plot.debug("Vine could not grow because vine-grow = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -493,18 +514,18 @@ public class BlockEventListener implements Listener { | |||||||
|                     BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |                     BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         if (!plot.hasOwner()) { |                         if (!plot.hasOwner()) { | ||||||
|                             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { |                             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED)) { | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } else if (!plot.isAdded(plotPlayer.getUUID())) { |                         } else if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|                             if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { |                             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER)) { | ||||||
|                                 return; |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                     } else { |                     } else { | ||||||
|                         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { |                         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD)) { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                         if (this.worldEdit != null && plotPlayer.getAttribute("worldedit")) { |                         if (this.worldEdit != null && plotPlayer.getAttribute("worldedit")) { | ||||||
| @@ -548,17 +569,18 @@ public class BlockEventListener implements Listener { | |||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         switch (event.getNewState().getType()) { |         if (!area.buildRangeContainsY(location.getY())) { | ||||||
|             case SNOW: |             event.setCancelled(true); | ||||||
|             case SNOW_BLOCK: |             return; | ||||||
|  |         } | ||||||
|  |         if (org.bukkit.Tag.SNOW.isTagged(event.getNewState().getType())) { | ||||||
|             if (!plot.getFlag(SnowFormFlag.class)) { |             if (!plot.getFlag(SnowFormFlag.class)) { | ||||||
|                 plot.debug("Snow could not form because snow-form = false"); |                 plot.debug("Snow could not form because snow-form = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|             case ICE: |         } | ||||||
|             case FROSTED_ICE: |         if (org.bukkit.Tag.ICE.isTagged(event.getNewState().getType())) { | ||||||
|             case PACKED_ICE: |  | ||||||
|             if (!plot.getFlag(IceFormFlag.class)) { |             if (!plot.getFlag(IceFormFlag.class)) { | ||||||
|                 plot.debug("Ice could not form because ice-form = false"); |                 plot.debug("Ice could not form because ice-form = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -583,18 +605,12 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Class<? extends BooleanFlag<?>> flag; |         Class<? extends BooleanFlag<?>> flag; | ||||||
|         switch (event.getNewState().getType()) { |         if (org.bukkit.Tag.SNOW.isTagged(event.getNewState().getType())) { | ||||||
|             case SNOW: |  | ||||||
|             case SNOW_BLOCK: |  | ||||||
|             flag = SnowFormFlag.class; |             flag = SnowFormFlag.class; | ||||||
|                 break; |         } else if (org.bukkit.Tag.ICE.isTagged(event.getNewState().getType())) { | ||||||
|             case ICE: |  | ||||||
|             case FROSTED_ICE: |  | ||||||
|             case PACKED_ICE: |  | ||||||
|             flag = IceFormFlag.class; |             flag = IceFormFlag.class; | ||||||
|                 break; |         } else { | ||||||
|             default: |             return; | ||||||
|                 return; // other blocks are ignored by this event |  | ||||||
|         } |         } | ||||||
|         boolean allowed = plot.getFlag(flag); |         boolean allowed = plot.getFlag(flag); | ||||||
|         Entity entity = event.getEntity(); |         Entity entity = event.getEntity(); | ||||||
| @@ -647,14 +663,14 @@ public class BlockEventListener implements Listener { | |||||||
|                     event.getBlock().breakNaturally(); |                     event.getBlock().breakNaturally(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             if (location.getY() == 0) { |             // == rather than <= as we only care about the "ground level" not being destroyed | ||||||
|  |             if (location.getY() == area.getMinGenHeight()) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                 if (Permissions |                 if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_UNOWNED)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
| @@ -666,8 +682,7 @@ public class BlockEventListener implements Listener { | |||||||
|                 Block block = event.getBlock(); |                 Block block = event.getBlock(); | ||||||
|                 if (destroy |                 if (destroy | ||||||
|                         .contains(BlockTypeWrapper.get(BukkitAdapter.asBlockType(block.getType()))) |                         .contains(BlockTypeWrapper.get(BukkitAdapter.asBlockType(block.getType()))) | ||||||
|                         || Permissions |                         || plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_OTHER)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 plot.debug(player.getName() + " could not break " + block.getType() |                 plot.debug(player.getName() + " could not break " + block.getType() | ||||||
| @@ -678,7 +693,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { |         if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY_ROAD)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         event.setCancelled(true); |         event.setCancelled(true); | ||||||
| @@ -697,111 +712,141 @@ public class BlockEventListener implements Listener { | |||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         switch (block.getType()) { |         Material blockType = block.getType(); | ||||||
|             case ICE: |         if (org.bukkit.Tag.ICE.isTagged(blockType)) { | ||||||
|             if (!plot.getFlag(IceMeltFlag.class)) { |             if (!plot.getFlag(IceMeltFlag.class)) { | ||||||
|                 plot.debug("Ice could not melt because ice-melt = false"); |                 plot.debug("Ice could not melt because ice-melt = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|                 break; |             return; | ||||||
|             case SNOW: |         } | ||||||
|  |         if (org.bukkit.Tag.SNOW.isTagged(blockType)) { | ||||||
|             if (!plot.getFlag(SnowMeltFlag.class)) { |             if (!plot.getFlag(SnowMeltFlag.class)) { | ||||||
|                 plot.debug("Snow could not melt because snow-melt = false"); |                 plot.debug("Snow could not melt because snow-melt = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|                 break; |             return; | ||||||
|             case FARMLAND: |         } | ||||||
|  |         if (blockType == Material.FARMLAND) { | ||||||
|             if (!plot.getFlag(SoilDryFlag.class)) { |             if (!plot.getFlag(SoilDryFlag.class)) { | ||||||
|                 plot.debug("Soil could not dry because soil-dry = false"); |                 plot.debug("Soil could not dry because soil-dry = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|                 break; |             return; | ||||||
|             case TUBE_CORAL_BLOCK: |         } | ||||||
|             case BRAIN_CORAL_BLOCK: |         if (CORAL_BLOCKS.isTagged(blockType) || CORALS.isTagged(blockType) || WALL_CORALS.isTagged(blockType)) { | ||||||
|             case BUBBLE_CORAL_BLOCK: |  | ||||||
|             case FIRE_CORAL_BLOCK: |  | ||||||
|             case HORN_CORAL_BLOCK: |  | ||||||
|             case TUBE_CORAL: |  | ||||||
|             case BRAIN_CORAL: |  | ||||||
|             case BUBBLE_CORAL: |  | ||||||
|             case FIRE_CORAL: |  | ||||||
|             case HORN_CORAL: |  | ||||||
|             case TUBE_CORAL_FAN: |  | ||||||
|             case BRAIN_CORAL_FAN: |  | ||||||
|             case BUBBLE_CORAL_FAN: |  | ||||||
|             case FIRE_CORAL_FAN: |  | ||||||
|             case HORN_CORAL_FAN: |  | ||||||
|             case BRAIN_CORAL_WALL_FAN: |  | ||||||
|             case BUBBLE_CORAL_WALL_FAN: |  | ||||||
|             case FIRE_CORAL_WALL_FAN: |  | ||||||
|             case HORN_CORAL_WALL_FAN: |  | ||||||
|             case TUBE_CORAL_WALL_FAN: |  | ||||||
|             if (!plot.getFlag(CoralDryFlag.class)) { |             if (!plot.getFlag(CoralDryFlag.class)) { | ||||||
|                 plot.debug("Coral could not dry because coral-dry = false"); |                 plot.debug("Coral could not dry because coral-dry = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|                 break; |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|  |     public void onMoistureChange(MoistureChangeEvent event) { | ||||||
|  |         Block block = event.getBlock(); | ||||||
|  |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|  |  | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Plot plot = area.getOwnedPlot(location); | ||||||
|  |  | ||||||
|  |         if (plot == null) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (block.getBlockData() instanceof Farmland farmland && event | ||||||
|  |                 .getNewState() | ||||||
|  |                 .getBlockData() instanceof Farmland newFarmland) { | ||||||
|  |             int currentMoisture = farmland.getMoisture(); | ||||||
|  |             int newMoisture = newFarmland.getMoisture(); | ||||||
|  |  | ||||||
|  |             // farmland gets moisturizes | ||||||
|  |             if (newMoisture > currentMoisture) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (plot.getFlag(SoilDryFlag.class)) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             plot.debug("Soil could not dry because soil-dry = false"); | ||||||
|  |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onChange(BlockFromToEvent event) { |     public void onChange(BlockFromToEvent event) { | ||||||
|         Block from = event.getBlock(); |         Block fromBlock = event.getBlock(); | ||||||
|  |  | ||||||
|         // Check liquid flow flag inside of origin plot too |         // Check liquid flow flag inside of origin plot too | ||||||
|         final Location fLocation = BukkitUtil.adapt(from.getLocation()); |         final Location fromLocation = BukkitUtil.adapt(fromBlock.getLocation()); | ||||||
|         final PlotArea fromArea = fLocation.getPlotArea(); |         final PlotArea fromArea = fromLocation.getPlotArea(); | ||||||
|         if (fromArea != null) { |         if (fromArea != null) { | ||||||
|             final Plot plot = fromArea.getOwnedPlot(fLocation); |             final Plot fromPlot = fromArea.getOwnedPlot(fromLocation); | ||||||
|             if (plot != null && plot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event |             if (fromPlot != null && fromPlot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event | ||||||
|                     .getBlock() |                     .getBlock() | ||||||
|                     .isLiquid()) { |                     .isLiquid()) { | ||||||
|                 plot.debug("Liquid could not flow because liquid-flow = disabled"); |                 fromPlot.debug("Liquid could not flow because liquid-flow = disabled"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Block to = event.getToBlock(); |         Block toBlock = event.getToBlock(); | ||||||
|         Location tLocation = BukkitUtil.adapt(to.getLocation()); |         Location toLocation = BukkitUtil.adapt(toBlock.getLocation()); | ||||||
|         PlotArea area = tLocation.getPlotArea(); |         PlotArea toArea = toLocation.getPlotArea(); | ||||||
|         if (area == null) { |         if (toArea == null) { | ||||||
|             if (from.getType() == Material.DRAGON_EGG && fromArea != null) { |             if (fromBlock.getType() == Material.DRAGON_EGG && fromArea != null) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = area.getOwnedPlot(tLocation); |         if (!toArea.buildRangeContainsY(toLocation.getY())) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot toPlot = toArea.getOwnedPlot(toLocation); | ||||||
|  |  | ||||||
|         if (from.getType() == Material.DRAGON_EGG && fromArea != null) { |         if (fromBlock.getType() == Material.DRAGON_EGG && fromArea != null) { | ||||||
|             final Plot fromPlot = fromArea.getOwnedPlot(fLocation); |             final Plot fromPlot = fromArea.getOwnedPlot(fromLocation); | ||||||
|  |  | ||||||
|             if (fromPlot != null || plot != null) { |             if (fromPlot != null || toPlot != null) { | ||||||
|                 if ((fromPlot == null || !fromPlot.equals(plot)) && (plot == null || !plot.equals(fromPlot))) { |                 if ((fromPlot == null || !fromPlot.equals(toPlot)) && (toPlot == null || !toPlot.equals(fromPlot))) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (plot != null) { |         if (toPlot != null) { | ||||||
|             if (!area.contains(fLocation.getX(), fLocation.getZ()) || !Objects.equals(plot, area.getOwnedPlot(fLocation))) { |             if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals( | ||||||
|  |                     toPlot, | ||||||
|  |                     toArea.getOwnedPlot(fromLocation) | ||||||
|  |             )) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.ENABLED && event.getBlock().isLiquid()) { |             if (toPlot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.ENABLED && event.getBlock().isLiquid()) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.getFlag(DisablePhysicsFlag.class)) { |             if (toPlot.getFlag(DisablePhysicsFlag.class)) { | ||||||
|                 plot.debug(event.getBlock().getType() + " could not update because disable-physics = true"); |                 toPlot.debug(event.getBlock().getType() + " could not update because disable-physics = true"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event.getBlock().isLiquid()) { |             if (toPlot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event.getBlock().isLiquid()) { | ||||||
|                 plot.debug("Liquid could not flow because liquid-flow = disabled"); |                 toPlot.debug("Liquid could not flow because liquid-flow = disabled"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!area.contains(fLocation.getX(), fLocation.getZ()) || !Objects.equals(null, area.getOwnedPlot(fLocation))) { |         } else if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals( | ||||||
|  |                 null, | ||||||
|  |                 toArea.getOwnedPlot(fromLocation) | ||||||
|  |         )) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (event.getBlock().isLiquid()) { |         } else if (event.getBlock().isLiquid()) { | ||||||
|             final org.bukkit.Location location = event.getBlock().getLocation(); |             final org.bukkit.Location location = event.getBlock().getLocation(); | ||||||
| @@ -841,6 +886,11 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (!area.buildRangeContainsY(location.getY())) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null || !plot.getFlag(CropGrowFlag.class)) { |         if (plot == null || !plot.getFlag(CropGrowFlag.class)) { | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
| @@ -884,15 +934,16 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         for (Block block1 : event.getBlocks()) { |         for (Block block1 : event.getBlocks()) { | ||||||
|             Location bloc = BukkitUtil.adapt(block1.getLocation()); |             Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains( |             Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); | ||||||
|                     bloc.getX() + relative.getBlockX(), |             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains(newLoc)) { | ||||||
|                     bloc.getZ() + relative.getBlockZ() |  | ||||||
|             )) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot |             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot.equals(area.getOwnedPlot(newLoc))) { | ||||||
|                     .equals(area.getOwnedPlot(bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ())))) { |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             if (!area.buildRangeContainsY(bloc.getY()) || !area.buildRangeContainsY(newLoc.getY())) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -918,9 +969,8 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             for (Block block1 : event.getBlocks()) { |             for (Block block1 : event.getBlocks()) { | ||||||
|                 Location bloc = BukkitUtil.adapt(block1.getLocation()); |                 Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|                 if (bloc.isPlotArea() || bloc |                 Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); | ||||||
|                         .add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()) |                 if (bloc.isPlotArea() || newLoc.isPlotArea()) { | ||||||
|                         .isPlotArea()) { |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -934,15 +984,16 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         for (Block block1 : event.getBlocks()) { |         for (Block block1 : event.getBlocks()) { | ||||||
|             Location bloc = BukkitUtil.adapt(block1.getLocation()); |             Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains( |             Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); | ||||||
|                     bloc.getX() + relative.getBlockX(), |             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains(newLoc)) { | ||||||
|                     bloc.getZ() + relative.getBlockZ() |  | ||||||
|             )) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot |             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot.equals(area.getOwnedPlot(newLoc))) { | ||||||
|                     .equals(area.getOwnedPlot(bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ())))) { |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |             if (!area.buildRangeContainsY(bloc.getY()) || !area.buildRangeContainsY(newLoc.getY())) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -951,16 +1002,29 @@ public class BlockEventListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBlockDispense(BlockDispenseEvent event) { |     public void onBlockDispense(BlockDispenseEvent event) { | ||||||
|  |         if (!this.plotAreaManager.hasPlotArea(event.getBlock().getWorld().getName())) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         Material type = event.getItem().getType(); |         Material type = event.getItem().getType(); | ||||||
|         switch (type.toString()) { |         switch (type.toString()) { | ||||||
|             case "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", "CARVED_PUMPKIN", "WITHER_SKELETON_SKULL", "FLINT_AND_STEEL", "BONE_MEAL", "SHEARS", "GLASS_BOTTLE", "GLOWSTONE", "COD_BUCKET", "PUFFERFISH_BUCKET", "SALMON_BUCKET", "TROPICAL_FISH_BUCKET", "AXOLOTL_BUCKET", "BUCKET", "WATER_BUCKET", "LAVA_BUCKET" -> { |             case "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", "CARVED_PUMPKIN", "WITHER_SKELETON_SKULL", "FLINT_AND_STEEL", | ||||||
|  |                     "BONE_MEAL", "SHEARS", "GLASS_BOTTLE", "GLOWSTONE", "COD_BUCKET", "PUFFERFISH_BUCKET", "SALMON_BUCKET", | ||||||
|  |                     "TROPICAL_FISH_BUCKET", "AXOLOTL_BUCKET", "BUCKET", "WATER_BUCKET", "LAVA_BUCKET", "TADPOLE_BUCKET" -> { | ||||||
|                 if (event.getBlock().getType() == Material.DROPPER) { |                 if (event.getBlock().getType() == Material.DROPPER) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 BlockFace targetFace = ((Directional) event.getBlock().getState().getData()).getFacing(); |                 BlockFace targetFace = ((Dispenser) event.getBlock().getBlockData()).getFacing(); | ||||||
|                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); |                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); | ||||||
|                 if (location.isPlotRoad()) { |                 if (location.isPlotRoad()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 PlotArea area = location.getPlotArea(); | ||||||
|  |                 if (area != null && !area.buildRangeContainsY(location.getY())) { | ||||||
|  |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -1000,6 +1064,10 @@ public class BlockEventListener implements Listener { | |||||||
|                 Plot plot = area.getOwnedPlot(location); |                 Plot plot = area.getOwnedPlot(location); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 if (!Objects.equals(plot, origin)) { | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 if (!area.buildRangeContainsY(location.getY())) { | ||||||
|  |                     event.getBlocks().remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -1048,6 +1116,7 @@ public class BlockEventListener implements Listener { | |||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 plot.debug("Explosion was cancelled because explosion = false"); |                 plot.debug("Explosion was cancelled because explosion = false"); | ||||||
|             } |             } | ||||||
|  |             return; | ||||||
|         } |         } | ||||||
|         event.blockList().removeIf(blox -> !plot.equals(area.getOwnedPlot(BukkitUtil.adapt(blox.getLocation())))); |         event.blockList().removeIf(blox -> !plot.equals(area.getOwnedPlot(BukkitUtil.adapt(blox.getLocation())))); | ||||||
|     } |     } | ||||||
| @@ -1091,27 +1160,44 @@ public class BlockEventListener implements Listener { | |||||||
|         Plot plot = area.getOwnedPlot(location1); |         Plot plot = area.getOwnedPlot(location1); | ||||||
|         if (player != null) { |         if (player != null) { | ||||||
|             BukkitPlayer pp = BukkitUtil.adapt(player); |             BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|  |             if (area.notifyIfOutsideBuildArea(pp, location1.getY())) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_BUILD_ROAD | ||||||
|  |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_ROAD)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.hasOwner()) { |             } else if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, BlockIgnitionFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_BUILD_UNOWNED | ||||||
|  |                 )) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_UNOWNED) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } else if (!plot.isAdded(pp.getUUID())) { |             } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_BUILD_OTHER)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_OTHER) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
| @@ -1198,7 +1284,10 @@ public class BlockEventListener implements Listener { | |||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = area.getOwnedPlot(blockLocation); |                 Plot plot = area.getOwnedPlot(blockLocation); | ||||||
|                 return !Objects.equals(plot, origin); |                 if (!Objects.equals(plot, origin)) { | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |                 return !area.buildRangeContainsY(location.getY()); | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|         if (blocks.isEmpty()) { |         if (blocks.isEmpty()) { | ||||||
| @@ -1208,4 +1297,55 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |      * BlockMultiPlaceEvent is called unrelated to the BlockPlaceEvent itself and therefore doesn't respect the cancellation. | ||||||
|  |      */ | ||||||
|  |     @EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST) | ||||||
|  |     public void onBlockMultiPlace(BlockMultiPlaceEvent event) { | ||||||
|  |         // Check if the generic block place event would be cancelled | ||||||
|  |         blockCreate(event); | ||||||
|  |         if (event.isCancelled()) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); | ||||||
|  |         Location placedLocation = BukkitUtil.adapt(event.getBlockReplacedState().getLocation()); | ||||||
|  |         PlotArea area = placedLocation.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot plot = placedLocation.getPlot(); | ||||||
|  |  | ||||||
|  |         for (final BlockState state : event.getReplacedBlockStates()) { | ||||||
|  |             Location currentLocation = BukkitUtil.adapt(state.getLocation()); | ||||||
|  |             if (!pp.hasPermission( | ||||||
|  |                     Permission.PERMISSION_ADMIN_BUILD_ROAD | ||||||
|  |             ) && !(Objects.equals(currentLocation.getPlot(), plot))) { | ||||||
|  |                 pp.sendMessage( | ||||||
|  |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|  |                         TagResolver.resolver("node", Tag.inserting(Permission.PERMISSION_ADMIN_BUILD_ROAD)) | ||||||
|  |                 ); | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             if (currentLocation.getY() >= area.getMaxBuildHeight() || currentLocation.getY() < area.getMinBuildHeight()) { | ||||||
|  |                 pp.sendMessage( | ||||||
|  |                         TranslatableCaption.of("height.height_limit"), | ||||||
|  |                         TagResolver.builder() | ||||||
|  |                                 .tag("minheight", Tag.inserting(Component.text(area.getMinBuildHeight()))) | ||||||
|  |                                 .tag("maxheight", Tag.inserting(Component.text(area.getMaxBuildHeight()))) | ||||||
|  |                                 .build() | ||||||
|  |                 ); | ||||||
|  |                 if (area.notifyIfOutsideBuildArea(pp, currentLocation.getY())) { | ||||||
|  |                     event.setCancelled(true); | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -33,6 +26,9 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.SculkSensorInteractFlag; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
|  | import org.bukkit.Material; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Item; | import org.bukkit.entity.Item; | ||||||
| @@ -46,11 +42,31 @@ import org.bukkit.event.block.BlockReceiveGameEvent; | |||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
|  | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener117 implements Listener { | public class BlockEventListener117 implements Listener { | ||||||
|  |  | ||||||
|  |     private static final Set<Material> COPPER_OXIDIZING = Set.of( | ||||||
|  |             Material.COPPER_BLOCK, | ||||||
|  |             Material.EXPOSED_COPPER, | ||||||
|  |             Material.WEATHERED_COPPER, | ||||||
|  |             Material.OXIDIZED_COPPER, | ||||||
|  |             Material.CUT_COPPER, | ||||||
|  |             Material.EXPOSED_CUT_COPPER, | ||||||
|  |             Material.WEATHERED_CUT_COPPER, | ||||||
|  |             Material.OXIDIZED_CUT_COPPER, | ||||||
|  |             Material.CUT_COPPER_STAIRS, | ||||||
|  |             Material.EXPOSED_CUT_COPPER_STAIRS, | ||||||
|  |             Material.WEATHERED_CUT_COPPER_STAIRS, | ||||||
|  |             Material.OXIDIZED_CUT_COPPER_STAIRS, | ||||||
|  |             Material.CUT_COPPER_SLAB, | ||||||
|  |             Material.EXPOSED_CUT_COPPER_SLAB, | ||||||
|  |             Material.WEATHERED_CUT_COPPER_SLAB, | ||||||
|  |             Material.OXIDIZED_CUT_COPPER_SLAB | ||||||
|  |     ); | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public BlockEventListener117() { |     public BlockEventListener117() { | ||||||
|     } |     } | ||||||
| @@ -66,13 +82,27 @@ public class BlockEventListener117 implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         BukkitPlayer plotPlayer = null; | ||||||
|         if (plot == null || !plot.getFlag(MiscInteractFlag.class)) { |  | ||||||
|         if (entity instanceof Player player) { |         if (entity instanceof Player player) { | ||||||
|                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |             plotPlayer = BukkitUtil.adapt(player); | ||||||
|  |             if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Plot plot = location.getOwnedPlot(); | ||||||
|  |         if (plot == null && !PlotFlagUtil.isAreaRoadFlagsAndFlagEquals( | ||||||
|  |                 area, | ||||||
|  |                 MiscInteractFlag.class, | ||||||
|  |                 true | ||||||
|  |         ) || plot != null && (!plot.getFlag(MiscInteractFlag.class) || !plot.getFlag(SculkSensorInteractFlag.class))) { | ||||||
|  |             if (plotPlayer != null) { | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (!plot.isAdded(plotPlayer.getUUID())) { |                     if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|                         plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because misc-interact = false"); |                         plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because both " + | ||||||
|  |                                 "sculk-sensor-interact and misc-interact = false"); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -81,9 +111,17 @@ public class BlockEventListener117 implements Listener { | |||||||
|             if (entity instanceof Item item) { |             if (entity instanceof Item item) { | ||||||
|                 UUID itemThrower = item.getThrower(); |                 UUID itemThrower = item.getThrower(); | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|  |                     if (itemThrower == null && (itemThrower = item.getOwner()) == null) { | ||||||
|  |                         plot.debug( | ||||||
|  |                                 "A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " + | ||||||
|  |                                         "misc-interact = false and the item's owner could not be resolved."); | ||||||
|  |                         event.setCancelled(true); | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|                     if (!plot.isAdded(itemThrower)) { |                     if (!plot.isAdded(itemThrower)) { | ||||||
|                         if (!plot.isAdded(itemThrower)) { |                         if (!plot.isAdded(itemThrower)) { | ||||||
|                             plot.debug("A thrown item couldn't trigger sculk sensors because misc-interact = false"); |                             plot.debug("A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " + | ||||||
|  |                                     "misc-interact = false"); | ||||||
|                             event.setCancelled(true); |                             event.setCancelled(true); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
| @@ -101,12 +139,11 @@ public class BlockEventListener117 implements Listener { | |||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             for (int i = blocks.size() - 1; i >= 0; i--) { |             for (int i = blocks.size() - 1; i >= 0; i--) { | ||||||
|                 location = BukkitUtil.adapt(blocks.get(i).getLocation()); |                 Location blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 if (location.isPlotArea()) { |                 if (blockLocation.isPlotArea()) { | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             return; |  | ||||||
|         } else { |         } else { | ||||||
|             Plot origin = area.getOwnedPlot(location); |             Plot origin = area.getOwnedPlot(location); | ||||||
|             if (origin == null) { |             if (origin == null) { | ||||||
| @@ -114,30 +151,22 @@ public class BlockEventListener117 implements Listener { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             for (int i = blocks.size() - 1; i >= 0; i--) { |             for (int i = blocks.size() - 1; i >= 0; i--) { | ||||||
|                 location = BukkitUtil.adapt(blocks.get(i).getLocation()); |                 Location blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 if (!area.contains(location.getX(), location.getZ())) { |                 if (!area.contains(blockLocation.getX(), blockLocation.getZ())) { | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = area.getOwnedPlot(location); |                 Plot plot = area.getOwnedPlot(blockLocation); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 if (!Objects.equals(plot, origin)) { | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|  |                     continue; | ||||||
|                 } |                 } | ||||||
|             } |                 if (!area.buildRangeContainsY(location.getY())) { | ||||||
|         } |  | ||||||
|         Plot origin = area.getPlot(location); |  | ||||||
|         if (origin == null) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         for (int i = blocks.size() - 1; i >= 0; i--) { |  | ||||||
|             location = BukkitUtil.adapt(blocks.get(i).getLocation()); |  | ||||||
|             Plot plot = area.getOwnedPlot(location); |  | ||||||
|             if (!Objects.equals(plot, origin) && (!plot.isMerged() && !origin.isMerged())) { |  | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBlockForm(BlockFormEvent event) { |     public void onBlockForm(BlockFormEvent event) { | ||||||
| @@ -155,23 +184,7 @@ public class BlockEventListener117 implements Listener { | |||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         switch (event.getNewState().getType()) { |         if (COPPER_OXIDIZING.contains(event.getNewState().getType())) { | ||||||
|             case COPPER_BLOCK: |  | ||||||
|             case EXPOSED_COPPER: |  | ||||||
|             case WEATHERED_COPPER: |  | ||||||
|             case OXIDIZED_COPPER: |  | ||||||
|             case CUT_COPPER: |  | ||||||
|             case EXPOSED_CUT_COPPER: |  | ||||||
|             case WEATHERED_CUT_COPPER: |  | ||||||
|             case OXIDIZED_CUT_COPPER: |  | ||||||
|             case CUT_COPPER_STAIRS: |  | ||||||
|             case EXPOSED_CUT_COPPER_STAIRS: |  | ||||||
|             case WEATHERED_CUT_COPPER_STAIRS: |  | ||||||
|             case OXIDIZED_CUT_COPPER_STAIRS: |  | ||||||
|             case CUT_COPPER_SLAB: |  | ||||||
|             case EXPOSED_CUT_COPPER_SLAB: |  | ||||||
|             case WEATHERED_CUT_COPPER_SLAB: |  | ||||||
|             case OXIDIZED_CUT_COPPER_SLAB: |  | ||||||
|             if (!plot.getFlag(CopperOxideFlag.class)) { |             if (!plot.getFlag(CopperOxideFlag.class)) { | ||||||
|                 plot.debug("Copper could not oxide because copper-oxide = false"); |                 plot.debug("Copper could not oxide because copper-oxide = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -33,6 +26,7 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
|  | import com.plotsquared.core.util.ReflectionUtils; | ||||||
| import com.plotsquared.core.util.ReflectionUtils.RefClass; | import com.plotsquared.core.util.ReflectionUtils.RefClass; | ||||||
| import com.plotsquared.core.util.ReflectionUtils.RefField; | import com.plotsquared.core.util.ReflectionUtils.RefField; | ||||||
| import com.plotsquared.core.util.ReflectionUtils.RefMethod; | import com.plotsquared.core.util.ReflectionUtils.RefMethod; | ||||||
| @@ -71,9 +65,11 @@ public class ChunkListener implements Listener { | |||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final int version; |     private final int version; | ||||||
|  |  | ||||||
|  |     private RefMethod methodSetUnsaved; | ||||||
|     private RefMethod methodGetHandleChunk; |     private RefMethod methodGetHandleChunk; | ||||||
|     private RefMethod methodGetHandleWorld; |     private RefMethod methodGetHandleWorld; | ||||||
|     private RefField mustSave; |     private RefField mustNotSave; | ||||||
|  |     private Object objChunkStatusFull = null; | ||||||
|     /* |     /* | ||||||
|     private RefMethod methodGetFullChunk; |     private RefMethod methodGetFullChunk; | ||||||
|     private RefMethod methodGetBukkitChunk; |     private RefMethod methodGetBukkitChunk; | ||||||
| @@ -86,7 +82,6 @@ public class ChunkListener implements Listener { | |||||||
|     */ |     */ | ||||||
|     private Chunk lastChunk; |     private Chunk lastChunk; | ||||||
|     private boolean ignoreUnload = false; |     private boolean ignoreUnload = false; | ||||||
|     private boolean isTrueForNotSave = true; |  | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public ChunkListener(final @NonNull PlotAreaManager plotAreaManager) { |     public ChunkListener(final @NonNull PlotAreaManager plotAreaManager) { | ||||||
| @@ -97,22 +92,27 @@ public class ChunkListener implements Listener { | |||||||
|         } |         } | ||||||
|         try { |         try { | ||||||
|             RefClass classCraftWorld = getRefClass("{cb}.CraftWorld"); |             RefClass classCraftWorld = getRefClass("{cb}.CraftWorld"); | ||||||
|             this.methodGetHandleWorld = classCraftWorld.getMethod("getHandle"); |  | ||||||
|             RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); |             RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); | ||||||
|  |             ReflectionUtils.RefClass classChunkAccess = getRefClass("net.minecraft.world.level.chunk.IChunkAccess"); | ||||||
|  |             this.methodSetUnsaved = classChunkAccess.getMethod("a", boolean.class); | ||||||
|  |             try { | ||||||
|                 this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle"); |                 this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle"); | ||||||
|  |             } catch (NoSuchMethodException ignored) { | ||||||
|  |                 try { | ||||||
|  |                     RefClass classChunkStatus = getRefClass("net.minecraft.world.level.chunk.ChunkStatus"); | ||||||
|  |                     this.objChunkStatusFull = classChunkStatus.getRealClass().getField("n").get(null); | ||||||
|  |                     this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle", classChunkStatus.getRealClass()); | ||||||
|  |                 } catch (NoSuchMethodException ex) { | ||||||
|  |                     throw new RuntimeException(ex); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|             try { |             try { | ||||||
|                 if (version < 17) { |                 if (version < 17) { | ||||||
|                     RefClass classChunk = getRefClass("{nms}.Chunk"); |                     RefClass classChunk = getRefClass("{nms}.Chunk"); | ||||||
|                     if (version == 13) { |                     this.mustNotSave = classChunk.getField("mustNotSave"); | ||||||
|                         this.mustSave = classChunk.getField("mustSave"); |  | ||||||
|                         this.isTrueForNotSave = false; |  | ||||||
|                     } else { |  | ||||||
|                         this.mustSave = classChunk.getField("mustNotSave"); |  | ||||||
|                     } |  | ||||||
|                 } else { |                 } else { | ||||||
|                     RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); |                     RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); | ||||||
|                     this.mustSave = classChunk.getField("mustNotSave"); |                     this.mustNotSave = classChunk.getField("mustNotSave"); | ||||||
|  |  | ||||||
|                 } |                 } | ||||||
|             } catch (NoSuchFieldException e) { |             } catch (NoSuchFieldException e) { | ||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
| @@ -174,10 +174,13 @@ public class ChunkListener implements Listener { | |||||||
|         if (safe && shouldSave(world, chunk.getX(), chunk.getZ())) { |         if (safe && shouldSave(world, chunk.getX(), chunk.getZ())) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         Object c = this.methodGetHandleChunk.of(chunk).call(); |         Object c = objChunkStatusFull != null | ||||||
|         RefField.RefExecutor field = this.mustSave.of(c); |                 ? this.methodGetHandleChunk.of(chunk).call(objChunkStatusFull) | ||||||
|         if ((Boolean) field.get() != isTrueForNotSave) { |                 : this.methodGetHandleChunk.of(chunk).call(); | ||||||
|             field.set(isTrueForNotSave); |         RefField.RefExecutor field = this.mustNotSave.of(c); | ||||||
|  |         methodSetUnsaved.of(c).call(false); | ||||||
|  |         if (!((Boolean) field.get())) { | ||||||
|  |             field.set(true); | ||||||
|             if (chunk.isLoaded()) { |             if (chunk.isLoaded()) { | ||||||
|                 ignoreUnload = true; |                 ignoreUnload = true; | ||||||
|                 chunk.unload(false); |                 chunk.unload(false); | ||||||
| @@ -241,7 +244,8 @@ public class ChunkListener implements Listener { | |||||||
|         Chunk chunk = event.getChunk(); |         Chunk chunk = event.getChunk(); | ||||||
|         if (Settings.Chunk_Processor.AUTO_TRIM) { |         if (Settings.Chunk_Processor.AUTO_TRIM) { | ||||||
|             String world = chunk.getWorld().getName(); |             String world = chunk.getWorld().getName(); | ||||||
|             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea(world)) { |             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea( | ||||||
|  |                     world)) { | ||||||
|                 if (unloadChunk(world, chunk, true)) { |                 if (unloadChunk(world, chunk, true)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -44,7 +37,7 @@ import com.plotsquared.core.plot.flag.implementations.ExplosionFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.InvincibleFlag; | import com.plotsquared.core.plot.flag.implementations.InvincibleFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| @@ -152,53 +145,37 @@ public class EntityEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         CreatureSpawnEvent.SpawnReason reason = event.getSpawnReason(); |         CreatureSpawnEvent.SpawnReason reason = event.getSpawnReason(); | ||||||
|         switch (reason.toString()) { |         switch (reason.toString()) { | ||||||
|             case "DISPENSE_EGG": |             case "DISPENSE_EGG", "EGG", "OCELOT_BABY", "SPAWNER_EGG" -> { | ||||||
|             case "EGG": |  | ||||||
|             case "OCELOT_BABY": |  | ||||||
|             case "SPAWNER_EGG": |  | ||||||
|                 if (!area.isSpawnEggs()) { |                 if (!area.isSpawnEggs()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "REINFORCEMENTS": |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", | ||||||
|             case "NATURAL": |                     "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||||
|             case "MOUNT": |  | ||||||
|             case "PATROL": |  | ||||||
|             case "RAID": |  | ||||||
|             case "SHEARED": |  | ||||||
|             case "SILVERFISH_BLOCK": |  | ||||||
|             case "TRAP": |  | ||||||
|             case "VILLAGE_DEFENSE": |  | ||||||
|             case "VILLAGE_INVASION": |  | ||||||
|             case "BEEHIVE": |  | ||||||
|             case "CHUNK_GEN": |  | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BREEDING": |             case "BREEDING" -> { | ||||||
|                 if (!area.isSpawnBreeding()) { |                 if (!area.isSpawnBreeding()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BUILD_IRONGOLEM": |             case "BUILD_IRONGOLEM", "BUILD_SNOWMAN", "BUILD_WITHER", "CUSTOM" -> { | ||||||
|             case "BUILD_SNOWMAN": |  | ||||||
|             case "BUILD_WITHER": |  | ||||||
|             case "CUSTOM": |  | ||||||
|                 if (!area.isSpawnCustom() && entity.getType() != EntityType.ARMOR_STAND) { |                 if (!area.isSpawnCustom() && entity.getType() != EntityType.ARMOR_STAND) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "SPAWNER": |             case "SPAWNER" -> { | ||||||
|                 if (!area.isMobSpawnerSpawning()) { |                 if (!area.isMobSpawnerSpawning()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|         } |         } | ||||||
|         Plot plot = area.getOwnedPlotAbs(location); |         Plot plot = area.getOwnedPlotAbs(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
| @@ -207,7 +184,7 @@ public class EntityEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (BukkitEntityUtil.checkEntity(entity, plot)) { |         if (BukkitEntityUtil.checkEntity(entity, plot.getBasePlot(false))) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -267,7 +244,7 @@ public class EntityEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (area.isRoadFlags() && area.getRoadFlag(InvincibleFlag.class)) { |             if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, InvincibleFlag.class, true)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
| @@ -376,14 +353,13 @@ public class EntityEventListener implements Listener { | |||||||
|             if (shooter instanceof Player) { |             if (shooter instanceof Player) { | ||||||
|                 PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |                 PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |                     if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                         entity.remove(); |                         entity.remove(); | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (plot.isAdded(pp.getUUID()) || Permissions |                 if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                         .hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -36,6 +29,7 @@ import com.plotsquared.core.plot.flag.implementations.DoneFlag; | |||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
|  | import org.bukkit.block.Block; | ||||||
| import org.bukkit.entity.ArmorStand; | import org.bukkit.entity.ArmorStand; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.EntityType; | import org.bukkit.entity.EntityType; | ||||||
| @@ -130,16 +124,16 @@ public class EntitySpawnListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         if (plot == null) { |  | ||||||
|         EntityType type = entity.getType(); |         EntityType type = entity.getType(); | ||||||
|             if (!area.isMobSpawning()) { |         if (plot == null) { | ||||||
|                 switch (type) { |             if (type == EntityType.DROPPED_ITEM) { | ||||||
|                     case DROPPED_ITEM: |  | ||||||
|                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { |                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|  |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|                     case PLAYER: |             if (!area.isMobSpawning()) { | ||||||
|  |                 if (type == EntityType.PLAYER) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (type.isAlive()) { |                 if (type.isAlive()) { | ||||||
| @@ -154,12 +148,13 @@ public class EntitySpawnListener implements Listener { | |||||||
|         if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|         switch (entity.getType()) { |         if (type == EntityType.ENDER_CRYSTAL) { | ||||||
|             case ENDER_CRYSTAL: |  | ||||||
|             if (BukkitEntityUtil.checkEntity(entity, plot)) { |             if (BukkitEntityUtil.checkEntity(entity, plot)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             case SHULKER: |             return; | ||||||
|  |         } | ||||||
|  |         if (type == EntityType.SHULKER) { | ||||||
|             if (!entity.hasMetadata("shulkerPlot")) { |             if (!entity.hasMetadata("shulkerPlot")) { | ||||||
|                 entity.setMetadata("shulkerPlot", new FixedMetadataValue((Plugin) PlotSquared.platform(), plot.getId())); |                 entity.setMetadata("shulkerPlot", new FixedMetadataValue((Plugin) PlotSquared.platform(), plot.getId())); | ||||||
|             } |             } | ||||||
| @@ -191,8 +186,32 @@ public class EntitySpawnListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onTeleport(EntityTeleportEvent event) { |     public void onTeleport(EntityTeleportEvent event) { | ||||||
|         Entity ent = event.getEntity(); |         Entity entity = event.getEntity(); | ||||||
|         if (ent instanceof Vehicle || ent instanceof ArmorStand) { |         Entity fromLocation = event.getEntity(); | ||||||
|  |         Block toLocation = event.getTo().getBlock(); | ||||||
|  |         final Location fromLocLocation = BukkitUtil.adapt(fromLocation.getLocation()); | ||||||
|  |         final PlotArea fromArea = fromLocLocation.getPlotArea(); | ||||||
|  |         Location toLocLocation = BukkitUtil.adapt(toLocation.getLocation()); | ||||||
|  |         PlotArea toArea = toLocLocation.getPlotArea(); | ||||||
|  |  | ||||||
|  |         if (toArea == null) { | ||||||
|  |             if (fromLocation.getType() == EntityType.SHULKER && fromArea != null) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         Plot toPlot = toArea.getOwnedPlot(toLocLocation); | ||||||
|  |         if (fromLocation.getType() == EntityType.SHULKER && fromArea != null) { | ||||||
|  |             final Plot fromPlot = fromArea.getOwnedPlot(fromLocLocation); | ||||||
|  |  | ||||||
|  |             if (fromPlot != null || toPlot != null) { | ||||||
|  |                 if ((fromPlot == null || !fromPlot.equals(toPlot)) && (toPlot == null || !toPlot.equals(fromPlot))) { | ||||||
|  |                     event.setCancelled(true); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (entity instanceof Vehicle || entity instanceof ArmorStand) { | ||||||
|             testNether(event.getEntity()); |             testNether(event.getEntity()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -25,7 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.listener; | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
| import com.google.common.collect.Iterables; |  | ||||||
| import com.plotsquared.bukkit.player.BukkitPlayer; | import com.plotsquared.bukkit.player.BukkitPlayer; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| @@ -33,7 +25,6 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ForcefieldFlag; | import com.plotsquared.core.plot.flag.implementations.ForcefieldFlag; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
|  |  | ||||||
| @@ -46,8 +37,11 @@ public class ForceFieldListener { | |||||||
|  |  | ||||||
|     private static Set<PlotPlayer<?>> getNearbyPlayers(Player player, Plot plot) { |     private static Set<PlotPlayer<?>> getNearbyPlayers(Player player, Plot plot) { | ||||||
|         Set<PlotPlayer<?>> players = new HashSet<>(); |         Set<PlotPlayer<?>> players = new HashSet<>(); | ||||||
|         for (Player nearPlayer : Iterables |         for (Player nearPlayer : player.getNearbyEntities(5d, 5d, 5d).stream() | ||||||
|                 .filter(player.getNearbyEntities(5d, 5d, 5d), Player.class)) { |                 .filter(entity -> entity instanceof Player) | ||||||
|  |                 .map(entity -> (Player) entity) | ||||||
|  |                 .toList() | ||||||
|  |         ) { | ||||||
|             PlotPlayer<?> plotPlayer; |             PlotPlayer<?> plotPlayer; | ||||||
|             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot |             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot | ||||||
|                     .equals(plotPlayer.getCurrentPlot())) { |                     .equals(plotPlayer.getCurrentPlot())) { | ||||||
| @@ -61,8 +55,11 @@ public class ForceFieldListener { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static PlotPlayer<?> hasNearbyPermitted(Player player, Plot plot) { |     private static PlotPlayer<?> hasNearbyPermitted(Player player, Plot plot) { | ||||||
|         for (Player nearPlayer : Iterables |         for (Player nearPlayer : player.getNearbyEntities(5d, 5d, 5d).stream() | ||||||
|                 .filter(player.getNearbyEntities(5d, 5d, 5d), Player.class)) { |                 .filter(entity -> entity instanceof Player) | ||||||
|  |                 .map(entity -> (Player) entity) | ||||||
|  |                 .toList() | ||||||
|  |         ) { | ||||||
|             PlotPlayer<?> plotPlayer; |             PlotPlayer<?> plotPlayer; | ||||||
|             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot |             if ((plotPlayer = BukkitUtil.adapt(nearPlayer)) == null || !plot | ||||||
|                     .equals(plotPlayer.getCurrentPlot())) { |                     .equals(plotPlayer.getCurrentPlot())) { | ||||||
| @@ -111,8 +108,7 @@ public class ForceFieldListener { | |||||||
|             if (plot.isAdded(uuid)) { |             if (plot.isAdded(uuid)) { | ||||||
|                 Set<PlotPlayer<?>> players = getNearbyPlayers(player, plot); |                 Set<PlotPlayer<?>> players = getNearbyPlayers(player, plot); | ||||||
|                 for (PlotPlayer<?> oPlayer : players) { |                 for (PlotPlayer<?> oPlayer : players) { | ||||||
|                     if (!Permissions |                     if (!oPlayer.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { | ||||||
|                             .hasPermission(oPlayer, Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { |  | ||||||
|                         ((BukkitPlayer) oPlayer).player |                         ((BukkitPlayer) oPlayer).player | ||||||
|                                 .setVelocity(calculateVelocity(plotPlayer, oPlayer)); |                                 .setVelocity(calculateVelocity(plotPlayer, oPlayer)); | ||||||
|                     } |                     } | ||||||
| @@ -122,8 +118,7 @@ public class ForceFieldListener { | |||||||
|                 if (oPlayer == null) { |                 if (oPlayer == null) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { | ||||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_ENTRY_FORCEFIELD)) { |  | ||||||
|                     player.setVelocity(calculateVelocity(oPlayer, plotPlayer)); |                     player.setVelocity(calculateVelocity(oPlayer, plotPlayer)); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -25,6 +18,7 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.listener; | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.destroystokyo.paper.event.block.BeaconEffectEvent; | ||||||
| import com.destroystokyo.paper.event.entity.EntityPathfindEvent; | import com.destroystokyo.paper.event.entity.EntityPathfindEvent; | ||||||
| import com.destroystokyo.paper.event.entity.PlayerNaturallySpawnCreaturesEvent; | import com.destroystokyo.paper.event.entity.PlayerNaturallySpawnCreaturesEvent; | ||||||
| import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; | import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; | ||||||
| @@ -43,10 +37,16 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.flag.FlagContainer; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.Component; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.TileState; | import org.bukkit.block.TileState; | ||||||
| @@ -178,71 +178,54 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|         CreatureSpawnEvent.SpawnReason reason = event.getReason(); |         CreatureSpawnEvent.SpawnReason reason = event.getReason(); | ||||||
|         switch (reason.toString()) { |         switch (reason.toString()) { | ||||||
|             case "DISPENSE_EGG": |             case "DISPENSE_EGG", "EGG", "OCELOT_BABY", "SPAWNER_EGG" -> { | ||||||
|             case "EGG": |  | ||||||
|             case "OCELOT_BABY": |  | ||||||
|             case "SPAWNER_EGG": |  | ||||||
|                 if (!area.isSpawnEggs()) { |                 if (!area.isSpawnEggs()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "REINFORCEMENTS": |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||||
|             case "NATURAL": |  | ||||||
|             case "MOUNT": |  | ||||||
|             case "PATROL": |  | ||||||
|             case "RAID": |  | ||||||
|             case "SHEARED": |  | ||||||
|             case "SILVERFISH_BLOCK": |  | ||||||
|             case "TRAP": |  | ||||||
|             case "VILLAGE_DEFENSE": |  | ||||||
|             case "VILLAGE_INVASION": |  | ||||||
|             case "BEEHIVE": |  | ||||||
|             case "CHUNK_GEN": |  | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BREEDING": |             case "BREEDING" -> { | ||||||
|                 if (!area.isSpawnBreeding()) { |                 if (!area.isSpawnBreeding()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BUILD_IRONGOLEM": |             case "BUILD_IRONGOLEM", "BUILD_SNOWMAN", "BUILD_WITHER", "CUSTOM" -> { | ||||||
|             case "BUILD_SNOWMAN": |  | ||||||
|             case "BUILD_WITHER": |  | ||||||
|             case "CUSTOM": |  | ||||||
|                 if (!area.isSpawnCustom() && event.getType() != EntityType.ARMOR_STAND) { |                 if (!area.isSpawnCustom() && event.getType() != EntityType.ARMOR_STAND) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "SPAWNER": |             case "SPAWNER" -> { | ||||||
|                 if (!area.isMobSpawnerSpawning()) { |                 if (!area.isMobSpawnerSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             EntityType type = event.getType(); |             EntityType type = event.getType(); | ||||||
|             if (!area.isMobSpawning()) { |             // PreCreatureSpawnEvent **should** not be called for DROPPED_ITEM, just for the sake of consistency | ||||||
|                 switch (type) { |             if (type == EntityType.DROPPED_ITEM) { | ||||||
|                     case DROPPED_ITEM: |  | ||||||
|                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { |                 if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { | ||||||
|                             event.setShouldAbortSpawn(true); |  | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|  |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|                     case PLAYER: |             if (!area.isMobSpawning()) { | ||||||
|  |                 if (type == EntityType.PLAYER) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (type.isAlive()) { |                 if (type.isAlive()) { | ||||||
| @@ -303,7 +286,7 @@ public class PaperListener implements Listener { | |||||||
|             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); |             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); | ||||||
|             plotPlayer.sendMessage( |             plotPlayer.sendMessage( | ||||||
|                     TranslatableCaption.of("errors.tile_entity_cap_reached"), |                     TranslatableCaption.of("errors.tile_entity_cap_reached"), | ||||||
|                     Template.of("amount", String.valueOf(Settings.Chunk_Processor.MAX_TILES)) |                     TagResolver.resolver("amount", Tag.inserting(Component.text(Settings.Chunk_Processor.MAX_TILES))) | ||||||
|             ); |             ); | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             event.setBuild(false); |             event.setBuild(false); | ||||||
| @@ -327,41 +310,55 @@ public class PaperListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); |         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|  |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) { |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( | ||||||
|  |                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD | ||||||
|  |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) |                         TagResolver.resolver( | ||||||
|  |                                 "node", | ||||||
|  |                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD) | ||||||
|  |                         ) | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) |                         TagResolver.resolver( | ||||||
|  |                                 "node", | ||||||
|  |                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED) | ||||||
|  |                         ) | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |             if (!plot.getFlag(ProjectilesFlag.class)) { | ||||||
|  |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onAsyncTabCompletion(final AsyncTabCompleteEvent event) { |     public void onAsyncTabCompletion(final AsyncTabCompleteEvent event) { | ||||||
| @@ -403,4 +400,52 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true) | ||||||
|  |     public void onBeaconEffect(final BeaconEffectEvent event) { | ||||||
|  |         Block block = event.getBlock(); | ||||||
|  |         Location beaconLocation = BukkitUtil.adapt(block.getLocation()); | ||||||
|  |         Plot beaconPlot = beaconLocation.getPlot(); | ||||||
|  |  | ||||||
|  |         PlotArea area = beaconLocation.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Player player = event.getPlayer(); | ||||||
|  |         Location playerLocation = BukkitUtil.adapt(player.getLocation()); | ||||||
|  |  | ||||||
|  |         PlotPlayer<Player> plotPlayer = BukkitUtil.adapt(player); | ||||||
|  |         Plot playerStandingPlot = playerLocation.getPlot(); | ||||||
|  |         if (playerStandingPlot == null) { | ||||||
|  |             FlagContainer container = area.getRoadFlagContainer(); | ||||||
|  |             if (!getBooleanFlagValue(container, BeaconEffectsFlag.class, true) || | ||||||
|  |                     (beaconPlot != null && Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW)) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         FlagContainer container = playerStandingPlot.getFlagContainer(); | ||||||
|  |         boolean plotBeaconEffects = getBooleanFlagValue(container, BeaconEffectsFlag.class, true); | ||||||
|  |         if (playerStandingPlot.equals(beaconPlot)) { | ||||||
|  |             if (!plotBeaconEffects) { | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |             } | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (!plotBeaconEffects || Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private boolean getBooleanFlagValue( | ||||||
|  |             @NonNull FlagContainer container, | ||||||
|  |             @NonNull Class<? extends BooleanFlag<?>> flagClass, | ||||||
|  |             boolean defaultValue | ||||||
|  |     ) { | ||||||
|  |         BooleanFlag<?> flag = container.getFlag(flagClass); | ||||||
|  |         return flag == null ? defaultValue : flag.getValue(); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,94 +0,0 @@ | |||||||
| /* |  | ||||||
|  *       _____  _       _    _____                                _ |  | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  | ||||||
|  *     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 <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.listener; |  | ||||||
|  |  | ||||||
| import com.google.inject.Inject; |  | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; |  | ||||||
| import com.plotsquared.core.configuration.Settings; |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; |  | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.player.PlotPlayer; |  | ||||||
| import com.plotsquared.core.plot.PlotArea; |  | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; |  | ||||||
| import net.kyori.adventure.text.minimessage.Template; |  | ||||||
| import org.bukkit.block.Banner; |  | ||||||
| import org.bukkit.block.Beacon; |  | ||||||
| import org.bukkit.block.BlockState; |  | ||||||
| import org.bukkit.block.CommandBlock; |  | ||||||
| import org.bukkit.block.Comparator; |  | ||||||
| import org.bukkit.block.Conduit; |  | ||||||
| import org.bukkit.block.Container; |  | ||||||
| import org.bukkit.block.CreatureSpawner; |  | ||||||
| import org.bukkit.block.DaylightDetector; |  | ||||||
| import org.bukkit.block.EnchantingTable; |  | ||||||
| import org.bukkit.block.EndGateway; |  | ||||||
| import org.bukkit.block.EnderChest; |  | ||||||
| import org.bukkit.block.Jukebox; |  | ||||||
| import org.bukkit.block.Sign; |  | ||||||
| import org.bukkit.block.Skull; |  | ||||||
| import org.bukkit.block.Structure; |  | ||||||
| import org.bukkit.block.data.type.Bed; |  | ||||||
| import org.bukkit.event.EventHandler; |  | ||||||
| import org.bukkit.event.block.BlockPlaceEvent; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
|  |  | ||||||
| public class PaperListener113 extends PaperListener { |  | ||||||
|  |  | ||||||
|     @Inject |  | ||||||
|     public PaperListener113(@NonNull PlotAreaManager plotAreaManager) { |  | ||||||
|         super(plotAreaManager); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler |  | ||||||
|     public void onBlockPlace(BlockPlaceEvent event) { |  | ||||||
|         if (!Settings.Paper_Components.TILE_ENTITY_CHECK || !Settings.Enabled_Components.CHUNK_PROCESSOR) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         BlockState state = event.getBlock().getState(false); |  | ||||||
|         if (!(state instanceof Banner || state instanceof Beacon || state instanceof Bed || state instanceof CommandBlock |  | ||||||
|                 || state instanceof Comparator || state instanceof Conduit || state instanceof Container || state instanceof CreatureSpawner |  | ||||||
|                 || state instanceof DaylightDetector || state instanceof EnchantingTable || state instanceof EnderChest || state instanceof EndGateway |  | ||||||
|                 || state instanceof Jukebox || state instanceof Sign || state instanceof Skull || state instanceof Structure)) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         final Location location = BukkitUtil.adapt(event.getBlock().getLocation()); |  | ||||||
|         final PlotArea plotArea = location.getPlotArea(); |  | ||||||
|         if (plotArea == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         final int tileEntityCount = event.getBlock().getChunk().getTileEntities(false).length; |  | ||||||
|         if (tileEntityCount >= Settings.Chunk_Processor.MAX_TILES) { |  | ||||||
|             final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer()); |  | ||||||
|             plotPlayer.sendMessage( |  | ||||||
|                     TranslatableCaption.of("errors.tile_entity_cap_reached"), |  | ||||||
|                     Template.of("amount", String.valueOf(Settings.Chunk_Processor.MAX_TILES)) |  | ||||||
|             ); |  | ||||||
|             event.setCancelled(true); |  | ||||||
|             event.setBuild(false); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -35,9 +28,11 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.PlotHandler; | import com.plotsquared.core.plot.PlotHandler; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.LivingEntity; | import org.bukkit.entity.LivingEntity; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -95,7 +90,7 @@ public class ProjectileEventListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler(ignoreCancelled = true) | ||||||
|     public void onProjectileLaunch(ProjectileLaunchEvent event) { |     public void onProjectileLaunch(ProjectileLaunchEvent event) { | ||||||
|         Projectile entity = event.getEntity(); |         Projectile entity = event.getEntity(); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
| @@ -103,41 +98,55 @@ public class ProjectileEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         PlotArea area = location.getPlotArea(); | ||||||
|  |         if (area == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); |         PlotPlayer<Player> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|  |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) { |             if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( | ||||||
|  |                     Permission.PERMISSION_ADMIN_PROJECTILE_ROAD | ||||||
|  |             )) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD)) |                         TagResolver.resolver( | ||||||
|  |                                 "node", | ||||||
|  |                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_ROAD) | ||||||
|  |                         ) | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.hasOwner()) { |         } else if (!plot.hasOwner()) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |             if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("permission.no_permission_event"), |                         TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) |                         TagResolver.resolver( | ||||||
|  |                                 "node", | ||||||
|  |                                 Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED) | ||||||
|  |                         ) | ||||||
|                 ); |                 ); | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!plot.isAdded(pp.getUUID())) { |         } else if (!plot.isAdded(pp.getUUID())) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |             if (!plot.getFlag(ProjectilesFlag.class)) { | ||||||
|  |                 if (!pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                         Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onProjectileHit(ProjectileHitEvent event) { |     public void onProjectileHit(ProjectileHitEvent event) { | ||||||
| @@ -153,16 +162,32 @@ public class ProjectileEventListener implements Listener { | |||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
|         if (shooter instanceof Player) { |         if (shooter instanceof Player) { | ||||||
|  |             if (!((Player) shooter).isOnline()) { | ||||||
|  |                 if (plot != null) { | ||||||
|  |                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { | ||||||
|  |                         return; | ||||||
|  |                     } | ||||||
|  |                 } else if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true)) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 entity.remove(); | ||||||
|  |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |                 if (!PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true) && !pp.hasPermission( | ||||||
|  |                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED | ||||||
|  |                 )) { | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.isAdded(pp.getUUID()) || Permissions |             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( | ||||||
|                     .hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_OTHER)) { |                     ProjectilesFlag.class)) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             entity.remove(); |             entity.remove(); | ||||||
| @@ -186,7 +211,6 @@ public class ProjectileEventListener implements Listener { | |||||||
|             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { |             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -38,42 +31,39 @@ import org.bukkit.event.Listener; | |||||||
| import org.bukkit.event.world.ChunkEvent; | import org.bukkit.event.world.ChunkEvent; | ||||||
| import org.bukkit.event.world.ChunkLoadEvent; | import org.bukkit.event.world.ChunkLoadEvent; | ||||||
|  |  | ||||||
| import java.lang.reflect.Field; |  | ||||||
| import java.lang.reflect.Method; | import java.lang.reflect.Method; | ||||||
|  |  | ||||||
| import static com.plotsquared.core.util.ReflectionUtils.getRefClass; | import static com.plotsquared.core.util.ReflectionUtils.getRefClass; | ||||||
|  |  | ||||||
| public class SingleWorldListener implements Listener { | public class SingleWorldListener implements Listener { | ||||||
|  |  | ||||||
|     private final Method methodGetHandleChunk; |     private final Method methodSetUnsaved; | ||||||
|     private Field shouldSave; |     private Method methodGetHandleChunk; | ||||||
|  |     private Object objChunkStatusFull = null; | ||||||
|  |  | ||||||
|     public SingleWorldListener() throws Exception { |     public SingleWorldListener() throws Exception { | ||||||
|         ReflectionUtils.RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); |         ReflectionUtils.RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); | ||||||
|         this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle").getRealMethod(); |         ReflectionUtils.RefClass classChunkAccess = getRefClass("net.minecraft.world.level.chunk.IChunkAccess"); | ||||||
|  |         this.methodSetUnsaved = classChunkAccess.getMethod("a", boolean.class).getRealMethod(); | ||||||
|         try { |         try { | ||||||
|             if (PlotSquared.platform().serverVersion()[1] < 17) { |             this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle").getRealMethod(); | ||||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("{nms}.Chunk"); |         } catch (NoSuchMethodException ignored) { | ||||||
|                 if (PlotSquared.platform().serverVersion()[1] == 13) { |             try { | ||||||
|                     this.shouldSave = classChunk.getField("mustSave").getRealField(); |                 ReflectionUtils.RefClass classChunkStatus = getRefClass("net.minecraft.world.level.chunk.ChunkStatus"); | ||||||
|                 } else { |                 this.objChunkStatusFull = classChunkStatus.getRealClass().getField("n").get(null); | ||||||
|                     this.shouldSave = classChunk.getField("s").getRealField(); |                 this.methodGetHandleChunk = classCraftChunk.getMethod("getHandle", classChunkStatus.getRealClass()).getRealMethod(); | ||||||
|  |             } catch (NoSuchMethodException ex) { | ||||||
|  |                 throw new RuntimeException(ex); | ||||||
|             } |             } | ||||||
|             } else { |  | ||||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); |  | ||||||
|                 this.shouldSave = classChunk.getField("r").getRealField(); |  | ||||||
|             } |  | ||||||
|         } catch (NoSuchFieldException e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void markChunkAsClean(Chunk chunk) { |     public void markChunkAsClean(Chunk chunk) { | ||||||
|         try { |         try { | ||||||
|             Object nmsChunk = methodGetHandleChunk.invoke(chunk); |             Object nmsChunk = objChunkStatusFull != null | ||||||
|             if (shouldSave != null) { |                     ? this.methodGetHandleChunk.invoke(chunk, objChunkStatusFull) | ||||||
|                 this.shouldSave.set(nmsChunk, false); |                     : this.methodGetHandleChunk.invoke(chunk); | ||||||
|             } |             methodSetUnsaved.invoke(nmsChunk, false); | ||||||
|         } catch (Throwable e) { |         } catch (Throwable e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
| @@ -89,7 +79,12 @@ public class SingleWorldListener implements Listener { | |||||||
|         if (!SinglePlotArea.isSinglePlotWorld(name)) { |         if (!SinglePlotArea.isSinglePlotWorld(name)) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |         int x = event.getChunk().getX(); | ||||||
|  |         int z = event.getChunk().getZ(); | ||||||
|  |         if (x < 16 && x > -16 && z < 16 && z > -16) { | ||||||
|  |             // Allow spawn to generate | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         markChunkAsClean(event.getChunk()); |         markChunkAsClean(event.getChunk()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,57 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
|  | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.plotsquared.core.plot.Plot; | ||||||
|  | import com.plotsquared.core.plot.flag.FlagContainer; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; | ||||||
|  | import org.bukkit.entity.Entity; | ||||||
|  | import org.bukkit.event.EventHandler; | ||||||
|  | import org.bukkit.event.Listener; | ||||||
|  | import org.bukkit.event.entity.EntityPotionEffectEvent; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Fallback listener for paper events on spigot | ||||||
|  |  */ | ||||||
|  | public class SpigotListener implements Listener { | ||||||
|  |  | ||||||
|  |     @EventHandler(ignoreCancelled = true) | ||||||
|  |     public void onEffect(@NonNull EntityPotionEffectEvent event) { | ||||||
|  |         if (event.getCause() != EntityPotionEffectEvent.Cause.BEACON) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         Entity entity = event.getEntity(); | ||||||
|  |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|  |         Plot plot = location.getPlot(); | ||||||
|  |         if (plot == null) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         FlagContainer container = plot.getFlagContainer(); | ||||||
|  |         BeaconEffectsFlag effectsEnabled = container.getFlag(BeaconEffectsFlag.class); | ||||||
|  |         if (effectsEnabled != null && !effectsEnabled.getValue()) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,70 +0,0 @@ | |||||||
| /* |  | ||||||
|  *       _____  _       _    _____                                _ |  | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  | ||||||
|  *     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 <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.managers; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| import com.google.inject.Singleton; |  | ||||||
| import org.bukkit.World; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; |  | ||||||
| import se.hyperver.hyperverse.Hyperverse; |  | ||||||
| import se.hyperver.hyperverse.world.WorldConfiguration; |  | ||||||
| import se.hyperver.hyperverse.world.WorldConfigurationBuilder; |  | ||||||
| import se.hyperver.hyperverse.world.WorldFeatures; |  | ||||||
| import se.hyperver.hyperverse.world.WorldType; |  | ||||||
|  |  | ||||||
| Hyperverse implementation is currently put on ice until Hyperverse is released on a stable line and deployed to the central |  | ||||||
| repository. |  | ||||||
|  |  | ||||||
| @Singleton |  | ||||||
| public class HyperverseWorldManager extends BukkitWorldManager { |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public @Nullable World handleWorldCreation(@NonNull String worldName, @Nullable String generator) { |  | ||||||
|         // First let Bukkit register the world |  | ||||||
|         this.setGenerator(worldName, generator); |  | ||||||
|         // Create the world |  | ||||||
|         final WorldConfigurationBuilder worldConfigurationBuilder = WorldConfiguration.builder() |  | ||||||
|                 .setName(worldName).setType(WorldType.OVER_WORLD); |  | ||||||
|         if (generator != null) { |  | ||||||
|             worldConfigurationBuilder.setGenerator(generator).setWorldFeatures(WorldFeatures.FLATLAND); |  | ||||||
|         } |  | ||||||
|         try { |  | ||||||
|             return Hyperverse.getApi().createWorld(worldConfigurationBuilder.createWorldConfiguration()) |  | ||||||
|                     .getBukkitWorld(); |  | ||||||
|         } catch (final Exception e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public String getName() { |  | ||||||
|         return "bukkit-hyperverse"; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  */ |  | ||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -37,8 +30,9 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  * |  * | ||||||
|  * @deprecated Deprecated and scheduled for removal without replacement |  * @deprecated Deprecated and scheduled for removal without replacement | ||||||
|  *         in favor of the build in setup wizard. |  *         in favor of the build in setup wizard. | ||||||
|  |  *         However, this class will be kept around for a while, given it's not a maintenance burden. | ||||||
|  */ |  */ | ||||||
| @Deprecated(forRemoval = true, since = "6.0.0") | @Deprecated | ||||||
| @Singleton | @Singleton | ||||||
| public class MultiverseWorldManager extends BukkitWorldManager { | public class MultiverseWorldManager extends BukkitWorldManager { | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -59,7 +52,7 @@ public class MVdWPlaceholders { | |||||||
|  |  | ||||||
|     @Subscribe |     @Subscribe | ||||||
|     public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) { |     public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) { | ||||||
|         this.addPlaceholder(event.getPlaceholder()); |         this.addPlaceholder(event.placeholder()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void addPlaceholder(final @NonNull Placeholder placeholder) { |     private void addPlaceholder(final @NonNull Placeholder placeholder) { | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -94,4 +87,9 @@ public class BukkitOfflinePlayer implements OfflinePlotPlayer { | |||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean hasPermission(@NonNull final String permission, final boolean notify) { | ||||||
|  |         return hasPermission(permission); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -54,13 +47,13 @@ import org.bukkit.event.EventException; | |||||||
| import org.bukkit.event.player.PlayerTeleportEvent; | import org.bukkit.event.player.PlayerTeleportEvent; | ||||||
| import org.bukkit.permissions.PermissionAttachmentInfo; | import org.bukkit.permissions.PermissionAttachmentInfo; | ||||||
| import org.bukkit.plugin.RegisteredListener; | import org.bukkit.plugin.RegisteredListener; | ||||||
|  | import org.bukkit.potion.PotionEffectType; | ||||||
| import org.checkerframework.checker.index.qual.NonNegative; | import org.checkerframework.checker.index.qual.NonNegative; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.stream.Collectors; |  | ||||||
|  |  | ||||||
| import static com.sk89q.worldedit.world.gamemode.GameModes.ADVENTURE; | import static com.sk89q.worldedit.world.gamemode.GameModes.ADVENTURE; | ||||||
| import static com.sk89q.worldedit.world.gamemode.GameModes.CREATIVE; | import static com.sk89q.worldedit.world.gamemode.GameModes.CREATIVE; | ||||||
| @@ -74,24 +67,15 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|     private String name; |     private String name; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * <p>Please do not use this method. Instead use |  | ||||||
|      * BukkitUtil.getPlayer(Player), as it caches player objects.</p> |  | ||||||
|      * |  | ||||||
|      * @param plotAreaManager   PlotAreaManager instance |      * @param plotAreaManager   PlotAreaManager instance | ||||||
|      * @param eventDispatcher   EventDispatcher instance |      * @param eventDispatcher   EventDispatcher instance | ||||||
|      * @param player            Bukkit player instance |      * @param player            Bukkit player instance | ||||||
|      * @param permissionHandler PermissionHandler instance |      * @param permissionHandler PermissionHandler instance | ||||||
|      */ |      */ | ||||||
|     public BukkitPlayer( |     BukkitPlayer( | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, final @NonNull EventDispatcher eventDispatcher, |             final @NonNull PlotAreaManager plotAreaManager, | ||||||
|             final @NonNull Player player, final @NonNull PermissionHandler permissionHandler |             final @NonNull EventDispatcher eventDispatcher, | ||||||
|     ) { |             final @NonNull Player player, | ||||||
|         this(plotAreaManager, eventDispatcher, player, false, permissionHandler); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public BukkitPlayer( |  | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, final @NonNull |  | ||||||
|             EventDispatcher eventDispatcher, final @NonNull Player player, |  | ||||||
|             final boolean realPlayer, |             final boolean realPlayer, | ||||||
|             final @NonNull PermissionHandler permissionHandler |             final @NonNull PermissionHandler permissionHandler | ||||||
|     ) { |     ) { | ||||||
| @@ -192,6 +176,10 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|             final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions(); |             final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions(); | ||||||
|             if (!effective.isEmpty()) { |             if (!effective.isEmpty()) { | ||||||
|                 for (PermissionAttachmentInfo attach : effective) { |                 for (PermissionAttachmentInfo attach : effective) { | ||||||
|  |                     // Ignore all "false" permissions | ||||||
|  |                     if (!attach.getValue()) { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|                     String permStr = attach.getPermission(); |                     String permStr = attach.getPermission(); | ||||||
|                     if (permStr.startsWith(stubPlus)) { |                     if (permStr.startsWith(stubPlus)) { | ||||||
|                         hasAny = true; |                         hasAny = true; | ||||||
| @@ -355,6 +343,14 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|         return BukkitUtil.BUKKIT_AUDIENCES.player(this.player); |         return BukkitUtil.BUKKIT_AUDIENCES.player(this.player); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public void removeEffect(@NonNull String name) { | ||||||
|  |         PotionEffectType type = PotionEffectType.getByName(name); | ||||||
|  |         if (type != null) { | ||||||
|  |             player.removePotionEffect(type); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean canSee(final PlotPlayer<?> other) { |     public boolean canSee(final PlotPlayer<?> other) { | ||||||
|         if (other instanceof ConsolePlayer) { |         if (other instanceof ConsolePlayer) { | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -77,7 +70,7 @@ public class BukkitPlayerManager extends PlayerManager<BukkitPlayer, Player> { | |||||||
|         if (player == null || !player.isOnline()) { |         if (player == null || !player.isOnline()) { | ||||||
|             throw new NoSuchPlayerException(uuid); |             throw new NoSuchPlayerException(uuid); | ||||||
|         } |         } | ||||||
|         return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, this.permissionHandler); |         return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, false, this.permissionHandler); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Nullable |     @Nullable | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -74,11 +67,13 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|     private final Consumer<Throwable> throwableConsumer; |     private final Consumer<Throwable> throwableConsumer; | ||||||
|     private final boolean unloadAfter; |     private final boolean unloadAfter; | ||||||
|     private final int totalSize; |     private final int totalSize; | ||||||
|  |  | ||||||
|     private final AtomicInteger expectedSize; |     private final AtomicInteger expectedSize; | ||||||
|  |     private final AtomicInteger loadingChunks = new AtomicInteger(); | ||||||
|  |     private final boolean forceSync; | ||||||
|  |  | ||||||
|     private int batchSize; |     private int batchSize; | ||||||
|     private PlotSquaredTask task; |     private PlotSquaredTask task; | ||||||
|     private boolean shouldCancel; |     private volatile boolean shouldCancel; | ||||||
|     private boolean finished; |     private boolean finished; | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
| @@ -90,8 +85,9 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|             @Assisted final @NonNull Collection<BlockVector2> requestedChunks, |             @Assisted final @NonNull Collection<BlockVector2> requestedChunks, | ||||||
|             @Assisted final @NonNull Runnable whenDone, |             @Assisted final @NonNull Runnable whenDone, | ||||||
|             @Assisted final @NonNull Consumer<Throwable> throwableConsumer, |             @Assisted final @NonNull Consumer<Throwable> throwableConsumer, | ||||||
|             @Assisted final boolean unloadAfter, |             @Assisted("unloadAfter") final boolean unloadAfter, | ||||||
|             @Assisted final @NonNull Collection<ProgressSubscriber> progressSubscribers |             @Assisted final @NonNull Collection<ProgressSubscriber> progressSubscribers, | ||||||
|  |             @Assisted("forceSync") final boolean forceSync | ||||||
|     ) { |     ) { | ||||||
|         this.requestedChunks = new LinkedBlockingQueue<>(requestedChunks); |         this.requestedChunks = new LinkedBlockingQueue<>(requestedChunks); | ||||||
|         this.availableChunks = new LinkedBlockingQueue<>(); |         this.availableChunks = new LinkedBlockingQueue<>(); | ||||||
| @@ -106,14 +102,27 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|         this.plugin = JavaPlugin.getPlugin(BukkitPlatform.class); |         this.plugin = JavaPlugin.getPlugin(BukkitPlatform.class); | ||||||
|         this.bukkitWorld = Bukkit.getWorld(world.getName()); |         this.bukkitWorld = Bukkit.getWorld(world.getName()); | ||||||
|         this.progressSubscribers.addAll(progressSubscribers); |         this.progressSubscribers.addAll(progressSubscribers); | ||||||
|  |         this.forceSync = forceSync; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void start() { |     public void start() { | ||||||
|  |         if (!forceSync) { | ||||||
|             // Request initial batch |             // Request initial batch | ||||||
|             this.requestBatch(); |             this.requestBatch(); | ||||||
|             // Wait until next tick to give the chunks a chance to be loaded |             // Wait until next tick to give the chunks a chance to be loaded | ||||||
|             TaskManager.runTaskLater(() -> task = TaskManager.runTaskRepeat(this, TaskTime.ticks(1)), TaskTime.ticks(1)); |             TaskManager.runTaskLater(() -> task = TaskManager.runTaskRepeat(this, TaskTime.ticks(1)), TaskTime.ticks(1)); | ||||||
|  |         } else { | ||||||
|  |             try { | ||||||
|  |                 while (!shouldCancel && !requestedChunks.isEmpty()) { | ||||||
|  |                     chunkConsumer.accept(requestedChunks.poll()); | ||||||
|  |                 } | ||||||
|  |             } catch (Throwable t) { | ||||||
|  |                 throwableConsumer.accept(t); | ||||||
|  |             } finally { | ||||||
|  |                 finish(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -130,7 +139,9 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|             for (final ProgressSubscriber subscriber : this.progressSubscribers) { |             for (final ProgressSubscriber subscriber : this.progressSubscribers) { | ||||||
|                 subscriber.notifyEnd(); |                 subscriber.notifyEnd(); | ||||||
|             } |             } | ||||||
|  |             if (task != null) { | ||||||
|                 task.cancel(); |                 task.cancel(); | ||||||
|  |             } | ||||||
|             finished = true; |             finished = true; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -150,6 +161,13 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|  |  | ||||||
|         Chunk chunk = this.availableChunks.poll(); |         Chunk chunk = this.availableChunks.poll(); | ||||||
|         if (chunk == null) { |         if (chunk == null) { | ||||||
|  |             if (this.availableChunks.isEmpty()) { | ||||||
|  |                 if (this.requestedChunks.isEmpty() && loadingChunks.get() == 0) { | ||||||
|  |                     finish(); | ||||||
|  |                 } else { | ||||||
|  |                     requestBatch(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         long[] iterationTime = new long[2]; |         long[] iterationTime = new long[2]; | ||||||
| @@ -197,9 +215,11 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|         BlockVector2 chunk; |         BlockVector2 chunk; | ||||||
|         for (int i = 0; i < this.batchSize && (chunk = this.requestedChunks.poll()) != null; i++) { |         for (int i = 0; i < this.batchSize && (chunk = this.requestedChunks.poll()) != null; i++) { | ||||||
|             // This required PaperLib to be bumped to version 1.0.4 to mark the request as urgent |             // This required PaperLib to be bumped to version 1.0.4 to mark the request as urgent | ||||||
|  |             loadingChunks.incrementAndGet(); | ||||||
|             PaperLib |             PaperLib | ||||||
|                     .getChunkAtAsync(this.bukkitWorld, chunk.getX(), chunk.getZ(), true, true) |                     .getChunkAtAsync(this.bukkitWorld, chunk.getX(), chunk.getZ(), true, true) | ||||||
|                     .whenComplete((chunkObject, throwable) -> { |                     .whenComplete((chunkObject, throwable) -> { | ||||||
|  |                         loadingChunks.decrementAndGet(); | ||||||
|                         if (throwable != null) { |                         if (throwable != null) { | ||||||
|                             throwable.printStackTrace(); |                             throwable.printStackTrace(); | ||||||
|                             // We want one less because this couldn't be processed |                             // We want one less because this couldn't be processed | ||||||
| @@ -219,9 +239,11 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|      * server's main thread. |      * server's main thread. | ||||||
|      */ |      */ | ||||||
|     private void processChunk(final @NonNull Chunk chunk) { |     private void processChunk(final @NonNull Chunk chunk) { | ||||||
|  |         /* Chunk#isLoaded does not necessarily return true shortly after PaperLib#getChunkAtAsync completes, but the chunk is | ||||||
|  |         still loaded. | ||||||
|         if (!chunk.isLoaded()) { |         if (!chunk.isLoaded()) { | ||||||
|             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ())); |             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ()); | ||||||
|         } |         }*/ | ||||||
|         if (finished) { |         if (finished) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -51,6 +44,7 @@ import com.sk89q.worldedit.world.biome.BiomeType; | |||||||
| import com.sk89q.worldedit.world.block.BaseBlock; | import com.sk89q.worldedit.world.block.BaseBlock; | ||||||
| import com.sk89q.worldedit.world.block.BlockState; | import com.sk89q.worldedit.world.block.BlockState; | ||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
|  | import org.bukkit.Chunk; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.Container; | import org.bukkit.block.Container; | ||||||
| import org.bukkit.block.data.BlockData; | import org.bukkit.block.data.BlockData; | ||||||
| @@ -62,10 +56,27 @@ import java.util.function.Consumer; | |||||||
|  |  | ||||||
| public class BukkitQueueCoordinator extends BasicQueueCoordinator { | public class BukkitQueueCoordinator extends BasicQueueCoordinator { | ||||||
|  |  | ||||||
|     private final SideEffectSet noSideEffectSet; |     private static final SideEffectSet NO_SIDE_EFFECT_SET; | ||||||
|     private final SideEffectSet lightingSideEffectSet; |     private static final SideEffectSet EDGE_SIDE_EFFECT_SET; | ||||||
|     private final SideEffectSet edgeSideEffectSet; |     private static final SideEffectSet LIGHTING_SIDE_EFFECT_SET; | ||||||
|     private final SideEffectSet edgeLightingSideEffectSet; |     private static final SideEffectSet EDGE_LIGHTING_SIDE_EFFECT_SET; | ||||||
|  |  | ||||||
|  |     static { | ||||||
|  |         NO_SIDE_EFFECT_SET = SideEffectSet.none().with(SideEffect.LIGHTING, SideEffect.State.OFF).with( | ||||||
|  |                 SideEffect.NEIGHBORS, | ||||||
|  |                 SideEffect.State.OFF | ||||||
|  |         ); | ||||||
|  |         EDGE_SIDE_EFFECT_SET = SideEffectSet.none().with(SideEffect.UPDATE, SideEffect.State.ON).with( | ||||||
|  |                 SideEffect.NEIGHBORS, | ||||||
|  |                 SideEffect.State.ON | ||||||
|  |         ); | ||||||
|  |         LIGHTING_SIDE_EFFECT_SET = SideEffectSet.none().with(SideEffect.NEIGHBORS, SideEffect.State.OFF); | ||||||
|  |         EDGE_LIGHTING_SIDE_EFFECT_SET = SideEffectSet.none().with(SideEffect.UPDATE, SideEffect.State.ON).with( | ||||||
|  |                 SideEffect.NEIGHBORS, | ||||||
|  |                 SideEffect.State.ON | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private org.bukkit.World bukkitWorld; |     private org.bukkit.World bukkitWorld; | ||||||
|     @Inject |     @Inject | ||||||
|     private ChunkCoordinatorBuilderFactory chunkCoordinatorBuilderFactory; |     private ChunkCoordinatorBuilderFactory chunkCoordinatorBuilderFactory; | ||||||
| @@ -76,19 +87,6 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|     @Inject |     @Inject | ||||||
|     public BukkitQueueCoordinator(@NonNull World world) { |     public BukkitQueueCoordinator(@NonNull World world) { | ||||||
|         super(world); |         super(world); | ||||||
|         noSideEffectSet = SideEffectSet.none().with(SideEffect.LIGHTING, SideEffect.State.OFF).with( |  | ||||||
|                 SideEffect.NEIGHBORS, |  | ||||||
|                 SideEffect.State.OFF |  | ||||||
|         ); |  | ||||||
|         lightingSideEffectSet = SideEffectSet.none().with(SideEffect.NEIGHBORS, SideEffect.State.OFF); |  | ||||||
|         edgeSideEffectSet = noSideEffectSet.with(SideEffect.UPDATE, SideEffect.State.ON).with( |  | ||||||
|                 SideEffect.NEIGHBORS, |  | ||||||
|                 SideEffect.State.ON |  | ||||||
|         ); |  | ||||||
|         edgeLightingSideEffectSet = noSideEffectSet.with(SideEffect.UPDATE, SideEffect.State.ON).with( |  | ||||||
|                 SideEffect.NEIGHBORS, |  | ||||||
|                 SideEffect.State.ON |  | ||||||
|         ); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -111,8 +109,8 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|     public boolean enqueue() { |     public boolean enqueue() { | ||||||
|         final Clipboard regenClipboard; |         final Clipboard regenClipboard; | ||||||
|         if (isRegen()) { |         if (isRegen()) { | ||||||
|             BlockVector3 start = BlockVector3.at(getRegenStart()[0] << 4, 0, getRegenStart()[1] << 4); |             BlockVector3 start = BlockVector3.at(getRegenStart()[0] << 4, getMinY(), getRegenStart()[1] << 4); | ||||||
|             BlockVector3 end = BlockVector3.at((getRegenEnd()[0] << 4) + 15, 255, (getRegenEnd()[1] << 4) + 15); |             BlockVector3 end = BlockVector3.at((getRegenEnd()[0] << 4) + 15, getMaxY(), (getRegenEnd()[1] << 4) + 15); | ||||||
|             Region region = new CuboidRegion(start, end); |             Region region = new CuboidRegion(start, end); | ||||||
|             regenClipboard = new BlockArrayClipboard(region); |             regenClipboard = new BlockArrayClipboard(region); | ||||||
|             regenClipboard.setOrigin(start); |             regenClipboard.setOrigin(start); | ||||||
| @@ -134,7 +132,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                 int sx = blockVector2.getX() << 4; |                 int sx = blockVector2.getX() << 4; | ||||||
|                 int sz = blockVector2.getZ() << 4; |                 int sz = blockVector2.getZ() << 4; | ||||||
|                 if (isRegenChunk) { |                 if (isRegenChunk) { | ||||||
|                     for (int layer = 0; layer < 16; layer++) { |                     for (int layer = getMinLayer(); layer <= getMaxLayer(); layer++) { | ||||||
|                         for (int y = 0; y < 16; y++) { |                         for (int y = 0; y < 16; y++) { | ||||||
|                             for (int x = 0; x < 16; x++) { |                             for (int x = 0; x < 16; x++) { | ||||||
|                                 for (int z = 0; z < 16; z++) { |                                 for (int z = 0; z < 16; z++) { | ||||||
| @@ -170,7 +168,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                             int lx = ChunkUtil.getX(j); |                             int lx = ChunkUtil.getX(j); | ||||||
|                             int lz = ChunkUtil.getZ(j); |                             int lz = ChunkUtil.getZ(j); | ||||||
|                             int x = sx + lx; |                             int x = sx + lx; | ||||||
|                             int y = ChunkUtil.getY(layer, j); |                             int y = ChunkUtil.getY(layer + localChunk.getMinSection(), j); | ||||||
|                             int z = sz + lz; |                             int z = sz + lz; | ||||||
|                             boolean edge = Settings.QUEUE.UPDATE_EDGES && isEdge(y >> 4, lx, y & 15, lz, blockVector2, |                             boolean edge = Settings.QUEUE.UPDATE_EDGES && isEdge(y >> 4, lx, y & 15, lz, blockVector2, | ||||||
|                                     localChunk |                                     localChunk | ||||||
| @@ -179,7 +177,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 for (int layer = 0; layer < localChunk.getBaseblocks().length; layer++) { |                 for (int layer = 0; layer < localChunk.getBiomes().length; layer++) { | ||||||
|                     BiomeType[] biomesLayer = localChunk.getBiomes()[layer]; |                     BiomeType[] biomesLayer = localChunk.getBiomes()[layer]; | ||||||
|                     if (biomesLayer == null) { |                     if (biomesLayer == null) { | ||||||
|                         continue; |                         continue; | ||||||
| @@ -201,7 +199,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                     localChunk.getTiles().forEach((blockVector3, tag) -> { |                     localChunk.getTiles().forEach((blockVector3, tag) -> { | ||||||
|                         try { |                         try { | ||||||
|                             BaseBlock block = getWorld().getBlock(blockVector3).toBaseBlock(tag); |                             BaseBlock block = getWorld().getBlock(blockVector3).toBaseBlock(tag); | ||||||
|                             getWorld().setBlock(blockVector3, block, noSideEffectSet); |                             getWorld().setBlock(blockVector3, block, getSideEffectSet(SideEffectState.NONE)); | ||||||
|                         } catch (WorldEditException ignored) { |                         } catch (WorldEditException ignored) { | ||||||
|                             StateWrapper sw = new StateWrapper(tag); |                             StateWrapper sw = new StateWrapper(tag); | ||||||
|                             sw.restoreTag(getWorld().getName(), blockVector3.getX(), blockVector3.getY(), blockVector3.getZ()); |                             sw.restoreTag(getWorld().getName(), blockVector3.getX(), blockVector3.getY(), blockVector3.getZ()); | ||||||
| @@ -230,6 +228,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                         .withConsumer(consumer) |                         .withConsumer(consumer) | ||||||
|                         .unloadAfter(isUnloadAfter()) |                         .unloadAfter(isUnloadAfter()) | ||||||
|                         .withProgressSubscribers(getProgressSubscribers()) |                         .withProgressSubscribers(getProgressSubscribers()) | ||||||
|  |                         .forceSync(isForceSync()) | ||||||
|                         .build(); |                         .build(); | ||||||
|         return super.enqueue(); |         return super.enqueue(); | ||||||
|     } |     } | ||||||
| @@ -258,15 +257,21 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|             } |             } | ||||||
|             SideEffectSet sideEffectSet; |             SideEffectSet sideEffectSet; | ||||||
|             if (lighting) { |             if (lighting) { | ||||||
|                 sideEffectSet = edge ? edgeLightingSideEffectSet : lightingSideEffectSet; |                 sideEffectSet = getSideEffectSet(edge ? SideEffectState.EDGE_LIGHTING : SideEffectState.LIGHTING); | ||||||
|             } else { |             } else { | ||||||
|                 sideEffectSet = edge ? edgeSideEffectSet : noSideEffectSet; |                 sideEffectSet = getSideEffectSet(edge ? SideEffectState.EDGE : SideEffectState.NONE); | ||||||
|             } |             } | ||||||
|             getWorld().setBlock(loc, block, sideEffectSet); |             getWorld().setBlock(loc, block, sideEffectSet); | ||||||
|         } catch (WorldEditException ignored) { |         } catch (WorldEditException ignored) { | ||||||
|             // Fallback to not so nice method |             // Fallback to not so nice method | ||||||
|             BlockData blockData = BukkitAdapter.adapt(block); |             BlockData blockData = BukkitAdapter.adapt(block); | ||||||
|             Block existing = getBukkitWorld().getBlockAt(x, y, z); |             Block existing; | ||||||
|  |             // Assume a chunk object has been given only when it should have been. | ||||||
|  |             if (getChunkObject() instanceof Chunk chunkObject) { | ||||||
|  |                 existing = chunkObject.getBlock(x & 15, y, z & 15); | ||||||
|  |             } else { | ||||||
|  |                 existing = getBukkitWorld().getBlockAt(x, y, z); | ||||||
|  |             } | ||||||
|             final BlockState existingBaseBlock = BukkitAdapter.adapt(existing.getBlockData()); |             final BlockState existingBaseBlock = BukkitAdapter.adapt(existing.getBlockData()); | ||||||
|             if (BukkitBlockUtil.get(existing).equals(existingBaseBlock) && existing.getBlockData().matches(blockData)) { |             if (BukkitBlockUtil.get(existing).equals(existingBaseBlock) && existing.getBlockData().matches(blockData)) { | ||||||
|                 return; |                 return; | ||||||
| @@ -282,7 +287,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                 CompoundTag tag = block.getNbtData(); |                 CompoundTag tag = block.getNbtData(); | ||||||
|                 StateWrapper sw = new StateWrapper(tag); |                 StateWrapper sw = new StateWrapper(tag); | ||||||
|  |  | ||||||
|                 sw.restoreTag(getWorld().getName(), existing.getX(), existing.getY(), existing.getZ()); |                 sw.restoreTag(existing); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -295,47 +300,48 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private boolean isEdge(int layer, int x, int y, int z, BlockVector2 blockVector2, LocalChunk localChunk) { |     private boolean isEdge(int layer, int x, int y, int z, BlockVector2 blockVector2, LocalChunk localChunk) { | ||||||
|         if (layer == 0 || layer == localChunk.getBaseblocks().length - 1) { |         int layerIndex = (layer - localChunk.getMinSection()); | ||||||
|  |         if (layer == localChunk.getMinSection() || layerIndex == localChunk.getBaseblocks().length - 1) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (x == 0) { |         if (x == 0) { | ||||||
|             LocalChunk localChunkX = getBlockChunks().get(blockVector2.withX(blockVector2.getX() - 1)); |             LocalChunk localChunkX = getBlockChunks().get(blockVector2.withX(blockVector2.getX() - 1)); | ||||||
|             if (localChunkX == null || localChunkX.getBaseblocks()[layer] == null || |             if (localChunkX == null || localChunkX.getBaseblocks()[layerIndex] == null || | ||||||
|                     localChunkX.getBaseblocks()[layer][ChunkUtil.getJ(15, y, z)] != null) { |                     localChunkX.getBaseblocks()[layerIndex][ChunkUtil.getJ(15, y, z)] != null) { | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } else if (x == 15) { |         } else if (x == 15) { | ||||||
|             LocalChunk localChunkX = getBlockChunks().get(blockVector2.withX(blockVector2.getX() + 1)); |             LocalChunk localChunkX = getBlockChunks().get(blockVector2.withX(blockVector2.getX() + 1)); | ||||||
|             if (localChunkX == null || localChunkX.getBaseblocks()[layer] == null || |             if (localChunkX == null || localChunkX.getBaseblocks()[layerIndex] == null || | ||||||
|                     localChunkX.getBaseblocks()[layer][ChunkUtil.getJ(0, y, z)] != null) { |                     localChunkX.getBaseblocks()[layerIndex][ChunkUtil.getJ(0, y, z)] != null) { | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (z == 0) { |         if (z == 0) { | ||||||
|             LocalChunk localChunkZ = getBlockChunks().get(blockVector2.withZ(blockVector2.getZ() - 1)); |             LocalChunk localChunkZ = getBlockChunks().get(blockVector2.withZ(blockVector2.getZ() - 1)); | ||||||
|             if (localChunkZ == null || localChunkZ.getBaseblocks()[layer] == null || |             if (localChunkZ == null || localChunkZ.getBaseblocks()[layerIndex] == null || | ||||||
|                     localChunkZ.getBaseblocks()[layer][ChunkUtil.getJ(x, y, 15)] != null) { |                     localChunkZ.getBaseblocks()[layerIndex][ChunkUtil.getJ(x, y, 15)] != null) { | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } else if (z == 15) { |         } else if (z == 15) { | ||||||
|             LocalChunk localChunkZ = getBlockChunks().get(blockVector2.withZ(blockVector2.getZ() + 1)); |             LocalChunk localChunkZ = getBlockChunks().get(blockVector2.withZ(blockVector2.getZ() + 1)); | ||||||
|             if (localChunkZ == null || localChunkZ.getBaseblocks()[layer] == null || |             if (localChunkZ == null || localChunkZ.getBaseblocks()[layerIndex] == null || | ||||||
|                     localChunkZ.getBaseblocks()[layer][ChunkUtil.getJ(x, y, 0)] != null) { |                     localChunkZ.getBaseblocks()[layerIndex][ChunkUtil.getJ(x, y, 0)] != null) { | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (y == 0) { |         if (y == 0) { | ||||||
|             if (localChunk.getBaseblocks()[layer - 1] == null || |             if (localChunk.getBaseblocks()[layerIndex - 1] == null || | ||||||
|                     localChunk.getBaseblocks()[layer][ChunkUtil.getJ(x, 15, z)] != null) { |                     localChunk.getBaseblocks()[layerIndex][ChunkUtil.getJ(x, 15, z)] != null) { | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } else if (y == 15) { |         } else if (y == 15) { | ||||||
|             if (localChunk.getBaseblocks()[layer + 1] == null || |             if (localChunk.getBaseblocks()[layerIndex + 1] == null || | ||||||
|                     localChunk.getBaseblocks()[layer][ChunkUtil.getJ(x, 0, z)] != null) { |                     localChunk.getBaseblocks()[layerIndex][ChunkUtil.getJ(x, 0, z)] != null) { | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         BaseBlock[] baseBlocks = localChunk.getBaseblocks()[layer]; |         BaseBlock[] baseBlocks = localChunk.getBaseblocks()[layerIndex]; | ||||||
|         if (x > 0 && baseBlocks[ChunkUtil.getJ(x - 1, y, z)] == null) { |         if (x > 0 && baseBlocks[ChunkUtil.getJ(x - 1, y, z)] == null) { | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -374,4 +380,23 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private SideEffectSet getSideEffectSet(SideEffectState state) { | ||||||
|  |         if (getSideEffectSet() != null) { | ||||||
|  |             return getSideEffectSet(); | ||||||
|  |         } | ||||||
|  |         return switch (state) { | ||||||
|  |             case NONE -> NO_SIDE_EFFECT_SET; | ||||||
|  |             case EDGE -> EDGE_SIDE_EFFECT_SET; | ||||||
|  |             case LIGHTING -> LIGHTING_SIDE_EFFECT_SET; | ||||||
|  |             case EDGE_LIGHTING -> EDGE_LIGHTING_SIDE_EFFECT_SET; | ||||||
|  |         }; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private enum SideEffectState { | ||||||
|  |         NONE, | ||||||
|  |         EDGE, | ||||||
|  |         LIGHTING, | ||||||
|  |         EDGE_LIGHTING | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -26,11 +19,12 @@ | |||||||
| package com.plotsquared.bukkit.queue; | package com.plotsquared.bukkit.queue; | ||||||
|  |  | ||||||
| import com.google.common.base.Preconditions; | import com.google.common.base.Preconditions; | ||||||
|  | import com.intellectualsites.annotations.DoNotUse; | ||||||
| import com.plotsquared.bukkit.util.BukkitBlockUtil; | import com.plotsquared.bukkit.util.BukkitBlockUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.ChunkUtil; | import com.plotsquared.core.util.ChunkUtil; | ||||||
| import com.plotsquared.core.util.PatternUtil; | import com.plotsquared.core.util.PatternUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| @@ -50,7 +44,11 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|  |  | ||||||
| public class GenChunk extends ScopedQueueCoordinator { | /** | ||||||
|  |  * Internal use only. Subject to changes at any time. | ||||||
|  |  */ | ||||||
|  | @DoNotUse | ||||||
|  | public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | ||||||
|  |  | ||||||
|     public final Biome[] biomes; |     public final Biome[] biomes; | ||||||
|     public BlockState[][] result; |     public BlockState[][] result; | ||||||
| @@ -61,8 +59,13 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|     public int chunkZ; |     public int chunkZ; | ||||||
|     private ChunkData chunkData = null; |     private ChunkData chunkData = null; | ||||||
|  |  | ||||||
|     public GenChunk() { |     /** | ||||||
|         super(null, Location.at("", 0, 0, 0), Location.at("", 15, 255, 15)); |      * @param minY minimum world Y, inclusive | ||||||
|  |      * @param maxY maximum world Y, inclusive | ||||||
|  |      * @since 6.6.0 | ||||||
|  |      */ | ||||||
|  |     public GenChunk(int minY, int maxY) { | ||||||
|  |         super(null, Location.at("", 0, minY, 0), Location.at("", 15, maxY, 15)); | ||||||
|         this.biomes = Biome.values(); |         this.biomes = Biome.values(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -102,13 +105,13 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|     /** |     /** | ||||||
|      * Set the world and XZ of the chunk being represented via {@link ChunkWrapper} |      * Set the world and XZ of the chunk being represented via {@link ChunkWrapper} | ||||||
|      * |      * | ||||||
|      * @param wrap P2 ChunkWrapper |      * @param wrap PlotSquared ChunkWrapper | ||||||
|      */ |      */ | ||||||
|     public void setChunk(@NonNull ChunkWrapper wrap) { |     public void setChunk(@NonNull ChunkWrapper wrap) { | ||||||
|         chunk = null; |         chunk = null; | ||||||
|         world = wrap.world; |         world = wrap.world(); | ||||||
|         chunkX = wrap.x; |         chunkX = wrap.x(); | ||||||
|         chunkZ = wrap.z; |         chunkZ = wrap.z(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -117,7 +120,7 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Biome biome = BukkitAdapter.adapt(biomeType); |         Biome biome = BukkitAdapter.adapt(biomeType); | ||||||
|         for (int y = 0; y < 256; y++) { |         for (int y = getMin().getY(); y <= getMax().getY(); y++) { | ||||||
|             for (int x = 0; x < 16; x++) { |             for (int x = 0; x < 16; x++) { | ||||||
|                 for (int z = 0; z < 16; z++) { |                 for (int z = 0; z < 16; z++) { | ||||||
|                     this.biomeGrid.setBiome(x, y, z, biome); |                     this.biomeGrid.setBiome(x, y, z, biome); | ||||||
| @@ -130,7 +133,7 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|     public void setCuboid(@NonNull Location pos1, @NonNull Location pos2, @NonNull BlockState block) { |     public void setCuboid(@NonNull Location pos1, @NonNull Location pos2, @NonNull BlockState block) { | ||||||
|         if (result != null && pos1.getX() == 0 && pos1.getZ() == 0 && pos2.getX() == 15 && pos2.getZ() == 15) { |         if (result != null && pos1.getX() == 0 && pos1.getZ() == 0 && pos2.getX() == 15 && pos2.getZ() == 15) { | ||||||
|             for (int y = pos1.getY(); y <= pos2.getY(); y++) { |             for (int y = pos1.getY(); y <= pos2.getY(); y++) { | ||||||
|                 int layer = y >> 4; |                 int layer = getLayerIndex(y); | ||||||
|                 BlockState[] data = result[layer]; |                 BlockState[] data = result[layer]; | ||||||
|                 if (data == null) { |                 if (data == null) { | ||||||
|                     result[layer] = data = new BlockState[4096]; |                     result[layer] = data = new BlockState[4096]; | ||||||
| @@ -164,7 +167,7 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|      */ |      */ | ||||||
|     public boolean setBiome(int x, int z, @NonNull Biome biome) { |     public boolean setBiome(int x, int z, @NonNull Biome biome) { | ||||||
|         if (this.biomeGrid != null) { |         if (this.biomeGrid != null) { | ||||||
|             for (int y = 0; y < 256; y++) { |             for (int y = getMin().getY(); y <= getMax().getY(); y++) { | ||||||
|                 this.setBiome(x, y, z, biome); |                 this.setBiome(x, y, z, biome); | ||||||
|             } |             } | ||||||
|             return true; |             return true; | ||||||
| @@ -182,7 +185,11 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean setBlock(int x, int y, int z, @NonNull Pattern pattern) { |     public boolean setBlock(int x, int y, int z, @NonNull Pattern pattern) { | ||||||
|         return setBlock(x, y, z, PatternUtil.apply(Preconditions.checkNotNull(pattern, "Pattern may not be null"), x, y, z)); |         final BaseBlock block = PatternUtil.apply(Preconditions.checkNotNull( | ||||||
|  |                 pattern, | ||||||
|  |                 "Pattern may not be null" | ||||||
|  |         ), x + (chunkX << 4), y, z + (chunkZ << 4)); | ||||||
|  |         return setBlock(x, y, z, block); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -197,7 +204,7 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void storeCache(final int x, final int y, final int z, final @NonNull BlockState id) { |     private void storeCache(final int x, final int y, final int z, final @NonNull BlockState id) { | ||||||
|         int i = y >> 4; |         int i = getLayerIndex(y); | ||||||
|         BlockState[] v = this.result[i]; |         BlockState[] v = this.result[i]; | ||||||
|         if (v == null) { |         if (v == null) { | ||||||
|             this.result[i] = v = new BlockState[4096]; |             this.result[i] = v = new BlockState[4096]; | ||||||
| @@ -219,7 +226,7 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @Nullable BlockState getBlock(int x, int y, int z) { |     public @Nullable BlockState getBlock(int x, int y, int z) { | ||||||
|         int i = y >> 4; |         int i = getLayerIndex(y); | ||||||
|         if (result == null) { |         if (result == null) { | ||||||
|             return BukkitBlockUtil.get(chunkData.getType(x, y, z)); |             return BukkitBlockUtil.get(chunkData.getType(x, y, z)); | ||||||
|         } |         } | ||||||
| @@ -246,16 +253,16 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull Location getMax() { |     public @NonNull Location getMax() { | ||||||
|         return Location.at(getWorld().getName(), 15 + (getX() << 4), 255, 15 + (getZ() << 4)); |         return Location.at(getWorld().getName(), 15 + (getX() << 4), super.getMax().getY(), 15 + (getZ() << 4)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull Location getMin() { |     public @NonNull Location getMin() { | ||||||
|         return Location.at(getWorld().getName(), getX() << 4, 0, getZ() << 4); |         return Location.at(getWorld().getName(), getX() << 4, super.getMin().getY(), getZ() << 4); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public @NonNull GenChunk clone() { |     public @NonNull GenChunk clone() { | ||||||
|         GenChunk toReturn = new GenChunk(); |         GenChunk toReturn = new GenChunk(getMin().getY(), getMax().getY()); | ||||||
|         if (this.result != null) { |         if (this.result != null) { | ||||||
|             for (int i = 0; i < this.result.length; i++) { |             for (int i = 0; i < this.result.length; i++) { | ||||||
|                 BlockState[] matrix = this.result[i]; |                 BlockState[] matrix = this.result[i]; | ||||||
| @@ -269,4 +276,8 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|         return toReturn; |         return toReturn; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private int getLayerIndex(int y) { | ||||||
|  |         return (y - getMin().getY()) >> 4; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,130 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.queue; | ||||||
|  |  | ||||||
|  | import com.plotsquared.bukkit.schematic.StateWrapper; | ||||||
|  | import com.plotsquared.core.queue.DelegateQueueCoordinator; | ||||||
|  | import com.sk89q.jnbt.CompoundTag; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
|  | import com.sk89q.worldedit.entity.Entity; | ||||||
|  | import com.sk89q.worldedit.function.pattern.Pattern; | ||||||
|  | import com.sk89q.worldedit.math.BlockVector3; | ||||||
|  | import com.sk89q.worldedit.world.block.BaseBlock; | ||||||
|  | import com.sk89q.worldedit.world.block.BlockState; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
|  | import org.bukkit.Location; | ||||||
|  | import org.bukkit.entity.EntityType; | ||||||
|  | import org.bukkit.generator.LimitedRegion; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Wraps a {@link LimitedRegion} inside a {@link com.plotsquared.core.queue.QueueCoordinator} so it can be written to. | ||||||
|  |  * | ||||||
|  |  * @since 6.9.0 | ||||||
|  |  */ | ||||||
|  | public class LimitedRegionWrapperQueue extends DelegateQueueCoordinator { | ||||||
|  |  | ||||||
|  |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + LimitedRegionWrapperQueue.class.getSimpleName()); | ||||||
|  |  | ||||||
|  |     private final LimitedRegion limitedRegion; | ||||||
|  |     private boolean useOtherRestoreTagMethod = false; | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * @since 6.9.0 | ||||||
|  |      */ | ||||||
|  |     public LimitedRegionWrapperQueue(LimitedRegion limitedRegion) { | ||||||
|  |         super(null); | ||||||
|  |         this.limitedRegion = limitedRegion; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean setBlock(final int x, final int y, final int z, @NonNull final Pattern pattern) { | ||||||
|  |         return setBlock(x, y, z, pattern.applyBlock(BlockVector3.at(x, y, z))); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean setBlock(final int x, final int y, final int z, @NonNull final BaseBlock id) { | ||||||
|  |         boolean result = setBlock(x, y, z, id.toImmutableState()); | ||||||
|  |         if (result && id.hasNbtData()) { | ||||||
|  |             CompoundTag tag = id.getNbtData(); | ||||||
|  |             StateWrapper sw = new StateWrapper(tag); | ||||||
|  |             try { | ||||||
|  |                 if (useOtherRestoreTagMethod && getWorld() != null) { | ||||||
|  |                     sw.restoreTag(getWorld().getName(), x, y, z); | ||||||
|  |                 } else { | ||||||
|  |                     sw.restoreTag(limitedRegion.getBlockState(x, y, z).getBlock()); | ||||||
|  |                 } | ||||||
|  |             } catch (IllegalArgumentException e) { | ||||||
|  |                 LOGGER.error("Error attempting to populate tile entity into the world at location {},{},{}", x, y, z, e); | ||||||
|  |                 return false; | ||||||
|  |             } catch (IllegalStateException e) { | ||||||
|  |                 useOtherRestoreTagMethod = true; | ||||||
|  |                 LOGGER.warn("IllegalStateException attempting to populate tile entity into the world at location {},{},{}. " + | ||||||
|  |                         "Possibly on <=1.17.1, switching to secondary method.", x, y, z, e); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean setBlock(final int x, final int y, final int z, @NonNull final BlockState id) { | ||||||
|  |         try { | ||||||
|  |             limitedRegion.setType(x, y, z, BukkitAdapter.adapt(id.getBlockType())); | ||||||
|  |             limitedRegion.setBlockData(x, y, z, BukkitAdapter.adapt(id)); | ||||||
|  |         } catch (IllegalArgumentException e) { | ||||||
|  |             LOGGER.error("Error attempting to populate block into the world at location {},{},{}", x, y, z, e); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean setEntity(@NonNull final Entity entity) { | ||||||
|  |         EntityType type = BukkitAdapter.adapt(entity.getState().getType()); | ||||||
|  |         double x = entity.getLocation().getX(); | ||||||
|  |         double y = entity.getLocation().getY(); | ||||||
|  |         double z = entity.getLocation().getZ(); | ||||||
|  |         Location location = new Location(limitedRegion.getWorld(), x, y, z); | ||||||
|  |         try { | ||||||
|  |             limitedRegion.spawnEntity(location, type); | ||||||
|  |         } catch (IllegalArgumentException e) { | ||||||
|  |             LOGGER.error("Error attempting to populate entity into the world at location {},{},{}", (int) x, (int) y, (int) z, e); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean setTile(final int x, final int y, final int z, @NonNull final CompoundTag tag) { | ||||||
|  |         StateWrapper sw = new StateWrapper(tag); | ||||||
|  |         try { | ||||||
|  |             return sw.restoreTag(limitedRegion.getBlockState(x, y, z).getBlock()); | ||||||
|  |         } catch (IllegalArgumentException e) { | ||||||
|  |             LOGGER.error("Error attempting to populate tile entity into the world at location {},{},{}", x, y, z, e); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public boolean isSettingTiles() { | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -25,6 +18,8 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.schematic; | package com.plotsquared.bukkit.schematic; | ||||||
|  |  | ||||||
|  | import com.destroystokyo.paper.profile.PlayerProfile; | ||||||
|  | import com.destroystokyo.paper.profile.ProfileProperty; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.sk89q.jnbt.ByteTag; | import com.sk89q.jnbt.ByteTag; | ||||||
| import com.sk89q.jnbt.CompoundTag; | import com.sk89q.jnbt.CompoundTag; | ||||||
| @@ -35,30 +30,39 @@ import com.sk89q.jnbt.Tag; | |||||||
| import com.sk89q.worldedit.blocks.BaseItemStack; | import com.sk89q.worldedit.blocks.BaseItemStack; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.item.ItemType; | import com.sk89q.worldedit.world.item.ItemType; | ||||||
|  | import io.papermc.lib.PaperLib; | ||||||
|  | import org.apache.logging.log4j.LogManager; | ||||||
|  | import org.apache.logging.log4j.Logger; | ||||||
|  | import org.bukkit.Bukkit; | ||||||
| import org.bukkit.ChatColor; | import org.bukkit.ChatColor; | ||||||
|  | import org.bukkit.DyeColor; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
|  | import org.bukkit.block.Banner; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.Container; | import org.bukkit.block.Container; | ||||||
| import org.bukkit.block.Sign; | import org.bukkit.block.Sign; | ||||||
|  | import org.bukkit.block.Skull; | ||||||
|  | import org.bukkit.block.banner.Pattern; | ||||||
|  | import org.bukkit.block.banner.PatternType; | ||||||
| import org.bukkit.enchantments.Enchantment; | import org.bukkit.enchantments.Enchantment; | ||||||
| import org.bukkit.inventory.Inventory; | import org.bukkit.inventory.Inventory; | ||||||
| import org.bukkit.inventory.InventoryHolder; |  | ||||||
| import org.bukkit.inventory.ItemStack; | import org.bukkit.inventory.ItemStack; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.HashMap; | import java.util.HashMap; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| import java.util.Map.Entry; | import java.util.Map.Entry; | ||||||
|  | import java.util.Objects; | ||||||
|  | import java.util.UUID; | ||||||
|  |  | ||||||
| public class StateWrapper { | public class StateWrapper { | ||||||
|  |  | ||||||
|     public org.bukkit.block.BlockState state = null; |     public CompoundTag tag; | ||||||
|     public CompoundTag tag = null; |  | ||||||
|  |  | ||||||
|     public StateWrapper(org.bukkit.block.BlockState state) { |     private boolean paperErrorTextureSent = false; | ||||||
|         this.state = state; |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + StateWrapper.class.getSimpleName()); | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public StateWrapper(CompoundTag tag) { |     public StateWrapper(CompoundTag tag) { | ||||||
|         this.tag = tag; |         this.tag = tag; | ||||||
| @@ -166,14 +170,32 @@ public class StateWrapper { | |||||||
|         return str; |         return str; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") // #setLine is needed for Spigot compatibility |     /** | ||||||
|  |      * Restore the TileEntity data to the given world at the given coordinates. | ||||||
|  |      * | ||||||
|  |      * @param worldName World name | ||||||
|  |      * @param x         x position | ||||||
|  |      * @param y         y position | ||||||
|  |      * @param z         z position | ||||||
|  |      * @return true if successful | ||||||
|  |      */ | ||||||
|     public boolean restoreTag(String worldName, int x, int y, int z) { |     public boolean restoreTag(String worldName, int x, int y, int z) { | ||||||
|         if (this.tag == null) { |         World world = BukkitUtil.getWorld(worldName); | ||||||
|  |         if (world == null) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         World world = BukkitUtil.getWorld(worldName); |         return restoreTag(world.getBlockAt(x, y, z)); | ||||||
|         Block block = world.getBlockAt(x, y, z); |     } | ||||||
|         if (block == null) { |  | ||||||
|  |     /** | ||||||
|  |      * Restore the TileEntity data to the given block | ||||||
|  |      * | ||||||
|  |      * @param block Block to restore to | ||||||
|  |      * @return true if successful | ||||||
|  |      */ | ||||||
|  |     @SuppressWarnings("deprecation") // #setLine is needed for Spigot compatibility | ||||||
|  |     public boolean restoreTag(@NonNull Block block) { | ||||||
|  |         if (this.tag == null) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         org.bukkit.block.BlockState state = block.getState(); |         org.bukkit.block.BlockState state = block.getState(); | ||||||
| @@ -211,22 +233,78 @@ public class StateWrapper { | |||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|  |             case "skull" -> { | ||||||
|  |                 if (state instanceof Skull skull) { | ||||||
|  |                     CompoundTag skullOwner = ((CompoundTag) this.tag.getValue().get("SkullOwner")); | ||||||
|  |                     if (skullOwner == null) { | ||||||
|  |                         return true; | ||||||
|  |                     } | ||||||
|  |                     String player = skullOwner.getString("Name"); | ||||||
|  |  | ||||||
|  |                     if (player != null && !player.isEmpty()) { | ||||||
|  |                         try { | ||||||
|  |                             skull.setOwningPlayer(Bukkit.getOfflinePlayer(player)); | ||||||
|  |                             skull.update(true); | ||||||
|  |                         } catch (Exception e) { | ||||||
|  |                             e.printStackTrace(); | ||||||
|  |                         } | ||||||
|  |                         return true; | ||||||
|  |                     } | ||||||
|  |  | ||||||
|  |                     final CompoundTag properties = (CompoundTag) skullOwner.getValue().get("Properties"); | ||||||
|  |                     if (properties == null) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     final ListTag textures = properties.getListTag("textures"); | ||||||
|  |                     if (textures.getValue().isEmpty()) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     final CompoundTag textureCompound = (CompoundTag) textures.getValue().get(0); | ||||||
|  |                     if (textureCompound == null) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     String textureValue = textureCompound.getString("Value"); | ||||||
|  |                     if (textureValue == null) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     if (!PaperLib.isPaper()) { | ||||||
|  |                         if (!paperErrorTextureSent) { | ||||||
|  |                             paperErrorTextureSent = true; | ||||||
|  |                             LOGGER.error("Failed to populate skull data in your road schematic - This is a Spigot limitation."); | ||||||
|                         } |                         } | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|  |                     final PlayerProfile profile = Bukkit.createProfile(UUID.randomUUID()); | ||||||
|  |                     profile.setProperty(new ProfileProperty("textures", textureValue)); | ||||||
|  |                     skull.setPlayerProfile(profile); | ||||||
|  |                     skull.update(true); | ||||||
|  |                     return true; | ||||||
|  |  | ||||||
|     public CompoundTag getTag() { |  | ||||||
|         if (this.tag != null) { |  | ||||||
|             return this.tag; |  | ||||||
|                 } |                 } | ||||||
|         if (this.state instanceof InventoryHolder inv) { |                 return false; | ||||||
|             ItemStack[] contents = inv.getInventory().getContents(); |  | ||||||
|             Map<String, Tag> values = new HashMap<>(); |  | ||||||
|             values.put("Items", new ListTag(CompoundTag.class, serializeInventory(contents))); |  | ||||||
|             return new CompoundTag(values); |  | ||||||
|             } |             } | ||||||
|  |             case "banner" -> { | ||||||
|  |                 if (state instanceof Banner banner) { | ||||||
|  |                     List<Tag> patterns = this.tag.getListTag("Patterns").getValue(); | ||||||
|  |                     if (patterns == null || patterns.isEmpty()) { | ||||||
|  |                         return false; | ||||||
|  |                     } | ||||||
|  |                     banner.setPatterns(patterns.stream().map(t -> (CompoundTag) t).map(compoundTag -> { | ||||||
|  |                         DyeColor color = DyeColor.getByWoolData((byte) compoundTag.getInt("Color")); | ||||||
|  |                         PatternType patternType = PatternType.getByIdentifier(compoundTag.getString("Pattern")); | ||||||
|  |                         if (color == null || patternType == null) { | ||||||
|                             return null; |                             return null; | ||||||
|                         } |                         } | ||||||
|  |                         return new Pattern(color, patternType); | ||||||
|  |                     }).filter(Objects::nonNull).toList()); | ||||||
|  |                     banner.update(true); | ||||||
|  |                     return true; | ||||||
|  |                 } | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public String getId() { |     public String getId() { | ||||||
|         String tileid = this.tag.getString("id").toLowerCase(); |         String tileid = this.tag.getString("id").toLowerCase(); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -47,10 +40,11 @@ import com.plotsquared.core.plot.flag.implementations.PvpFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.TamedAttackFlag; | import com.plotsquared.core.plot.flag.implementations.TamedAttackFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleCapFlag; | ||||||
| import com.plotsquared.core.util.EntityUtil; | import com.plotsquared.core.util.EntityUtil; | ||||||
| import com.plotsquared.core.util.Permissions; |  | ||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.Component; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.bukkit.entity.Arrow; | import org.bukkit.entity.Arrow; | ||||||
| import org.bukkit.entity.Creature; | import org.bukkit.entity.Creature; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| @@ -175,8 +169,7 @@ public class BukkitEntityUtil { | |||||||
|                 if (plot != null && (plot.getFlag(HangingBreakFlag.class) || plot |                 if (plot != null && (plot.getFlag(HangingBreakFlag.class) || plot | ||||||
|                         .isAdded(plotPlayer.getUUID()))) { |                         .isAdded(plotPlayer.getUUID()))) { | ||||||
|                     if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |                     if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|                         if (!Permissions |                         if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_OTHER)) { | ||||||
|                                 .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER)) { |  | ||||||
|                             plotPlayer.sendMessage( |                             plotPlayer.sendMessage( | ||||||
|                                     TranslatableCaption.of("done.building_restricted") |                                     TranslatableCaption.of("done.building_restricted") | ||||||
|                             ); |                             ); | ||||||
| @@ -185,10 +178,13 @@ public class BukkitEntityUtil { | |||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_DESTROY + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -197,10 +193,13 @@ public class BukkitEntityUtil { | |||||||
|                         .isAdded(plotPlayer.getUUID()))) { |                         .isAdded(plotPlayer.getUUID()))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_DESTROY + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_DESTROY + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() |                         plot.debug(player.getName() | ||||||
| @@ -218,10 +217,13 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
| @@ -239,10 +241,13 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
| @@ -252,11 +257,13 @@ public class BukkitEntityUtil { | |||||||
|                 } |                 } | ||||||
|             } else if (EntityCategories.PLAYER.contains(entityType)) { |             } else if (EntityCategories.PLAYER.contains(entityType)) { | ||||||
|                 if (isPlot) { |                 if (isPlot) { | ||||||
|                     if (!plot.getFlag(PvpFlag.class) && !Permissions |                     if (!plot.getFlag(PvpFlag.class) && !plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVP + "." + stub)) { | ||||||
|                             .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVP + "." + stub)) { |  | ||||||
|                         plotPlayer.sendMessage( |                         plotPlayer.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 Template.of("node", Permission.PERMISSION_ADMIN_PVP + "." + stub) |                                 TagResolver.resolver( | ||||||
|  |                                         "node", | ||||||
|  |                                         Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVP + "." + stub)) | ||||||
|  |                                 ) | ||||||
|                         ); |                         ); | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
|                                 + " because pve = false"); |                                 + " because pve = false"); | ||||||
| @@ -267,10 +274,13 @@ public class BukkitEntityUtil { | |||||||
|                 } else if (roadFlags && area.getRoadFlag(PvpFlag.class)) { |                 } else if (roadFlags && area.getRoadFlag(PvpFlag.class)) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVP + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVP + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_PVP + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVP + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
| @@ -284,10 +294,13 @@ public class BukkitEntityUtil { | |||||||
|                         .getFlag(PveFlag.class))) { |                         .getFlag(PveFlag.class))) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
| @@ -306,10 +319,13 @@ public class BukkitEntityUtil { | |||||||
|                 } else if (roadFlags && area.getRoadFlag(PveFlag.class)) { |                 } else if (roadFlags && area.getRoadFlag(PveFlag.class)) { | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 if (!Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_PVE + "." + stub)) { |                 if (!plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_PVE + "." + stub)) { | ||||||
|                     plotPlayer.sendMessage( |                     plotPlayer.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission_event"), |                             TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                             Template.of("node", Permission.PERMISSION_ADMIN_PVE + "." + stub) |                             TagResolver.resolver( | ||||||
|  |                                     "node", | ||||||
|  |                                     Tag.inserting(Component.text(Permission.PERMISSION_ADMIN_PVE + "." + stub)) | ||||||
|  |                             ) | ||||||
|                     ); |                     ); | ||||||
|                     if (plot != null) { |                     if (plot != null) { | ||||||
|                         plot.debug(player.getName() + " could not attack " + entityType |                         plot.debug(player.getName() + " could not attack " + entityType | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -63,7 +56,7 @@ public class BukkitInventoryUtil extends InventoryUtil { | |||||||
|         ItemMeta meta = null; |         ItemMeta meta = null; | ||||||
|         if (item.getName() != null) { |         if (item.getName() != null) { | ||||||
|             meta = stack.getItemMeta(); |             meta = stack.getItemMeta(); | ||||||
|             Component nameComponent = BukkitUtil.MINI_MESSAGE.parse(item.getName()); |             Component nameComponent = BukkitUtil.MINI_MESSAGE.deserialize(item.getName()); | ||||||
|             meta.setDisplayName(BukkitUtil.LEGACY_COMPONENT_SERIALIZER.serialize(nameComponent)); |             meta.setDisplayName(BukkitUtil.LEGACY_COMPONENT_SERIALIZER.serialize(nameComponent)); | ||||||
|         } |         } | ||||||
|         if (item.getLore() != null) { |         if (item.getLore() != null) { | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -37,10 +30,9 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotManager; | import com.plotsquared.core.plot.PlotManager; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; | import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.plotsquared.core.util.RegionManager; | import com.plotsquared.core.util.RegionManager; | ||||||
| import com.plotsquared.core.util.RegionUtil; |  | ||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.entity.EntityCategories; | import com.plotsquared.core.util.entity.EntityCategories; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| @@ -261,13 +253,13 @@ public class BukkitRegionManager extends RegionManager { | |||||||
|             if (checkX2 && checkZ2) { |             if (checkX2 && checkZ2) { | ||||||
|                 map.saveRegion(world, xxt2, xxt, zzt2, zzt); // |                 map.saveRegion(world, xxt2, xxt, zzt2, zzt); // | ||||||
|             } |             } | ||||||
|             CuboidRegion currentPlotClear = RegionUtil.createRegion(pos1.getX(), pos2.getX(), pos1.getZ(), pos2.getZ()); |             CuboidRegion currentPlotClear = new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()); | ||||||
|             map.saveEntitiesOut(Bukkit.getWorld(world.getName()).getChunkAt(x, z), currentPlotClear); |             map.saveEntitiesOut(Bukkit.getWorld(world.getName()).getChunkAt(x, z), currentPlotClear); | ||||||
|             AugmentedUtils.bypass( |             AugmentedUtils.bypass( | ||||||
|                     ignoreAugment, |                     ignoreAugment, | ||||||
|                     () -> ChunkManager.setChunkInPlotArea(null, new RunnableVal<ScopedQueueCoordinator>() { |                     () -> ChunkManager.setChunkInPlotArea(null, new RunnableVal<ZeroedDelegateScopedQueueCoordinator>() { | ||||||
|                         @Override |                         @Override | ||||||
|                         public void run(ScopedQueueCoordinator value) { |                         public void run(ZeroedDelegateScopedQueueCoordinator value) { | ||||||
|                             Location min = value.getMin(); |                             Location min = value.getMin(); | ||||||
|                             int bx = min.getX(); |                             int bx = min.getX(); | ||||||
|                             int bz = min.getZ(); |                             int bz = min.getZ(); | ||||||
| @@ -276,20 +268,16 @@ public class BukkitRegionManager extends RegionManager { | |||||||
|                                     PlotLoc plotLoc = new PlotLoc(bx + x1, bz + z1); |                                     PlotLoc plotLoc = new PlotLoc(bx + x1, bz + z1); | ||||||
|                                     BaseBlock[] ids = map.allBlocks.get(plotLoc); |                                     BaseBlock[] ids = map.allBlocks.get(plotLoc); | ||||||
|                                     if (ids != null) { |                                     if (ids != null) { | ||||||
|                                         for (int y = 0; y < Math.min(128, ids.length); y++) { |                                         int minY = value.getMin().getY(); | ||||||
|                                             BaseBlock id = ids[y]; |                                         for (int yIndex = 0; yIndex < ids.length; yIndex++) { | ||||||
|  |                                             int y = yIndex + minY; | ||||||
|  |                                             BaseBlock id = ids[yIndex]; | ||||||
|                                             if (id != null) { |                                             if (id != null) { | ||||||
|                                                 value.setBlock(x1, y, z1, id); |                                                 value.setBlock(x1, y, z1, id); | ||||||
|                                             } else { |                                             } else { | ||||||
|                                                 value.setBlock(x1, y, z1, BlockTypes.AIR.getDefaultState()); |                                                 value.setBlock(x1, y, z1, BlockTypes.AIR.getDefaultState()); | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                         for (int y = Math.min(128, ids.length); y < ids.length; y++) { |  | ||||||
|                                             BaseBlock id = ids[y]; |  | ||||||
|                                             if (id != null) { |  | ||||||
|                                                 value.setBlock(x1, y, z1, id); |  | ||||||
|                                             } |  | ||||||
|                                         } |  | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
| @@ -297,7 +285,7 @@ public class BukkitRegionManager extends RegionManager { | |||||||
|                     }, world.getName(), chunk) |                     }, world.getName(), chunk) | ||||||
|             ); |             ); | ||||||
|             //map.restoreBlocks(worldObj, 0, 0); |             //map.restoreBlocks(worldObj, 0, 0); | ||||||
|             map.restoreEntities(Bukkit.getWorld(world.getName()), 0, 0); |             map.restoreEntities(Bukkit.getWorld(world.getName())); | ||||||
|         }); |         }); | ||||||
|         regenQueue.setCompleteTask(whenDone); |         regenQueue.setCompleteTask(whenDone); | ||||||
|         queue.setCompleteTask(regenQueue::enqueue); |         queue.setCompleteTask(regenQueue::enqueue); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -76,7 +69,7 @@ public class BukkitSetupUtils extends SetupUtils { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void updateGenerators(final boolean force) { |     public void updateGenerators(final boolean force) { | ||||||
|         if (!SetupUtils.generators.isEmpty() && !force) { |         if (loaded && !SetupUtils.generators.isEmpty() && !force) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         String testWorld = "CheckingPlotSquaredGenerator"; |         String testWorld = "CheckingPlotSquaredGenerator"; | ||||||
| @@ -100,6 +93,7 @@ public class BukkitSetupUtils extends SetupUtils { | |||||||
|                 e.printStackTrace(); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         loaded = true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -130,7 +124,7 @@ public class BukkitSetupUtils extends SetupUtils { | |||||||
|     public String setupWorld(PlotAreaBuilder builder) { |     public String setupWorld(PlotAreaBuilder builder) { | ||||||
|         this.updateGenerators(false); |         this.updateGenerators(false); | ||||||
|         ConfigurationNode[] steps = builder.settingsNodesWrapper() == null ? |         ConfigurationNode[] steps = builder.settingsNodesWrapper() == null ? | ||||||
|                 new ConfigurationNode[0] : builder.settingsNodesWrapper().getSettingsNodes(); |                 new ConfigurationNode[0] : builder.settingsNodesWrapper().settingsNodes(); | ||||||
|         String world = builder.worldName(); |         String world = builder.worldName(); | ||||||
|         PlotAreaType type = builder.plotAreaType(); |         PlotAreaType type = builder.plotAreaType(); | ||||||
|         String worldPath = "worlds." + builder.worldName(); |         String worldPath = "worlds." + builder.worldName(); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -44,7 +37,6 @@ import com.plotsquared.core.util.task.TaskManager; | |||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitWorld; | import com.sk89q.worldedit.bukkit.BukkitWorld; | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
| import com.sk89q.worldedit.regions.CuboidRegion; |  | ||||||
| import com.sk89q.worldedit.world.biome.BiomeType; | import com.sk89q.worldedit.world.biome.BiomeType; | ||||||
| import com.sk89q.worldedit.world.block.BlockCategories; | import com.sk89q.worldedit.world.block.BlockCategories; | ||||||
| import com.sk89q.worldedit.world.block.BlockState; | import com.sk89q.worldedit.world.block.BlockState; | ||||||
| @@ -53,7 +45,7 @@ import com.sk89q.worldedit.world.block.BlockTypes; | |||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.platform.bukkit.BukkitAudiences; | import net.kyori.adventure.platform.bukkit.BukkitAudiences; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; | import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer; | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| @@ -61,12 +53,12 @@ import org.bukkit.Bukkit; | |||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; |  | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.Sign; | import org.bukkit.block.Sign; | ||||||
| import org.bukkit.block.data.Directional; | import org.bukkit.block.data.Directional; | ||||||
| import org.bukkit.block.data.type.WallSign; | import org.bukkit.block.data.type.WallSign; | ||||||
|  | import org.bukkit.entity.Allay; | ||||||
| import org.bukkit.entity.Ambient; | import org.bukkit.entity.Ambient; | ||||||
| import org.bukkit.entity.Animals; | import org.bukkit.entity.Animals; | ||||||
| import org.bukkit.entity.AreaEffectCloud; | import org.bukkit.entity.AreaEffectCloud; | ||||||
| @@ -246,7 +238,9 @@ public class BukkitUtil extends WorldUtil { | |||||||
|             final World bukkitWorld = Objects.requireNonNull(getWorld(world)); |             final World bukkitWorld = Objects.requireNonNull(getWorld(world)); | ||||||
|             // Skip top and bottom block |             // Skip top and bottom block | ||||||
|             int air = 1; |             int air = 1; | ||||||
|             for (int y = bukkitWorld.getMaxHeight() - 1; y >= 0; y--) { |             int maxY = com.plotsquared.bukkit.util.BukkitWorld.getMaxWorldHeight(bukkitWorld); | ||||||
|  |             int minY = com.plotsquared.bukkit.util.BukkitWorld.getMinWorldHeight(bukkitWorld); | ||||||
|  |             for (int y = maxY - 1; y >= minY; y--) { | ||||||
|                 Block block = bukkitWorld.getBlockAt(x, y, z); |                 Block block = bukkitWorld.getBlockAt(x, y, z); | ||||||
|                 Material type = block.getType(); |                 Material type = block.getType(); | ||||||
|                 if (type.isSolid()) { |                 if (type.isSolid()) { | ||||||
| @@ -273,7 +267,9 @@ public class BukkitUtil extends WorldUtil { | |||||||
|         final World bukkitWorld = Objects.requireNonNull(getWorld(world)); |         final World bukkitWorld = Objects.requireNonNull(getWorld(world)); | ||||||
|         // Skip top and bottom block |         // Skip top and bottom block | ||||||
|         int air = 1; |         int air = 1; | ||||||
|         for (int y = bukkitWorld.getMaxHeight() - 1; y >= 0; y--) { |         int maxY = com.plotsquared.bukkit.util.BukkitWorld.getMaxWorldHeight(bukkitWorld); | ||||||
|  |         int minY = com.plotsquared.bukkit.util.BukkitWorld.getMinWorldHeight(bukkitWorld); | ||||||
|  |         for (int y = maxY - 1; y >= minY; y--) { | ||||||
|             Block block = bukkitWorld.getBlockAt(x, y, z); |             Block block = bukkitWorld.getBlockAt(x, y, z); | ||||||
|             Material type = block.getType(); |             Material type = block.getType(); | ||||||
|             if (type.isSolid()) { |             if (type.isSolid()) { | ||||||
| @@ -337,7 +333,7 @@ public class BukkitUtil extends WorldUtil { | |||||||
|     @SuppressWarnings("deprecation") |     @SuppressWarnings("deprecation") | ||||||
|     public void setSign( |     public void setSign( | ||||||
|             final @NonNull Location location, final @NonNull Caption[] lines, |             final @NonNull Location location, final @NonNull Caption[] lines, | ||||||
|             final @NonNull Template... replacements |             final @NonNull TagResolver... replacements | ||||||
|     ) { |     ) { | ||||||
|         ensureLoaded(location.getWorldName(), location.getX(), location.getZ(), chunk -> { |         ensureLoaded(location.getWorldName(), location.getX(), location.getZ(), chunk -> { | ||||||
|             PlotArea area = location.getPlotArea(); |             PlotArea area = location.getPlotArea(); | ||||||
| @@ -345,14 +341,16 @@ public class BukkitUtil extends WorldUtil { | |||||||
|             final Block block = world.getBlockAt(location.getX(), location.getY(), location.getZ()); |             final Block block = world.getBlockAt(location.getX(), location.getY(), location.getZ()); | ||||||
|             final Material type = block.getType(); |             final Material type = block.getType(); | ||||||
|             if (type != Material.LEGACY_SIGN && type != Material.LEGACY_WALL_SIGN) { |             if (type != Material.LEGACY_SIGN && type != Material.LEGACY_WALL_SIGN) { | ||||||
|                 BlockFace facing = BlockFace.EAST; |                 BlockFace facing = BlockFace.NORTH; | ||||||
|                 if (world.getBlockAt(location.getX(), location.getY(), location.getZ() + 1).getType().isSolid()) { |                 if (!world.getBlockAt(location.getX(), location.getY(), location.getZ() + 1).getType().isSolid()) { | ||||||
|                     facing = BlockFace.NORTH; |                     if (world.getBlockAt(location.getX() - 1, location.getY(), location.getZ()).getType().isSolid()) { | ||||||
|  |                         facing = BlockFace.EAST; | ||||||
|                     } else if (world.getBlockAt(location.getX() + 1, location.getY(), location.getZ()).getType().isSolid()) { |                     } else if (world.getBlockAt(location.getX() + 1, location.getY(), location.getZ()).getType().isSolid()) { | ||||||
|                         facing = BlockFace.WEST; |                         facing = BlockFace.WEST; | ||||||
|                     } else if (world.getBlockAt(location.getX(), location.getY(), location.getZ() - 1).getType().isSolid()) { |                     } else if (world.getBlockAt(location.getX(), location.getY(), location.getZ() - 1).getType().isSolid()) { | ||||||
|                         facing = BlockFace.SOUTH; |                         facing = BlockFace.SOUTH; | ||||||
|                     } |                     } | ||||||
|  |                 } | ||||||
|                 if (PlotSquared.platform().serverVersion()[1] == 13) { |                 if (PlotSquared.platform().serverVersion()[1] == 13) { | ||||||
|                     block.setType(Material.valueOf(area.legacySignMaterial()), false); |                     block.setType(Material.valueOf(area.legacySignMaterial()), false); | ||||||
|                 } else { |                 } else { | ||||||
| @@ -368,10 +366,11 @@ public class BukkitUtil extends WorldUtil { | |||||||
|             final org.bukkit.block.BlockState blockstate = block.getState(); |             final org.bukkit.block.BlockState blockstate = block.getState(); | ||||||
|             if (blockstate instanceof final Sign sign) { |             if (blockstate instanceof final Sign sign) { | ||||||
|                 for (int i = 0; i < lines.length; i++) { |                 for (int i = 0; i < lines.length; i++) { | ||||||
|                     sign.setLine(i, LEGACY_COMPONENT_SERIALIZER |                     sign.setLine(i, LEGACY_COMPONENT_SERIALIZER.serialize( | ||||||
|                             .serialize(MINI_MESSAGE.parse(lines[i].getComponent(LocaleHolder.console()), replacements))); |                             MINI_MESSAGE.deserialize(lines[i].getComponent(LocaleHolder.console()), replacements) | ||||||
|  |                     )); | ||||||
|                 } |                 } | ||||||
|                 sign.update(true); |                 sign.update(true, false); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| @@ -382,27 +381,6 @@ public class BukkitUtil extends WorldUtil { | |||||||
|         return new StringComparison<BlockState>().new ComparisonResult(1, state); |         return new StringComparison<BlockState>().new ComparisonResult(1, state); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void setBiomes( |  | ||||||
|             final @NonNull String worldName, |  | ||||||
|             final @NonNull CuboidRegion region, |  | ||||||
|             final @NonNull BiomeType biomeType |  | ||||||
|     ) { |  | ||||||
|         final World world = getWorld(worldName); |  | ||||||
|         if (world == null) { |  | ||||||
|             LOGGER.warn("An error occurred while setting the biome because the world was null", new RuntimeException()); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         final Biome biome = BukkitAdapter.adapt(biomeType); |  | ||||||
|         for (int x = region.getMinimumPoint().getX(); x <= region.getMaximumPoint().getX(); x++) { |  | ||||||
|             for (int z = region.getMinimumPoint().getZ(); z <= region.getMaximumPoint().getZ(); z++) { |  | ||||||
|                 if (world.getBiome(x, z) != biome) { |  | ||||||
|                     world.setBiome(x, z, biome); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public com.sk89q.worldedit.world.@NonNull World getWeWorld(final @NonNull String world) { |     public com.sk89q.worldedit.world.@NonNull World getWeWorld(final @NonNull String world) { | ||||||
|         return new BukkitWorld(Bukkit.getWorld(world)); |         return new BukkitWorld(Bukkit.getWorld(world)); | ||||||
| @@ -461,6 +439,9 @@ public class BukkitUtil extends WorldUtil { | |||||||
|                 allowedInterfaces.add(Animals.class); |                 allowedInterfaces.add(Animals.class); | ||||||
|                 allowedInterfaces.add(WaterMob.class); |                 allowedInterfaces.add(WaterMob.class); | ||||||
|                 allowedInterfaces.add(Ambient.class); |                 allowedInterfaces.add(Ambient.class); | ||||||
|  |                 if (PlotSquared.platform().serverVersion()[1] >= 19) { | ||||||
|  |                     allowedInterfaces.add(Allay.class); | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|             case "tameable" -> allowedInterfaces.add(Tameable.class); |             case "tameable" -> allowedInterfaces.add(Tameable.class); | ||||||
|             case "vehicle" -> allowedInterfaces.add(Vehicle.class); |             case "vehicle" -> allowedInterfaces.add(Vehicle.class); | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -31,11 +24,22 @@ import org.bukkit.Bukkit; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| import java.util.Objects; |  | ||||||
|  |  | ||||||
| public class BukkitWorld implements World<org.bukkit.World> { | public class BukkitWorld implements World<org.bukkit.World> { | ||||||
|  |  | ||||||
|     private static final Map<String, BukkitWorld> worldMap = Maps.newHashMap(); |     private static final Map<String, BukkitWorld> worldMap = Maps.newHashMap(); | ||||||
|  |     private static final boolean HAS_MIN_Y; | ||||||
|  |  | ||||||
|  |     static { | ||||||
|  |         boolean temp; | ||||||
|  |         try { | ||||||
|  |             org.bukkit.World.class.getMethod("getMinHeight"); | ||||||
|  |             temp = true; | ||||||
|  |         } catch (NoSuchMethodException e) { | ||||||
|  |             temp = false; | ||||||
|  |         } | ||||||
|  |         HAS_MIN_Y = temp; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private final org.bukkit.World world; |     private final org.bukkit.World world; | ||||||
|  |  | ||||||
| @@ -73,6 +77,24 @@ public class BukkitWorld implements World<org.bukkit.World> { | |||||||
|         return bukkitWorld; |         return bukkitWorld; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the min world height from a Bukkit {@link org.bukkit.World}. Inclusive | ||||||
|  |      * | ||||||
|  |      * @since 6.6.0 | ||||||
|  |      */ | ||||||
|  |     public static int getMinWorldHeight(org.bukkit.World world) { | ||||||
|  |         return HAS_MIN_Y ? world.getMinHeight() : 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the max world height from a Bukkit {@link org.bukkit.World}. Exclusive | ||||||
|  |      * | ||||||
|  |      * @since 6.6.0 | ||||||
|  |      */ | ||||||
|  |     public static int getMaxWorldHeight(org.bukkit.World world) { | ||||||
|  |         return HAS_MIN_Y ? world.getMaxHeight() : 256; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public org.bukkit.World getPlatformWorld() { |     public org.bukkit.World getPlatformWorld() { | ||||||
|         return this.world; |         return this.world; | ||||||
| @@ -83,32 +105,31 @@ public class BukkitWorld implements World<org.bukkit.World> { | |||||||
|         return this.world.getName(); |         return this.world.getName(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int getMinHeight() { | ||||||
|  |         return getMinWorldHeight(world); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public int getMaxHeight() { | ||||||
|  |         return getMaxWorldHeight(world) - 1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|     public boolean equals(final Object o) { |     public boolean equals(final Object o) { | ||||||
|         if (o == this) { |         if (this == o) { | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         if (!(o instanceof final BukkitWorld other)) { |         if (o == null || getClass() != o.getClass()) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!other.canEqual(this)) { |         final BukkitWorld that = (BukkitWorld) o; | ||||||
|             return false; |         return world.equals(that.world); | ||||||
|         } |  | ||||||
|         if (!Objects.equals(this.world, other.world)) { |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     protected boolean canEqual(final Object other) { |  | ||||||
|         return other instanceof BukkitWorld; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|     public int hashCode() { |     public int hashCode() { | ||||||
|         final int PRIME = 59; |         return world.hashCode(); | ||||||
|         int result = 1; |  | ||||||
|         final Object $world = this.world; |  | ||||||
|         result = result * PRIME + ($world == null ? 43 : $world.hashCode()); |  | ||||||
|         return result; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public String toString() { |     public String toString() { | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -70,7 +63,7 @@ public class ContentMap { | |||||||
|         } |         } | ||||||
|         for (int x = x1; x <= x2; x++) { |         for (int x = x1; x <= x2; x++) { | ||||||
|             for (int z = z1; z <= z2; z++) { |             for (int z = z1; z <= z2; z++) { | ||||||
|                 saveBlocks(world, 256, x, z, 0, 0); |                 saveBlocks(world, x, z); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -92,14 +85,7 @@ public class ContentMap { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     void saveEntitiesIn(Chunk chunk, CuboidRegion region) { |     void saveEntitiesIn(Chunk chunk, CuboidRegion region, boolean delete) { | ||||||
|         saveEntitiesIn(chunk, region, 0, 0, false); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void saveEntitiesIn( |  | ||||||
|             Chunk chunk, CuboidRegion region, int offsetX, int offsetZ, |  | ||||||
|             boolean delete |  | ||||||
|     ) { |  | ||||||
|         for (Entity entity : chunk.getEntities()) { |         for (Entity entity : chunk.getEntities()) { | ||||||
|             Location location = BukkitUtil.adapt(entity.getLocation()); |             Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|             int x = location.getX(); |             int x = location.getX(); | ||||||
| @@ -111,8 +97,6 @@ public class ContentMap { | |||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             EntityWrapper wrap = new ReplicatingEntityWrapper(entity, (short) 2); |             EntityWrapper wrap = new ReplicatingEntityWrapper(entity, (short) 2); | ||||||
|             wrap.x += offsetX; |  | ||||||
|             wrap.z += offsetZ; |  | ||||||
|             wrap.saveEntity(); |             wrap.saveEntity(); | ||||||
|             this.entities.add(wrap); |             this.entities.add(wrap); | ||||||
|             if (delete) { |             if (delete) { | ||||||
| @@ -123,10 +107,10 @@ public class ContentMap { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     void restoreEntities(World world, int xOffset, int zOffset) { |     void restoreEntities(World world) { | ||||||
|         for (EntityWrapper entity : this.entities) { |         for (EntityWrapper entity : this.entities) { | ||||||
|             try { |             try { | ||||||
|                 entity.spawn(world, xOffset, zOffset); |                 entity.spawn(world, 0, 0); | ||||||
|             } catch (Exception e) { |             } catch (Exception e) { | ||||||
|                 LOGGER.error("Failed to restore entity", e); |                 LOGGER.error("Failed to restore entity", e); | ||||||
|             } |             } | ||||||
| @@ -134,15 +118,13 @@ public class ContentMap { | |||||||
|         this.entities.clear(); |         this.entities.clear(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     //todo optimize maxY |     private void saveBlocks(BukkitWorld world, int x, int z) { | ||||||
|     void saveBlocks(BukkitWorld world, int maxY, int x, int z, int offsetX, int offsetZ) { |         BaseBlock[] ids = new BaseBlock[world.getMaxY() - world.getMinY() + 1]; | ||||||
|         maxY = Math.min(255, maxY); |         for (short yIndex = 0; yIndex <= world.getMaxY() - world.getMinY(); yIndex++) { | ||||||
|         BaseBlock[] ids = new BaseBlock[maxY + 1]; |             BaseBlock block = world.getFullBlock(BlockVector3.at(x, yIndex + world.getMinY(), z)); | ||||||
|         for (short y = 0; y <= maxY; y++) { |             ids[yIndex] = block; | ||||||
|             BaseBlock block = world.getFullBlock(BlockVector3.at(x, y, z)); |  | ||||||
|             ids[y] = block; |  | ||||||
|         } |         } | ||||||
|         PlotLoc loc = new PlotLoc(x + offsetX, z + offsetZ); |         PlotLoc loc = new PlotLoc(x, z); | ||||||
|         this.allBlocks.put(loc, ids); |         this.allBlocks.put(loc, ids); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -0,0 +1,72 @@ | |||||||
|  | /* | ||||||
|  |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  |  * | ||||||
|  |  * 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 <https://www.gnu.org/licenses/>. | ||||||
|  |  */ | ||||||
|  | package com.plotsquared.bukkit.util; | ||||||
|  |  | ||||||
|  | import com.intellectualsites.annotations.NotPublic; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
|  |  | ||||||
|  | import java.io.IOException; | ||||||
|  | import java.nio.file.Files; | ||||||
|  | import java.nio.file.Path; | ||||||
|  | import java.nio.file.Paths; | ||||||
|  | import java.util.stream.Stream; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This is a helper class which replaces older syntax no longer supported by MiniMessage with replacements in messages_%.json. | ||||||
|  |  * MiniMessage changed the syntax between major releases. To warrant a smooth upgrade, we attempt to replace any occurrences | ||||||
|  |  * while loading PlotSquared. | ||||||
|  |  * | ||||||
|  |  * @since 7.0.0 | ||||||
|  |  */ | ||||||
|  | @NotPublic | ||||||
|  | public class TranslationUpdateManager { | ||||||
|  |  | ||||||
|  |     public static void upgradeTranslationFile() throws IOException { | ||||||
|  |         String suggestCommand = "suggest_command"; | ||||||
|  |         String suggestCommandReplacement = "run_command"; | ||||||
|  |         String minHeight = "minHeight"; | ||||||
|  |         String minheightReplacement = "minheight"; | ||||||
|  |         String maxHeight = "maxHeight"; | ||||||
|  |         String maxheightReplacement = "maxheight"; | ||||||
|  |  | ||||||
|  |         try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) { | ||||||
|  |             paths | ||||||
|  |                     .filter(Files::isRegularFile) | ||||||
|  |                     .filter(p -> p.getFileName().toString().matches("messages_[a-z]{2}\\.json")) | ||||||
|  |                     .forEach(p -> { | ||||||
|  |                         replaceInFile(p, suggestCommand, suggestCommandReplacement); | ||||||
|  |                         replaceInFile(p, minHeight, minheightReplacement); | ||||||
|  |                         replaceInFile(p, maxHeight, maxheightReplacement); | ||||||
|  |                     }); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static void replaceInFile(Path path, String searchText, String replacementText) { | ||||||
|  |         try { | ||||||
|  |             String content = Files.readString(path); | ||||||
|  |             if (content.contains(searchText)) { | ||||||
|  |                 content = content.replaceAll(searchText, replacementText); | ||||||
|  |                 Files.writeString(path, content); | ||||||
|  |             } | ||||||
|  |         } catch (IOException e) { | ||||||
|  |             e.printStackTrace(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -61,7 +54,8 @@ public class UpdateUtility implements Listener { | |||||||
|         internalVersion = PlotSquared.get().getVersion(); |         internalVersion = PlotSquared.get().getVersion(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings({"deprecation", "DefaultCharset"}) // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet |     @SuppressWarnings({"deprecation", "DefaultCharset"}) | ||||||
|  |     // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet | ||||||
|     public void updateChecker() { |     public void updateChecker() { | ||||||
|         task = Bukkit.getScheduler().runTaskTimerAsynchronously(this.javaPlugin, () -> { |         task = Bukkit.getScheduler().runTaskTimerAsynchronously(this.javaPlugin, () -> { | ||||||
|             try { |             try { | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -43,8 +36,7 @@ import com.sk89q.worldedit.function.pattern.Pattern; | |||||||
| import com.sk89q.worldedit.regions.CuboidRegion; | import com.sk89q.worldedit.regions.CuboidRegion; | ||||||
| import com.sk89q.worldedit.world.biome.BiomeType; | import com.sk89q.worldedit.world.biome.BiomeType; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
| import org.jetbrains.annotations.Nullable; |  | ||||||
|  |  | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
| @@ -53,10 +45,7 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|     private final FaweDelegateRegionManager delegate = new FaweDelegateRegionManager(); |     private final FaweDelegateRegionManager delegate = new FaweDelegateRegionManager(); | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public FaweRegionManager( |     public FaweRegionManager(WorldUtil worldUtil, GlobalBlockQueue blockQueue, ProgressSubscriberFactory subscriberFactory) { | ||||||
|             @NonNull WorldUtil worldUtil, @NonNull GlobalBlockQueue blockQueue, @NonNull |  | ||||||
|             ProgressSubscriberFactory subscriberFactory |  | ||||||
|     ) { |  | ||||||
|         super(worldUtil, blockQueue, subscriberFactory); |         super(worldUtil, blockQueue, subscriberFactory); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -83,9 +72,9 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean handleClear( |     public boolean handleClear( | ||||||
|             @NotNull Plot plot, |             @NonNull Plot plot, | ||||||
|             @Nullable Runnable whenDone, |             @Nullable Runnable whenDone, | ||||||
|             @NotNull PlotManager manager, |             @NonNull PlotManager manager, | ||||||
|             final @Nullable PlotPlayer<?> player |             final @Nullable PlotPlayer<?> player | ||||||
|     ) { |     ) { | ||||||
|         if (!Settings.FAWE_Components.CLEAR || !(manager instanceof HybridPlotManager)) { |         if (!Settings.FAWE_Components.CLEAR || !(manager instanceof HybridPlotManager)) { | ||||||
| @@ -106,8 +95,8 @@ public class FaweRegionManager extends BukkitRegionManager { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void setBiome(CuboidRegion region, int extendBiome, BiomeType biome, String world, Runnable whenDone) { |     public void setBiome(CuboidRegion region, int extendBiome, BiomeType biome, PlotArea area, Runnable whenDone) { | ||||||
|         delegate.setBiome(region, extendBiome, biome, world, whenDone); |         delegate.setBiome(region, extendBiome, biome, area.getWorldName(), whenDone); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -36,7 +29,7 @@ import com.plotsquared.core.util.SchematicHandler; | |||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.sk89q.jnbt.CompoundTag; | import com.sk89q.jnbt.CompoundTag; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.io.InputStream; | import java.io.InputStream; | ||||||
| import java.net.URL; | import java.net.URL; | ||||||
| @@ -47,7 +40,7 @@ public class FaweSchematicHandler extends SchematicHandler { | |||||||
|     private final FaweDelegateSchematicHandler delegate = new FaweDelegateSchematicHandler(); |     private final FaweDelegateSchematicHandler delegate = new FaweDelegateSchematicHandler(); | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public FaweSchematicHandler(@NotNull WorldUtil worldUtil, @NotNull ProgressSubscriberFactory subscriberFactory) { |     public FaweSchematicHandler(WorldUtil worldUtil, ProgressSubscriberFactory subscriberFactory) { | ||||||
|         super(worldUtil, subscriberFactory); |         super(worldUtil, subscriberFactory); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -67,7 +60,7 @@ public class FaweSchematicHandler extends SchematicHandler { | |||||||
|             final PlotPlayer<?> actor, |             final PlotPlayer<?> actor, | ||||||
|             final RunnableVal<Boolean> whenDone |             final RunnableVal<Boolean> whenDone | ||||||
|     ) { |     ) { | ||||||
|         delegate.paste(schematic, plot, xOffset, yOffset, zOffset, autoHeight, whenDone); |         delegate.paste(schematic, plot, xOffset, yOffset, zOffset, autoHeight, actor, whenDone); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -82,9 +75,8 @@ public class FaweSchematicHandler extends SchematicHandler { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Schematic getSchematic(@NotNull InputStream is) { |     public Schematic getSchematic(@NonNull InputStream is) { | ||||||
|         return delegate.getSchematic(is); |         return delegate.getSchematic(is); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -118,8 +111,8 @@ public class SQLiteUUIDService implements UUIDService, Consumer<List<UUIDMapping | |||||||
|         try (final PreparedStatement statement = getConnection() |         try (final PreparedStatement statement = getConnection() | ||||||
|                 .prepareStatement("INSERT OR REPLACE INTO `usercache` (`uuid`, `username`) VALUES(?, ?)")) { |                 .prepareStatement("INSERT OR REPLACE INTO `usercache` (`uuid`, `username`) VALUES(?, ?)")) { | ||||||
|             for (final UUIDMapping mapping : uuidWrappers) { |             for (final UUIDMapping mapping : uuidWrappers) { | ||||||
|                 statement.setString(1, mapping.getUuid().toString()); |                 statement.setString(1, mapping.uuid().toString()); | ||||||
|                 statement.setString(2, mapping.getUsername()); |                 statement.setString(2, mapping.username()); | ||||||
|                 statement.executeUpdate(); |                 statement.executeUpdate(); | ||||||
|             } |             } | ||||||
|         } catch (SQLException e) { |         } catch (SQLException e) { | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,16 +4,16 @@ api-version: "1.13" | |||||||
| version: "${version}" | version: "${version}" | ||||||
| load: STARTUP | load: STARTUP | ||||||
| description: "Easy, yet powerful Plot World generation and management." | description: "Easy, yet powerful Plot World generation and management." | ||||||
| authors: [Citymonstret, Empire92, MattBDev, dordsor21, NotMyFault, SirYwell] | authors: [ Citymonstret, Empire92, MattBDev, dordsor21, NotMyFault, SirYwell ] | ||||||
| website: https://www.spigotmc.org/resources/77506/ | website: https://www.spigotmc.org/resources/77506/ | ||||||
| softdepend: [Vault, PlaceholderAPI, Essentials, LuckPerms, BungeePerms, MVdWPlaceholderAPI] | softdepend: [ Vault, PlaceholderAPI, Essentials, LuckPerms, BungeePerms, MVdWPlaceholderAPI ] | ||||||
| loadbefore: [MultiWorld, Multiverse-Core] | loadbefore: [ MultiWorld, Multiverse-Core ] | ||||||
| depend: [WorldEdit] | depend: [ WorldEdit ] | ||||||
| database: false | database: false | ||||||
| commands: | commands: | ||||||
|   plots: |   plots: | ||||||
|     description: Plot command. |     description: Plot command. | ||||||
|     aliases: [p,plot,ps,plotsquared,p2,2,plotme] |     aliases: [ p,plot,ps,plotsquared,p2,2,plotme ] | ||||||
|     permission: plots.use |     permission: plots.use | ||||||
|     permission-message: "You are lacking the permission node 'plots.use'" |     permission-message: "You are lacking the permission node 'plots.use'" | ||||||
| permissions: | permissions: | ||||||
|   | |||||||
| @@ -55,7 +55,7 @@ further defined and clarified by project maintainers. | |||||||
| ## Enforcement | ## Enforcement | ||||||
|  |  | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be | Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||||
| reported by contacting the project team at contact@alexander-soderberg.com. All | reported by contacting the project team at contact<at>intellectualsites.com. All | ||||||
| complaints will be reviewed and investigated and will result in a response that | complaints will be reviewed and investigated and will result in a response that | ||||||
| is deemed necessary and appropriate to the circumstances. The project team is | is deemed necessary and appropriate to the circumstances. The project team is | ||||||
| obligated to maintain confidentiality with regard to the reporter of an incident. | obligated to maintain confidentiality with regard to the reporter of an incident. | ||||||
|   | |||||||
| @@ -2,18 +2,18 @@ import java.time.format.DateTimeFormatter | |||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     // Expected everywhere. |     // Expected everywhere. | ||||||
|     compileOnlyApi(libs.checkerqual) |     compileOnlyApi("org.checkerframework:checker-qual") | ||||||
|  |  | ||||||
|     // Minecraft expectations |     // Minecraft expectations | ||||||
|     compileOnlyApi(libs.gson) |     compileOnlyApi("com.google.code.gson:gson") | ||||||
|     compileOnly(libs.guava) |     compileOnly("com.google.guava:guava") | ||||||
|  |  | ||||||
|     // Platform expectations |     // Platform expectations | ||||||
|     compileOnlyApi(libs.snakeyaml) |     compileOnlyApi("org.yaml:snakeyaml") | ||||||
|  |  | ||||||
|     // Adventure |     // Adventure | ||||||
|     api(libs.adventure) |     api("net.kyori:adventure-api") | ||||||
|     api(libs.minimessage) |     api("net.kyori:adventure-text-minimessage") | ||||||
|  |  | ||||||
|     // Guice |     // Guice | ||||||
|     api(libs.guice) { |     api(libs.guice) { | ||||||
| @@ -22,7 +22,7 @@ dependencies { | |||||||
|     api(libs.guiceassistedinject) { |     api(libs.guiceassistedinject) { | ||||||
|         exclude("com.google.inject", "guice") |         exclude("com.google.inject", "guice") | ||||||
|     } |     } | ||||||
|     api(libs.findbugs) |     api(libs.spotbugs) | ||||||
|  |  | ||||||
|     // Plugins |     // Plugins | ||||||
|     compileOnly(libs.worldeditCore) { |     compileOnly(libs.worldeditCore) { | ||||||
| @@ -31,18 +31,19 @@ dependencies { | |||||||
|         exclude(group = "dummypermscompat") |         exclude(group = "dummypermscompat") | ||||||
|     } |     } | ||||||
|     testImplementation(libs.worldeditCore) |     testImplementation(libs.worldeditCore) | ||||||
|     compileOnly(libs.fastasyncworldeditCore) { isTransitive = false } |     compileOnly("com.fastasyncworldedit:FastAsyncWorldEdit-Core") { isTransitive = false } | ||||||
|     testImplementation(libs.fastasyncworldeditCore) { isTransitive = false } |     testImplementation("com.fastasyncworldedit:FastAsyncWorldEdit-Core") { isTransitive = false } | ||||||
|  |  | ||||||
|     // Logging |     // Logging | ||||||
|     compileOnlyApi(libs.log4j) |     compileOnlyApi("org.apache.logging.log4j:log4j-api") | ||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|     api(libs.prtree) |     api(libs.prtree) | ||||||
|     api(libs.aopalliance) |     api(libs.aopalliance) | ||||||
|     api(libs.cloudServices) |     api(libs.cloudServices) | ||||||
|     api(libs.arkitektonika) |     api(libs.arkitektonika) | ||||||
|     api(libs.paster) |     api("com.intellectualsites.paster:Paster") | ||||||
|  |     api("com.intellectualsites.informative-annotations:informative-annotations") | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks.processResources { | tasks.processResources { | ||||||
| @@ -53,14 +54,30 @@ tasks.processResources { | |||||||
|                 "date" to rootProject.grgit.head().dateTime.format(DateTimeFormatter.ofPattern("yy.MM.dd")) |                 "date" to rootProject.grgit.head().dateTime.format(DateTimeFormatter.ofPattern("yy.MM.dd")) | ||||||
|         ) |         ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     doLast { | ||||||
|  |         copy { | ||||||
|  |             from(File("$rootDir/LICENSE")) | ||||||
|  |             into("$buildDir/resources/main/") | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|  |         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/" + libs.adventure.get().versionConstraint.toString()) |         opt.links("https://jd.advntr.dev/api/4.14.0/") | ||||||
|  |         opt.links("https://jd.advntr.dev/text-minimessage/4.14.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|  |         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") | ||||||
|  |         opt.isLinkSource = true | ||||||
|  |         opt.bottom(File("$rootDir/javadocfooter.html").readText()) | ||||||
|  |         opt.isUse = true | ||||||
|  |         opt.encoding("UTF-8") | ||||||
|  |         opt.keyWords() | ||||||
|  |         opt.addStringOption("-since", isRelease) | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -37,7 +30,7 @@ import com.plotsquared.core.util.ChunkManager; | |||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.query.PlotQuery; | import com.plotsquared.core.util.query.PlotQuery; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -152,7 +145,7 @@ public class PlotAPI { | |||||||
|      */ |      */ | ||||||
|     public void sendConsoleMessage( |     public void sendConsoleMessage( | ||||||
|             final @NonNull String message, |             final @NonNull String message, | ||||||
|             final @NonNull Template @NonNull ... replacements |             final @NonNull TagResolver @NonNull ... replacements | ||||||
|     ) { |     ) { | ||||||
|         ConsolePlayer.getConsole().sendMessage(StaticCaption.of(message), replacements); |         ConsolePlayer.getConsole().sendMessage(StaticCaption.of(message), replacements); | ||||||
|     } |     } | ||||||
| @@ -165,7 +158,7 @@ public class PlotAPI { | |||||||
|      */ |      */ | ||||||
|     public void sendConsoleMessage( |     public void sendConsoleMessage( | ||||||
|             final @NonNull Caption caption, |             final @NonNull Caption caption, | ||||||
|             final @NonNull Template @NonNull ... replacements |             final @NonNull TagResolver @NonNull ... replacements | ||||||
|     ) { |     ) { | ||||||
|         ConsolePlayer.getConsole().sendMessage(caption, replacements); |         ConsolePlayer.getConsole().sendMessage(caption, replacements); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -29,6 +22,7 @@ import cloud.commandframework.services.ServicePipeline; | |||||||
| import com.google.inject.Injector; | import com.google.inject.Injector; | ||||||
| import com.google.inject.Key; | import com.google.inject.Key; | ||||||
| import com.google.inject.TypeLiteral; | import com.google.inject.TypeLiteral; | ||||||
|  | import com.intellectualsites.annotations.DoNotUse; | ||||||
| import com.plotsquared.core.backup.BackupManager; | import com.plotsquared.core.backup.BackupManager; | ||||||
| import com.plotsquared.core.configuration.caption.LocaleHolder; | import com.plotsquared.core.configuration.caption.LocaleHolder; | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| @@ -38,9 +32,9 @@ import com.plotsquared.core.inject.annotations.DefaultGenerator; | |||||||
| import com.plotsquared.core.location.World; | import com.plotsquared.core.location.World; | ||||||
| import com.plotsquared.core.permissions.PermissionHandler; | import com.plotsquared.core.permissions.PermissionHandler; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.expiration.ExpireManager; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
| import com.plotsquared.core.util.AnnotationHelper; |  | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.PlatformWorldManager; | import com.plotsquared.core.util.PlatformWorldManager; | ||||||
| @@ -82,6 +76,11 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      */ |      */ | ||||||
|     void shutdown(); |     void shutdown(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Completely shuts down the server. | ||||||
|  |      */ | ||||||
|  |     void shutdownServer(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the name of the plugin |      * Get the name of the plugin | ||||||
|      * |      * | ||||||
| @@ -98,6 +97,22 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      */ |      */ | ||||||
|     int[] serverVersion(); |     int[] serverVersion(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Gets the default minimum world height for the version of Minecraft that the server is running. | ||||||
|  |      * | ||||||
|  |      * @return minimum world height | ||||||
|  |      * @since 6.6.0 | ||||||
|  |      */ | ||||||
|  |     int versionMinHeight(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Gets the default maximum world height for the version of Minecraft that the server is running. | ||||||
|  |      * | ||||||
|  |      * @return maximum world height (inclusive) | ||||||
|  |      * @since 6.6.0 | ||||||
|  |      */ | ||||||
|  |     int versionMaxHeight(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Gets the server implementation name and version |      * Gets the server implementation name and version | ||||||
|      * |      * | ||||||
| @@ -270,6 +285,16 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|         return injector().getInstance(ChunkManager.class); |         return injector().getInstance(ChunkManager.class); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the {@link ExpireManager} implementation for the platform | ||||||
|  |      * | ||||||
|  |      * @return Expire manager | ||||||
|  |      * @since 6.10.2 | ||||||
|  |      */ | ||||||
|  |     default @NonNull ExpireManager expireManager() { | ||||||
|  |         return injector().getInstance(ExpireManager.class); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the {@link PlotAreaManager} implementation. |      * Get the {@link PlotAreaManager} implementation. | ||||||
|      * |      * | ||||||
| @@ -299,7 +324,7 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      * @return worldedit implementations |      * @return worldedit implementations | ||||||
|      * @since 6.3.0 |      * @since 6.3.0 | ||||||
|      */ |      */ | ||||||
|     @AnnotationHelper.ApiDescription(info = "Internal use only") |     @DoNotUse | ||||||
|     @NonNull String worldEditImplementations(); |     @NonNull String worldEditImplementations(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -343,9 +368,9 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|     @NonNull String toLegacyPlatformString(@NonNull Component component); |     @NonNull String toLegacyPlatformString(@NonNull Component component); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Returns if the FAWE-P2 hook is active/enabled |      * Returns if the FastAsyncWorldEdit-PlotSquared hook is active/enabled | ||||||
|      * |      * | ||||||
|      * @return status of FAWE-P2 hook |      * @return status of FastAsyncWorldEdit-PlotSquared hook | ||||||
|      */ |      */ | ||||||
|     default boolean isFaweHooking() { |     default boolean isFaweHooking() { | ||||||
|         return false; |         return false; | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
| @@ -72,7 +65,10 @@ import com.plotsquared.core.util.ReflectionUtils; | |||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.uuid.UUIDPipeline; | import com.plotsquared.core.uuid.UUIDPipeline; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
|  | import com.sk89q.worldedit.event.platform.PlatformReadyEvent; | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
|  | import com.sk89q.worldedit.util.eventbus.EventHandler; | ||||||
|  | import com.sk89q.worldedit.util.eventbus.Subscribe; | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| import org.checkerframework.checker.nullness.qual.MonotonicNonNull; | import org.checkerframework.checker.nullness.qual.MonotonicNonNull; | ||||||
| @@ -153,6 +149,8 @@ public class PlotSquared { | |||||||
|     private EventDispatcher eventDispatcher; |     private EventDispatcher eventDispatcher; | ||||||
|     private PlotListener plotListener; |     private PlotListener plotListener; | ||||||
|  |  | ||||||
|  |     private boolean weInitialised; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Initialize PlotSquared with the desired Implementation class. |      * Initialize PlotSquared with the desired Implementation class. | ||||||
|      * |      * | ||||||
| @@ -199,6 +197,9 @@ public class PlotSquared { | |||||||
|             this.loadCaptionMap(); |             this.loadCaptionMap(); | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|             LOGGER.error("Failed to load caption map", e); |             LOGGER.error("Failed to load caption map", e); | ||||||
|  |             LOGGER.error("Shutting down server to prevent further issues"); | ||||||
|  |             this.platform.shutdownServer(); | ||||||
|  |             throw new RuntimeException("Abort loading PlotSquared"); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Setup the global flag container |         // Setup the global flag container | ||||||
| @@ -223,6 +224,7 @@ public class PlotSquared { | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             this.worldedit = WorldEdit.getInstance(); |             this.worldedit = WorldEdit.getInstance(); | ||||||
|  |             WorldEdit.getInstance().getEventBus().register(new WEPlatformReadyListener()); | ||||||
|  |  | ||||||
|             // Create Event utility class |             // Create Event utility class | ||||||
|             this.eventDispatcher = new EventDispatcher(this.worldedit); |             this.eventDispatcher = new EventDispatcher(this.worldedit); | ||||||
| @@ -268,7 +270,11 @@ public class PlotSquared { | |||||||
|             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); |             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); | ||||||
|         } else { |         } else { | ||||||
|             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; |             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; | ||||||
|             captionMap = this.captionLoader.loadSingle(this.platform.getDirectory().toPath().resolve("lang").resolve(fileName)); |             captionMap = this.captionLoader.loadOrCreateSingle(this.platform | ||||||
|  |                     .getDirectory() | ||||||
|  |                     .toPath() | ||||||
|  |                     .resolve("lang") | ||||||
|  |                     .resolve(fileName)); | ||||||
|         } |         } | ||||||
|         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); |         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); | ||||||
|         LOGGER.info( |         LOGGER.info( | ||||||
| @@ -288,11 +294,11 @@ public class PlotSquared { | |||||||
|  |  | ||||||
|     public void startExpiryTasks() { |     public void startExpiryTasks() { | ||||||
|         if (Settings.Enabled_Components.PLOT_EXPIRY) { |         if (Settings.Enabled_Components.PLOT_EXPIRY) { | ||||||
|             ExpireManager.IMP = new ExpireManager(this.eventDispatcher); |             ExpireManager expireManager = PlotSquared.platform().expireManager(); | ||||||
|             ExpireManager.IMP.runAutomatedTask(); |             expireManager.runAutomatedTask(); | ||||||
|             for (Settings.Auto_Clear settings : Settings.AUTO_CLEAR.getInstances()) { |             for (Settings.Auto_Clear settings : Settings.AUTO_CLEAR.getInstances()) { | ||||||
|                 ExpiryTask task = new ExpiryTask(settings, this.getPlotAreaManager()); |                 ExpiryTask task = new ExpiryTask(settings, this.getPlotAreaManager()); | ||||||
|                 ExpireManager.IMP.addTask(task); |                 expireManager.addTask(task); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -643,7 +649,8 @@ public class PlotSquared { | |||||||
|         } else { |         } else { | ||||||
|             list = new ArrayList<>(input); |             list = new ArrayList<>(input); | ||||||
|         } |         } | ||||||
|         list.sort(Comparator.comparingLong(a -> ExpireManager.IMP.getTimestamp(a.getOwnerAbs()))); |         ExpireManager expireManager = PlotSquared.platform().expireManager(); | ||||||
|  |         list.sort(Comparator.comparingLong(a -> expireManager.getTimestamp(a.getOwnerAbs()))); | ||||||
|         return list; |         return list; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -787,7 +794,9 @@ public class PlotSquared { | |||||||
|         if (world.equals("CheckingPlotSquaredGenerator")) { |         if (world.equals("CheckingPlotSquaredGenerator")) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         this.getPlotAreaManager().addWorld(world); |         if (!this.getPlotAreaManager().addWorld(world)) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|         Set<String> worlds; |         Set<String> worlds; | ||||||
|         if (this.worldConfiguration.contains("worlds")) { |         if (this.worldConfiguration.contains("worlds")) { | ||||||
|             worlds = this.worldConfiguration.getConfigurationSection("worlds").getKeys(false); |             worlds = this.worldConfiguration.getConfigurationSection("worlds").getKeys(false); | ||||||
| @@ -889,8 +898,8 @@ public class PlotSquared { | |||||||
|                             e.printStackTrace(); |                             e.printStackTrace(); | ||||||
|                         } |                         } | ||||||
|                         LOGGER.info("| generator: {}>{}", baseGenerator, areaGen); |                         LOGGER.info("| generator: {}>{}", baseGenerator, areaGen); | ||||||
|                         LOGGER.info("| plot world: {}", pa); |                         LOGGER.info("| plot world: {}", pa.getClass().getCanonicalName()); | ||||||
|                         LOGGER.info("| manager: {}", pa); |                         LOGGER.info("| manager: {}", pa.getPlotManager().getClass().getCanonicalName()); | ||||||
|                         LOGGER.info("Note: Area created for cluster '{}' (invalid or old configuration?)", name); |                         LOGGER.info("Note: Area created for cluster '{}' (invalid or old configuration?)", name); | ||||||
|                         areaGen.getPlotGenerator().initialize(pa); |                         areaGen.getPlotGenerator().initialize(pa); | ||||||
|                         areaGen.augment(pa); |                         areaGen.augment(pa); | ||||||
| @@ -906,6 +915,13 @@ public class PlotSquared { | |||||||
|                     throw new IllegalArgumentException("Invalid Generator: " + gen_string); |                     throw new IllegalArgumentException("Invalid Generator: " + gen_string); | ||||||
|                 } |                 } | ||||||
|                 PlotArea pa = areaGen.getPlotGenerator().getNewPlotArea(world, null, null, null); |                 PlotArea pa = areaGen.getPlotGenerator().getNewPlotArea(world, null, null, null); | ||||||
|  |                 LOGGER.info("- generator: {}>{}", baseGenerator, areaGen); | ||||||
|  |                 LOGGER.info("- plot world: {}", pa.getClass().getCanonicalName()); | ||||||
|  |                 LOGGER.info("- plot area manager: {}", pa.getPlotManager().getClass().getCanonicalName()); | ||||||
|  |                 if (!this.worldConfiguration.contains(path)) { | ||||||
|  |                     this.worldConfiguration.createSection(path); | ||||||
|  |                     worldSection = this.worldConfiguration.getConfigurationSection(path); | ||||||
|  |                 } | ||||||
|                 pa.saveConfiguration(worldSection); |                 pa.saveConfiguration(worldSection); | ||||||
|                 pa.loadDefaultConfiguration(worldSection); |                 pa.loadDefaultConfiguration(worldSection); | ||||||
|                 try { |                 try { | ||||||
| @@ -913,9 +929,6 @@ public class PlotSquared { | |||||||
|                 } catch (IOException e) { |                 } catch (IOException e) { | ||||||
|                     e.printStackTrace(); |                     e.printStackTrace(); | ||||||
|                 } |                 } | ||||||
|                 LOGGER.info("- generator: {}>{}", baseGenerator, areaGen); |  | ||||||
|                 LOGGER.info("- plot world: {}", pa); |  | ||||||
|                 LOGGER.info("- plot area manager: {}", pa.getPlotManager()); |  | ||||||
|                 areaGen.getPlotGenerator().initialize(pa); |                 areaGen.getPlotGenerator().initialize(pa); | ||||||
|                 areaGen.augment(pa); |                 areaGen.augment(pa); | ||||||
|                 addPlotArea(pa); |                 addPlotArea(pa); | ||||||
| @@ -1002,7 +1015,7 @@ public class PlotSquared { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Setup the configuration for a plot world based on world arguments. |      * Setup the configuration for a plot world based on world arguments. | ||||||
|      * |      * <p> | ||||||
|      * |      * | ||||||
|      * <i>e.g. /mv create <world> normal -g PlotSquared:<args></i> |      * <i>e.g. /mv create <world> normal -g PlotSquared:<args></i> | ||||||
|      * |      * | ||||||
| @@ -1020,8 +1033,8 @@ public class PlotSquared { | |||||||
|             // save configuration |             // save configuration | ||||||
|  |  | ||||||
|             final List<String> validArguments = Arrays |             final List<String> validArguments = Arrays | ||||||
|                     .asList("s=", "size=", "g=", "gap=", "h=", "height=", "f=", "floor=", "m=", "main=", |                     .asList("s=", "size=", "g=", "gap=", "h=", "height=", "minh=", "minheight=", "maxh=", "maxheight=", | ||||||
|                             "w=", "wall=", "b=", "border=" |                             "f=", "floor=", "m=", "main=", "w=", "wall=", "b=", "border=" | ||||||
|                     ); |                     ); | ||||||
|  |  | ||||||
|             // Calculate the number of expected arguments |             // Calculate the number of expected arguments | ||||||
| @@ -1100,6 +1113,14 @@ public class PlotSquared { | |||||||
|                                     ConfigurationUtil.INTEGER.parseString(value).shortValue() |                                     ConfigurationUtil.INTEGER.parseString(value).shortValue() | ||||||
|                             ); |                             ); | ||||||
|                         } |                         } | ||||||
|  |                         case "minh", "minheight" -> this.worldConfiguration.set( | ||||||
|  |                                 base + "world.min_gen_height", | ||||||
|  |                                 ConfigurationUtil.INTEGER.parseString(value).shortValue() | ||||||
|  |                         ); | ||||||
|  |                         case "maxh", "maxheight" -> this.worldConfiguration.set( | ||||||
|  |                                 base + "world.max_gen_height", | ||||||
|  |                                 ConfigurationUtil.INTEGER.parseString(value).shortValue() | ||||||
|  |                         ); | ||||||
|                         case "f", "floor" -> this.worldConfiguration.set( |                         case "f", "floor" -> this.worldConfiguration.set( | ||||||
|                                 base + "plot.floor", |                                 base + "plot.floor", | ||||||
|                                 ConfigurationUtil.BLOCK_BUCKET.parseString(value).toString() |                                 ConfigurationUtil.BLOCK_BUCKET.parseString(value).toString() | ||||||
| @@ -1562,6 +1583,13 @@ public class PlotSquared { | |||||||
|         return this.plotListener; |         return this.plotListener; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get if the {@link PlatformReadyEvent} has been sent by WorldEdit. There is no way to query this within WorldEdit itself. | ||||||
|  |      */ | ||||||
|  |     public boolean isWeInitialised() { | ||||||
|  |         return weInitialised; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Different ways of sorting {@link Plot plots} |      * Different ways of sorting {@link Plot plots} | ||||||
|      */ |      */ | ||||||
| @@ -1584,4 +1612,15 @@ public class PlotSquared { | |||||||
|         DISTANCE_FROM_ORIGIN |         DISTANCE_FROM_ORIGIN | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private final class WEPlatformReadyListener { | ||||||
|  |  | ||||||
|  |         @SuppressWarnings("unused") | ||||||
|  |         @Subscribe(priority = EventHandler.Priority.VERY_EARLY) | ||||||
|  |         public void onPlatformReady(PlatformReadyEvent event) { | ||||||
|  |             weInitialised = true; | ||||||
|  |             WorldEdit.getInstance().getEventBus().unregister(WEPlatformReadyListener.this); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,14 +1,7 @@ | |||||||
| /* | /* | ||||||
|  *       _____  _       _    _____                                _ |  * PlotSquared, a land and world management plugin for Minecraft. | ||||||
|  *      |  __ \| |     | |  / ____|                              | | |  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||||
|  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | |  * Copyright (C) IntellectualSites team and contributors | ||||||
|  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | |  | ||||||
|  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | |  | ||||||
|  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| |  | ||||||
|  *                                    | | |  | ||||||
|  *                                    |_| |  | ||||||
|  *            PlotSquared plot management system for Minecraft |  | ||||||
|  *               Copyright (C) 2014 - 2022 IntellectualSites |  | ||||||
|  * |  * | ||||||
|  * This program is free software: you can redistribute it and/or modify |  * 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 |  * it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user