Skip to content

Commit

Permalink
Added the possiblity to disable smart truncate (with the exception of…
Browse files Browse the repository at this point in the history
… the triming)
  • Loading branch information
Aymen Ben Tanfous committed Sep 16, 2022
1 parent e104167 commit 1994a42
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 10 deletions.
8 changes: 7 additions & 1 deletion slug.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ var (
// after MaxLength.
MaxLength int

EnableSmartTruncate = true

// Lowercase defines if the resulting slug is transformed to lowercase.
// Default is true.
Lowercase = true
Expand Down Expand Up @@ -102,12 +104,16 @@ func MakeLang(s string, lang string) (slug string) {
slug = strings.ToLower(slug)
}

if !EnableSmartTruncate {
slug = slug[:MaxLength]
}

// Process all remaining symbols
slug = regexpNonAuthorizedChars.ReplaceAllString(slug, "-")
slug = regexpMultipleDashes.ReplaceAllString(slug, "-")
slug = strings.Trim(slug, "-_")

if MaxLength > 0 {
if MaxLength > 0 && EnableSmartTruncate {
slug = smartTruncate(slug)
}

Expand Down
27 changes: 18 additions & 9 deletions slug_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -266,20 +266,29 @@ func TestSubstituteRuneLang(t *testing.T) {

func TestSlugMakeSmartTruncate(t *testing.T) {
testCases := []struct {
in string
maxLength int
want string
in string
maxLength int
want string
smartTruncate bool
}{
{"DOBROSLAWZYBORT", 100, "dobroslawzybort"},
{"Dobroslaw Zybort", 100, "dobroslaw-zybort"},
{"Dobroslaw Zybort", 12, "dobroslaw"},
{" Dobroslaw Zybort ?", 12, "dobroslaw"},
{"Ala ma 6 kotów.", 10, "ala-ma-6"},
{"Dobrosław Żybort", 5, "dobro"},
{"DOBROSLAWZYBORT", 100, "dobroslawzybort", true},
{"Dobroslaw Zybort", 100, "dobroslaw-zybort", true},
{"Dobroslaw Zybort", 12, "dobroslaw", true},
{" Dobroslaw Zybort ?", 12, "dobroslaw", true},
{"Ala ma 6 kotów.", 10, "ala-ma-6", true},
{"Dobrosław Żybort", 5, "dobro", true},
{"Long branch-name", 14, "long-branch-na", false},
{"Long branch-name", 12, "long-branch", false},
}

for index, smstt := range testCases {
MaxLength = smstt.maxLength
if smstt.smartTruncate {
EnableSmartTruncate = true
} else {
EnableSmartTruncate = false
}

got := Make(smstt.in)
if got != smstt.want {
t.Errorf(
Expand Down

0 comments on commit 1994a42

Please sign in to comment.