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

Reply via email to