From c848b33030824e45fdee73397635206464b236b2 Mon Sep 17 00:00:00 2001 From: Nassim Jahnke Date: Mon, 25 Mar 2024 13:26:01 +0100 Subject: [PATCH] Return dummy string instead of empty optional --- patches/server/Improve-tag-parser-handling.patch | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/patches/server/Improve-tag-parser-handling.patch b/patches/server/Improve-tag-parser-handling.patch index b86a852b95..9996ed519d 100644 --- a/patches/server/Improve-tag-parser-handling.patch +++ b/patches/server/Improve-tag-parser-handling.patch @@ -130,15 +130,15 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 @Override public Optional visit(FormattedText.ContentConsumer visitor) { -+ // Paper start ++ // Paper start - Count visited parts + try { + return this.visit(new TranslatableContentConsumer<>(visitor)); -+ } catch (IllegalArgumentException var5) { -+ return Optional.empty(); ++ } catch (IllegalArgumentException ignored) { ++ return visitor.accept("..."); + } + } + private Optional visit(TranslatableContentConsumer visitor) { -+ // Paper end ++ // Paper end - Count visited parts this.decompose(); for(FormattedText formattedText : this.decomposedParts) { @@ -146,8 +146,9 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 return Optional.empty(); } -+ // Paper start ++ // Paper start - Count visited parts + private static final class TranslatableContentConsumer implements FormattedText.ContentConsumer { ++ private static final IllegalArgumentException EX = new IllegalArgumentException("Too long"); + private final FormattedText.ContentConsumer visitor; + private int visited; + @@ -158,12 +159,12 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + @Override + public Optional accept(final String asString) { + if (visited++ > 32) { -+ throw new IllegalArgumentException("Too long"); ++ throw EX; + } + return this.visitor.accept(asString); + } + } -+ // Paper end ++ // Paper end - Count visited parts @Override public MutableComponent resolve(@Nullable CommandSourceStack source, @Nullable Entity sender, int depth) throws CommandSyntaxException {