From c1d06a9f8b37b2ef874e4e3a2e45b8415f84444f Mon Sep 17 00:00:00 2001 From: codemasterover9000 Date: Fri, 24 May 2024 16:12:56 +0200 Subject: [PATCH] Make rpc serialization chunk size configurable (#9578) --- .../server/rpc/impl/ServerSerializationStreamWriter.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/user/src/com/google/gwt/user/server/rpc/impl/ServerSerializationStreamWriter.java b/user/src/com/google/gwt/user/server/rpc/impl/ServerSerializationStreamWriter.java index 5e29935e368..93d2771f874 100644 --- a/user/src/com/google/gwt/user/server/rpc/impl/ServerSerializationStreamWriter.java +++ b/user/src/com/google/gwt/user/server/rpc/impl/ServerSerializationStreamWriter.java @@ -48,11 +48,11 @@ public final class ServerSerializationStreamWriter extends * array literals. */ public static class LengthConstrainedArray { - public static final int MAXIMUM_ARRAY_LENGTH = 1 << 15; private static final String POSTLUDE = "])"; private static final String PRELUDE = "].concat(["; private final StringBuffer buffer; + private final int maximumArrayLength = Integer.getInteger("gwt.rpc.maxPayloadChunkSize", 1 << 15); private int count = 0; private boolean needsComma = false; private int total = 0; @@ -68,8 +68,8 @@ public LengthConstrainedArray(int capacityGuess) { public void addToken(CharSequence token) { total++; - if (count++ == MAXIMUM_ARRAY_LENGTH) { - if (total == MAXIMUM_ARRAY_LENGTH + 1) { + if (count++ == maximumArrayLength) { + if (total == maximumArrayLength + 1) { buffer.append(PRELUDE); javascript = true; } else { @@ -106,7 +106,7 @@ public void setJavaScript(boolean javascript) { @Override public String toString() { - if (total > MAXIMUM_ARRAY_LENGTH) { + if (total > maximumArrayLength) { return "[" + buffer.toString() + POSTLUDE; } else { return "[" + buffer.toString() + "]";