diff --git a/chat/src/main/java/net/md_5/bungee/api/chat/ComponentStyle.java b/chat/src/main/java/net/md_5/bungee/api/chat/ComponentStyle.java index c19d92fabb..8b18aa7683 100644 --- a/chat/src/main/java/net/md_5/bungee/api/chat/ComponentStyle.java +++ b/chat/src/main/java/net/md_5/bungee/api/chat/ComponentStyle.java @@ -186,15 +186,15 @@ public Boolean isObfuscatedRaw() } /** - * Returns whether this style has any formatting explicitly set. + * Returns whether this style has no formatting explicitly set. * - * @return true if at least one value is set, false if none are set + * @return true if no value is set, false if at least one is set */ public boolean isEmpty() { - return color != null || font != null || bold != null - || italic != null || underlined != null - || strikethrough != null || obfuscated != null; + return color == null && font == null && bold == null + && italic == null && underlined == null + && strikethrough == null && obfuscated == null; } @Override diff --git a/chat/src/test/java/net/md_5/bungee/api/chat/ComponentsTest.java b/chat/src/test/java/net/md_5/bungee/api/chat/ComponentsTest.java index 555dd33328..0c36662f0f 100644 --- a/chat/src/test/java/net/md_5/bungee/api/chat/ComponentsTest.java +++ b/chat/src/test/java/net/md_5/bungee/api/chat/ComponentsTest.java @@ -825,6 +825,28 @@ public void testLegacyResetInBuilderBuild() ); } + @Test + public void testHasFormatting() + { + BaseComponent component = new TextComponent(); + assertFalse( component.hasFormatting() ); + + component.setBold( true ); + assertTrue( component.hasFormatting() ); + } + + @Test + public void testStyleIsEmpty() + { + ComponentStyle style = ComponentStyle.builder().build(); + assertTrue( style.isEmpty() ); + + style = ComponentStyle.builder() + .bold( true ) + .build(); + assertFalse( style.isEmpty() ); + } + /* * In legacy chat, colors and reset both reset all formatting. * Make sure it works in combination with ComponentBuilder.