This is an automated email from the ASF dual-hosted git repository.
ggregory pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/commons-lang.git
The following commit(s) were added to refs/heads/master by this push:
new 67f50236b Revert "'abbreviate' contract violations (#1490)"
67f50236b is described below
commit 67f50236bf337e20c6daa987d4d42c4fedb482ce
Author: Gary Gregory <[email protected]>
AuthorDate: Fri Jan 16 15:15:38 2026 -0500
Revert "'abbreviate' contract violations (#1490)"
This reverts commit 2f07d02fca0a66144b7106298fd9eb207783fecc.
---
src/main/java/org/apache/commons/lang3/StringUtils.java | 10 +++++-----
.../apache/commons/lang3/StringUtilsAbbreviateTest.java | 15 +--------------
2 files changed, 6 insertions(+), 19 deletions(-)
diff --git a/src/main/java/org/apache/commons/lang3/StringUtils.java
b/src/main/java/org/apache/commons/lang3/StringUtils.java
index ee6b9eea7..22d12e45b 100644
--- a/src/main/java/org/apache/commons/lang3/StringUtils.java
+++ b/src/main/java/org/apache/commons/lang3/StringUtils.java
@@ -352,12 +352,12 @@ public static String abbreviate(final String str, final
String abbrevMarker, fin
* @throws IllegalArgumentException if the width is too small.
* @since 3.6
*/
- public static String abbreviate(final String str, String abbrevMarker, int
offset, final int maxWidth) {
- if (isEmpty(str)) {
- return str;
+ public static String abbreviate(final String str, final String
abbrevMarker, int offset, final int maxWidth) {
+ if (isNotEmpty(str) && EMPTY.equals(abbrevMarker) && maxWidth > 0) {
+ return substring(str, 0, maxWidth);
}
- if (abbrevMarker == null) {
- abbrevMarker = EMPTY;
+ if (isAnyEmpty(str, abbrevMarker)) {
+ return str;
}
final int abbrevMarkerLength = abbrevMarker.length();
final int minAbbrevWidth = abbrevMarkerLength + 1;
diff --git
a/src/test/java/org/apache/commons/lang3/StringUtilsAbbreviateTest.java
b/src/test/java/org/apache/commons/lang3/StringUtilsAbbreviateTest.java
index ccd2ad211..49a188d06 100644
--- a/src/test/java/org/apache/commons/lang3/StringUtilsAbbreviateTest.java
+++ b/src/test/java/org/apache/commons/lang3/StringUtilsAbbreviateTest.java
@@ -101,16 +101,13 @@ void testAbbreviate_StringIntInt() {
assertAbbreviateWithOffset("...ijklmno", 15, 10);
assertAbbreviateWithOffset("...ijklmno", 16, 10);
assertAbbreviateWithOffset("...ijklmno", Integer.MAX_VALUE, 10);
-
- // abbreviating a shorter string allows maxWidth < 7
- assertEquals("...efg", StringUtils.abbreviate("abcdefg", 5, 6));
}
@Test
void testAbbreviate_StringStringInt() {
assertNull(StringUtils.abbreviate(null, null, 10));
assertNull(StringUtils.abbreviate(null, "...", 10));
- assertEquals("paranaguac", StringUtils.abbreviate("paranaguacu", null,
10));
+ assertEquals("paranaguacu", StringUtils.abbreviate("paranaguacu",
null, 10));
assertEquals("", StringUtils.abbreviate("", "...", 2));
assertEquals("wai**", StringUtils.abbreviate("waiheke", "**", 5));
assertEquals("And af,,,,", StringUtils.abbreviate("And after a long
time, he finally met his son.", ",,,,", 10));
@@ -133,12 +130,6 @@ void testAbbreviate_StringStringIntInt() {
assertNull(StringUtils.abbreviate(null, "...", 10, 12));
assertEquals("", StringUtils.abbreviate("", null, 0, 10));
assertEquals("", StringUtils.abbreviate("", "...", 2, 10));
- assertEquals("abcdefg", StringUtils.abbreviate("abcdefg", null, 2,
10));
- assertEquals("abcdefg", StringUtils.abbreviate("abcdefg", "", 2, 10));
- assertEquals("abc", StringUtils.abbreviate("abcdefg", null, 0, 3));
- assertEquals("cde", StringUtils.abbreviate("abcdefg", null, 2, 3));
- assertEquals("abc", StringUtils.abbreviate("abcdefg", "", 0, 3));
- assertEquals("cde", StringUtils.abbreviate("abcdefg", "", 2, 3));
assertIllegalArgumentException(() ->
StringUtils.abbreviate("abcdefghij", "::", 0, 2),
"StringUtils.abbreviate expecting IllegalArgumentException");
assertIllegalArgumentException(() ->
StringUtils.abbreviate("abcdefghij", "!!!", 5, 6),
@@ -166,10 +157,6 @@ void testAbbreviate_StringStringIntInt() {
assertAbbreviateWithAbbrevMarkerAndOffset("999ijklmno", "999", 15, 10);
assertAbbreviateWithAbbrevMarkerAndOffset("_ghijklmno", "_", 16, 10);
assertAbbreviateWithAbbrevMarkerAndOffset("+ghijklmno", "+",
Integer.MAX_VALUE, 10);
-
- // abbreviating a shorter string allows maxWidth < abbrevMarker.length
* 2 + 1
- assertEquals("..de", StringUtils.abbreviate("abcde", "..", 4, 4));
- assertEquals("....fg", StringUtils.abbreviate("abcdefg", "....", 5,
6));
}
// Fixed LANG-1463