Some checks failed
Build and Release / Create Release (push) Successful in 0s
Trigger Vault Plugin Rebuild / Trigger Vault Rebuild (push) Successful in 0s
Build and Release / Integration Tests (PostgreSQL) (push) Successful in 2m48s
Build and Release / Lint (push) Failing after 5m2s
Build and Release / Build Binaries (amd64, windows, windows-latest) (push) Has been skipped
Build and Release / Build Binaries (amd64, darwin, linux-latest) (push) Has been skipped
Build and Release / Build Binaries (amd64, linux, linux-latest) (push) Has been skipped
Build and Release / Build Binaries (arm64, darwin, linux-latest) (push) Has been skipped
Build and Release / Build Binaries (arm64, linux, linux-latest) (push) Has been skipped
Build and Release / Unit Tests (push) Successful in 5m37s
Go's semantic import versioning requires v2+ modules to include the major version in the module path. This enables using proper version tags (v3.x.x) instead of pseudo-versions. Updated module path: code.gitcaddy.com/server/v3
60 lines
1.4 KiB
Go
60 lines
1.4 KiB
Go
// This file is generated by modules/charset/ambiguous/generate.go DO NOT EDIT
|
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package charset
|
|
|
|
import (
|
|
"sort"
|
|
"strings"
|
|
"unicode"
|
|
|
|
"code.gitcaddy.com/server/v3/modules/translation"
|
|
)
|
|
|
|
// AmbiguousTablesForLocale provides the table of ambiguous characters for this locale.
|
|
func AmbiguousTablesForLocale(locale translation.Locale) []*AmbiguousTable {
|
|
key := locale.Language()
|
|
var table *AmbiguousTable
|
|
var ok bool
|
|
for len(key) > 0 {
|
|
if table, ok = AmbiguousCharacters[key]; ok {
|
|
break
|
|
}
|
|
idx := strings.LastIndexAny(key, "-_")
|
|
if idx < 0 {
|
|
key = ""
|
|
} else {
|
|
key = key[:idx]
|
|
}
|
|
}
|
|
if table == nil && (locale.Language() == "zh-CN" || locale.Language() == "zh_CN") {
|
|
table = AmbiguousCharacters["zh-hans"]
|
|
}
|
|
if table == nil && strings.HasPrefix(locale.Language(), "zh") {
|
|
table = AmbiguousCharacters["zh-hant"]
|
|
}
|
|
if table == nil {
|
|
table = AmbiguousCharacters["_default"]
|
|
}
|
|
|
|
return []*AmbiguousTable{
|
|
table,
|
|
AmbiguousCharacters["_common"],
|
|
}
|
|
}
|
|
|
|
func isAmbiguous(r rune, confusableTo *rune, tables ...*AmbiguousTable) bool {
|
|
for _, table := range tables {
|
|
if !unicode.Is(table.RangeTable, r) {
|
|
continue
|
|
}
|
|
i := sort.Search(len(table.Confusable), func(i int) bool {
|
|
return table.Confusable[i] >= r
|
|
})
|
|
(*confusableTo) = table.With[i]
|
|
return true
|
|
}
|
|
return false
|
|
}
|