From 3259bbca4b28e226e8939c8581e9e74684b7ac5d Mon Sep 17 00:00:00 2001 From: Adam Gent Date: Sun, 31 Jul 2022 16:27:16 -0400 Subject: [PATCH] Remove commons lang as a compile time dependency --- pom.xml | 8 +++ .../networknt/schema/BaseJsonValidator.java | 2 +- .../com/networknt/schema/JsonMetaSchema.java | 2 +- .../networknt/schema/ValidationMessage.java | 2 +- .../networknt/schema/utils/StringUtils.java | 53 +++++++++++++++++++ .../schema/BaseSuiteJsonSchemaTest.java | 2 +- 6 files changed, 65 insertions(+), 4 deletions(-) create mode 100644 src/main/java/com/networknt/schema/utils/StringUtils.java diff --git a/pom.xml b/pom.xml index 0f680ac86..26449d168 100644 --- a/pom.xml +++ b/pom.xml @@ -84,10 +84,18 @@ slf4j-api ${version.slf4j} + org.apache.commons commons-lang3 ${version.common-lang3} + runtime org.jruby.joni diff --git a/src/main/java/com/networknt/schema/BaseJsonValidator.java b/src/main/java/com/networknt/schema/BaseJsonValidator.java index 7ffa4baf9..51009318f 100644 --- a/src/main/java/com/networknt/schema/BaseJsonValidator.java +++ b/src/main/java/com/networknt/schema/BaseJsonValidator.java @@ -26,7 +26,7 @@ import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.node.ObjectNode; import com.networknt.schema.ValidationContext.DiscriminatorContext; -import org.apache.commons.lang3.StringUtils; +import com.networknt.schema.utils.StringUtils; import org.slf4j.Logger; public abstract class BaseJsonValidator implements JsonValidator { diff --git a/src/main/java/com/networknt/schema/JsonMetaSchema.java b/src/main/java/com/networknt/schema/JsonMetaSchema.java index 1e543f327..61699bf14 100644 --- a/src/main/java/com/networknt/schema/JsonMetaSchema.java +++ b/src/main/java/com/networknt/schema/JsonMetaSchema.java @@ -17,7 +17,7 @@ package com.networknt.schema; import com.fasterxml.jackson.databind.JsonNode; -import org.apache.commons.lang3.StringUtils; +import com.networknt.schema.utils.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; diff --git a/src/main/java/com/networknt/schema/ValidationMessage.java b/src/main/java/com/networknt/schema/ValidationMessage.java index 843e4fe35..db14cab01 100644 --- a/src/main/java/com/networknt/schema/ValidationMessage.java +++ b/src/main/java/com/networknt/schema/ValidationMessage.java @@ -16,7 +16,7 @@ package com.networknt.schema; -import org.apache.commons.lang3.StringUtils; +import com.networknt.schema.utils.StringUtils; import java.text.MessageFormat; import java.util.Arrays; diff --git a/src/main/java/com/networknt/schema/utils/StringUtils.java b/src/main/java/com/networknt/schema/utils/StringUtils.java new file mode 100644 index 000000000..2e06651ce --- /dev/null +++ b/src/main/java/com/networknt/schema/utils/StringUtils.java @@ -0,0 +1,53 @@ +package com.networknt.schema.utils; + +public final class StringUtils { + + private StringUtils() { + } + + public static boolean isBlank(final CharSequence cs) { + int strLen = length(cs); + if (strLen == 0) { + return true; + } + for (int i = 0; i < strLen; i++) { + if (!Character.isWhitespace(cs.charAt(i))) { + return false; + } + } + return true; + } + + public static boolean isNotBlank(final CharSequence cs) { + return !isBlank(cs); + } + + private static int length(final CharSequence cs) { + return cs == null ? 0 : cs.length(); + } + + // The following was borrowed from Apache Commons Lang 3 + public static boolean equals(final CharSequence cs1, final CharSequence cs2) { + if (cs1 == cs2) { + return true; + } + if (cs1 == null || cs2 == null) { + return false; + } + if (cs1.length() != cs2.length()) { + return false; + } + if (cs1 instanceof String && cs2 instanceof String) { + return cs1.equals(cs2); + } + // Step-wise comparison + final int length = cs1.length(); + for (int i = 0; i < length; i++) { + if (cs1.charAt(i) != cs2.charAt(i)) { + return false; + } + } + return true; + } + +} diff --git a/src/test/java/com/networknt/schema/BaseSuiteJsonSchemaTest.java b/src/test/java/com/networknt/schema/BaseSuiteJsonSchemaTest.java index 2a316a40e..7711cdd95 100644 --- a/src/test/java/com/networknt/schema/BaseSuiteJsonSchemaTest.java +++ b/src/test/java/com/networknt/schema/BaseSuiteJsonSchemaTest.java @@ -21,7 +21,7 @@ import com.fasterxml.jackson.databind.node.ArrayNode; import io.undertow.Undertow; import io.undertow.server.handlers.resource.FileResourceManager; -import org.apache.commons.lang3.StringUtils; +import com.networknt.schema.utils.StringUtils; import org.junit.jupiter.api.AfterAll; import org.junit.jupiter.api.BeforeAll;