Skip to content

Commit

Permalink
GROOVY-11314: JsonOutput Pretty Print always escapes characters
Browse files Browse the repository at this point in the history
  • Loading branch information
paulk-asert committed Feb 21, 2024
1 parent 2bd36e5 commit b09ba10
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 6 deletions.
24 changes: 18 additions & 6 deletions subprojects/groovy-json/src/main/java/groovy/json/JsonOutput.java
Original file line number Diff line number Diff line change
Expand Up @@ -156,17 +156,29 @@ public static String toJson(Map m) {
/**
* Pretty print a JSON payload.
*
* @param jsonPayload
* @param jsonPayload a JSON payload
* @return a pretty representation of JSON payload.
*/
public static String prettyPrint(String jsonPayload) {
return prettyPrint(jsonPayload, false);
}

/**
* Pretty print a JSON payload.
*
* @param jsonPayload a JSON payload
* @param disableUnicodeEscaping whether to disable unicode escaping
* @return a pretty representation of JSON payload.
* @since 4.0.19
*/
public static String prettyPrint(String jsonPayload, boolean disableUnicodeEscaping) {
int indentSize = 0;
// Just a guess that the pretty view will take 20 percent more than original.
final CharBuf output = CharBuf.create((int) (jsonPayload.length() * 1.2));

JsonLexer lexer = new JsonLexer(new StringReader(jsonPayload));
// Will store already created indents.
Map<Integer, char[]> indentCache = new HashMap<Integer, char[]>();
Map<Integer, char[]> indentCache = new HashMap<>();
while (lexer.hasNext()) {
JsonToken token = lexer.next();
switch (token.getType()) {
Expand Down Expand Up @@ -209,8 +221,8 @@ public static String prettyPrint(String jsonPayload) {
case STRING:
String textStr = token.getText();
String textWithoutQuotes = textStr.substring(1, textStr.length() - 1);
if (textWithoutQuotes.length() > 0) {
output.addJsonEscapedString(textWithoutQuotes);
if (!textWithoutQuotes.isEmpty()) {
output.addJsonEscapedString(textWithoutQuotes, disableUnicodeEscaping);
} else {
output.addQuoted(Chr.array());
}
Expand All @@ -225,7 +237,7 @@ public static String prettyPrint(String jsonPayload) {
}

/**
* Creates new indent if it not exists in the indent cache.
* Creates a new indent if it doesn't exist in the indent cache.
*
* @return indent with the specified size.
*/
Expand Down Expand Up @@ -254,7 +266,7 @@ public static JsonUnescaped unescaped(CharSequence text) {
* Represents unescaped JSON
*/
public static class JsonUnescaped {
private CharSequence text;
private final CharSequence text;

public JsonUnescaped(CharSequence text) {
this.text = text;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -314,6 +314,22 @@ final class JsonOutputTest {
}""".stripIndent()
}

@Test
void testPrettyPrintUnicodeEscapeVariants() {
def map = [name: "Järry"]
def json = JsonOutput.toJson(map)
// with escaping
assert JsonOutput.prettyPrint(json) == '''\
{
"name": "J\\u00e4rry"
}'''.stripIndent()
// with escaping disabled
assert JsonOutput.prettyPrint(json, true) == '''\
{
"name": "Järry"
}'''.stripIndent()
}

@Test
void testSerializePogos() {
def city = new JsonCity("Paris", [
Expand Down

0 comments on commit b09ba10

Please sign in to comment.