Merge pull request #2 from linbergil/dev

dev
This commit is contained in:
Илья Смышляев 2023-11-05 05:29:01 +03:00 committed by GitHub
commit c45e5c6e0e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 13 additions and 12 deletions

View File

@ -21,9 +21,6 @@ func Unpack(str string) (string, error) {
var currentState state = start
var result strings.Builder
numOfRepeat := 1
//if firstCheckString(&str) == true {
// return "", ErrInvalidString
//}
var runeArray = []rune(str)
@ -38,6 +35,13 @@ func Unpack(str string) (string, error) {
if unicode.IsDigit(char) {
currentState = number
numOfRepeat, _ = strconv.Atoi(string(char))
repStr, err := repeatRune(runeArray[i-1], numOfRepeat)
if err != nil {
res := result.String()
result.Reset()
result.WriteString(res[0 : len(res)-1])
}
result.WriteString(repStr)
} else if char == '\\' {
currentState = escape
} else {
@ -48,18 +52,11 @@ func Unpack(str string) (string, error) {
if unicode.IsDigit(char) {
return "", ErrInvalidString
}
repStr, err := repeatRune(runeArray[i-2], numOfRepeat)
if err != nil {
res := result.String()
result.Reset()
result.WriteString(res[0 : len(res)-1])
}
result.WriteString(repStr)
currentState = start
result.WriteRune(char)
case escape:
result.WriteRune(char)
currentState = start
}
}

View File

@ -16,6 +16,10 @@ func TestUnpack(t *testing.T) {
{input: "abccd", expected: "abccd"},
{input: "", expected: ""},
{input: "aaa0b", expected: "aab"},
{input: "a2", expected: "aa"},
{input: "aa", expected: "aa"},
{input: "a", expected: "a"},
{input: "d\n5abc", expected: "d\n\n\n\n\nabc"},
{input: `qwe\4\5`, expected: `qwe45`},
{input: `qwe\45`, expected: `qwe44444`},
{input: `qwe\\5`, expected: `qwe\\\\\`},
@ -33,7 +37,7 @@ func TestUnpack(t *testing.T) {
}
func TestUnpackInvalidString(t *testing.T) {
invalidStrings := []string{"3abc", "45", "aaa10b"}
invalidStrings := []string{"3abc", "45", "aaa10b", "1"}
for _, tc := range invalidStrings {
tc := tc
t.Run(tc, func(t *testing.T) {