mirror of
https://github.com/qdm12/gluetun.git
synced 2026-05-10 04:30:20 +02:00
4a78989d9d
- main reason being it's a burden to always define sentinel errors at global scope, wrap them with `%w` instead of using a string directly - only use sentinel errors when it has to be checked using `errors.Is` - replace all usage of these sentinel errors in `fmt.Errorf` with direct strings that were in the sentinel error - exclude the sentinel error definition requirement from .golangci.yml - update unit tests to use ContainersError instead of ErrorIs so it stays as a "not a change detector test" without requiring a sentinel error
27 lines
544 B
Go
27 lines
544 B
Go
package updater
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
"strconv"
|
|
"strings"
|
|
)
|
|
|
|
var ErrNoIDInServerName = errors.New("no ID in server name")
|
|
|
|
func parseServerName(serverName string) (number uint16, err error) {
|
|
i := strings.IndexRune(serverName, '#')
|
|
if i < 0 {
|
|
return 0, fmt.Errorf("%w: %s", ErrNoIDInServerName, serverName)
|
|
}
|
|
|
|
idString := serverName[i+1:]
|
|
idUint64, err := strconv.ParseUint(idString, 10, 16)
|
|
if err != nil {
|
|
return 0, fmt.Errorf("invalid ID in server name: %s", serverName)
|
|
}
|
|
|
|
number = uint16(idUint64)
|
|
return number, nil
|
|
}
|