feat: align JS exports to PascalCase, merge xxxToString, and fix acronyms (by AI)

This commit is contained in:
AI Engineer 2026-06-08 21:19:24 +08:00
parent a45d8d20f1
commit 09af304a8c
5 changed files with 221 additions and 318 deletions

View File

@ -12,145 +12,87 @@ import (
"apigo.cc/go/cast" "apigo.cc/go/cast"
) )
// Hex 将数据转换为 Hex 编码的字节切片 // Hex 将数据转换为 Hex 编码的字符串
func Hex(data []byte) []byte { func Hex(data any) string {
dst := make([]byte, hex.EncodedLen(len(data))) b := cast.To[[]byte](data)
hex.Encode(dst, data) return hex.EncodeToString(b)
return dst
} }
// HexToString 将数据转换为 Hex 编码的字符串 // UnHex 将 Hex 编码的数据解码为字节切片
func HexToString(data []byte) string { func UnHex(data any) ([]byte, error) {
return hex.EncodeToString(data) s := cast.String(data)
return hex.DecodeString(s)
} }
// UnHex 将 Hex 编码的字节切片解码 // Base64 将数据转换为 Base64 编码的字符串
func UnHex(data []byte) ([]byte, error) { func Base64(data any) string {
dst := make([]byte, hex.DecodedLen(len(data))) b := cast.To[[]byte](data)
n, err := hex.Decode(dst, data) return base64.StdEncoding.EncodeToString(b)
return dst[:n], err
} }
// UnHexFromString 将 Hex 编码的字符串解码 // UnBase64 将 Base64 编码的数据解码为字节切片(自动兼容有无填充)
func UnHexFromString(data string) ([]byte, error) { func UnBase64(data any) ([]byte, error) {
return hex.DecodeString(data) s := cast.String(data)
if len(s) > 0 && s[len(s)-1] == '=' {
return base64.StdEncoding.DecodeString(s)
}
return base64.RawStdEncoding.DecodeString(s)
} }
// Base64 将数据转换为 Base64 编码的字节切片 // Base64Raw 将数据转换为无填充的 Base64 编码的字符串
func Base64(data []byte) []byte { func Base64Raw(data any) string {
buf := make([]byte, base64.StdEncoding.EncodedLen(len(data))) b := cast.To[[]byte](data)
base64.StdEncoding.Encode(buf, data) return base64.RawStdEncoding.EncodeToString(b)
return buf
} }
// Base64ToString 将数据转换为 Base64 编码的字符串 // URLBase64 将数据转换为 URL 安全的 Base64 编码的字符串
func Base64ToString(data []byte) string { func URLBase64(data any) string {
return base64.StdEncoding.EncodeToString(data) b := cast.To[[]byte](data)
return base64.URLEncoding.EncodeToString(b)
} }
// Base64Raw 将数据转换为无填充的 Base64 编码的字节切片 // UnURLBase64 将 URL 安全的 Base64 编码的数据解码为字节切片(自动兼容有无填充)
func Base64Raw(data []byte) []byte { func UnURLBase64(data any) ([]byte, error) {
buf := make([]byte, base64.RawStdEncoding.EncodedLen(len(data))) s := cast.String(data)
base64.RawStdEncoding.Encode(buf, data) if len(s) > 0 && s[len(s)-1] == '=' {
return buf return base64.URLEncoding.DecodeString(s)
}
return base64.RawURLEncoding.DecodeString(s)
} }
// Base64RawToString 将数据转换为无填充的 Base64 编码的字符串 // URLBase64Raw 将数据转换为 URL 安全且无填充的 Base64 编码的字符串
func Base64RawToString(data []byte) string { func URLBase64Raw(data any) string {
return base64.RawStdEncoding.EncodeToString(data) b := cast.To[[]byte](data)
return base64.RawURLEncoding.EncodeToString(b)
} }
// UrlBase64 将数据转换为 URL 安全的 Base64 编码的字节切片 // URLEncode 对数据进行 URL 编码
func UrlBase64(data []byte) []byte { func URLEncode(data any) string {
buf := make([]byte, base64.URLEncoding.EncodedLen(len(data))) return url.QueryEscape(cast.String(data))
base64.URLEncoding.Encode(buf, data)
return buf
} }
// UrlBase64ToString 将数据转换为 URL 安全的 Base64 编码的字符串 // UnURLEncode 对字符串进行 URL 解码
func UrlBase64ToString(data []byte) string { func UnURLEncode(data any) ([]byte, error) {
return base64.URLEncoding.EncodeToString(data) res, err := url.QueryUnescape(cast.String(data))
}
// UrlBase64Raw 将数据转换为 URL 安全且无填充的 Base64 编码的字节切片
func UrlBase64Raw(data []byte) []byte {
buf := make([]byte, base64.RawURLEncoding.EncodedLen(len(data)))
base64.RawURLEncoding.Encode(buf, data)
return buf
}
// UrlBase64RawToString 将数据转换为 URL 安全且无填充的 Base64 编码的字符串
func UrlBase64RawToString(data []byte) string {
return base64.RawURLEncoding.EncodeToString(data)
}
// UnBase64 将 Base64 编码的字节切片解码(自动兼容有无填充)
func UnBase64(data []byte) ([]byte, error) {
if len(data) > 0 && data[len(data)-1] == '=' {
dbuf := make([]byte, base64.StdEncoding.DecodedLen(len(data)))
n, err := base64.StdEncoding.Decode(dbuf, data)
return dbuf[:n], err
}
dbuf := make([]byte, base64.RawStdEncoding.DecodedLen(len(data)))
n, err := base64.RawStdEncoding.Decode(dbuf, data)
return dbuf[:n], err
}
// UnBase64FromString 将 Base64 编码的字符串解码(自动兼容有无填充)
func UnBase64FromString(data string) ([]byte, error) {
if len(data) > 0 && data[len(data)-1] == '=' {
return base64.StdEncoding.DecodeString(data)
}
return base64.RawStdEncoding.DecodeString(data)
}
// UnUrlBase64 将 URL 安全的 Base64 编码的字节切片解码(自动兼容有无填充)
func UnUrlBase64(data []byte) ([]byte, error) {
if len(data) > 0 && data[len(data)-1] == '=' {
dbuf := make([]byte, base64.URLEncoding.DecodedLen(len(data)))
n, err := base64.URLEncoding.Decode(dbuf, data)
return dbuf[:n], err
}
dbuf := make([]byte, base64.RawURLEncoding.DecodedLen(len(data)))
n, err := base64.RawURLEncoding.Decode(dbuf, data)
return dbuf[:n], err
}
// UnUrlBase64FromString 将 URL 安全的 Base64 编码的字符串解码(自动兼容有无填充)
func UnUrlBase64FromString(data string) ([]byte, error) {
if len(data) > 0 && data[len(data)-1] == '=' {
return base64.URLEncoding.DecodeString(data)
}
return base64.RawURLEncoding.DecodeString(data)
}
// UrlEncode 对数据进行 URL 编码
func UrlEncode(data []byte) string {
return url.QueryEscape(string(data))
}
// UnUrlEncode 对字符串进行 URL 解码
func UnUrlEncode(data string) ([]byte, error) {
res, err := url.QueryUnescape(data)
if err != nil { if err != nil {
return nil, err return nil, err
} }
return []byte(res), nil return []byte(res), nil
} }
// HtmlEscape 对数据进行 HTML 转义 // HTMLEscape 对数据进行 HTML 转义
func HtmlEscape(data []byte) string { func HTMLEscape(data any) string {
return html.EscapeString(string(data)) return html.EscapeString(cast.String(data))
} }
// HtmlUnescape 对 HTML 字符串进行反转义 // HTMLUnescape 对 HTML 字符串进行反转义
func HtmlUnescape(data string) string { func HTMLUnescape(data any) string {
return html.UnescapeString(data) return html.UnescapeString(cast.String(data))
} }
// Utf8Valid 检查字节切片是否为有效的 UTF-8 编码 // UTF8Valid 检查数据是否为有效的 UTF-8 编码
func Utf8Valid(data []byte) bool { func UTF8Valid(data any) bool {
return utf8.Valid(data) return utf8.Valid(cast.To[[]byte](data))
} }
// SortJoin 将 Map 或 Struct 转换为排序并拼接后的字符串 (常用于签名) // SortJoin 将 Map 或 Struct 转换为排序并拼接后的字符串 (常用于签名)

View File

@ -1,135 +1,96 @@
package encoding_test package encoding
import ( import (
"bytes" "bytes"
"testing" "testing"
"apigo.cc/go/cast"
"apigo.cc/go/encoding"
) )
// --- Hex --- func TestEncoding(t *testing.T) {
func TestHex(t *testing.T) {
data := []byte("hello go")
encoded := encoding.HexToString(data)
decoded, err := encoding.UnHex([]byte(encoded))
if err != nil || !bytes.Equal(data, decoded) {
t.Fatal("Hex roundtrip failed")
}
if !bytes.Equal(cast.As(encoding.UnHexFromString(encoded)), data) {
t.Error("UnHexFromString with cast.As failed")
}
if len(cast.As(encoding.UnHexFromString("!@#$"))) != 0 {
t.Error("UnHexFromString should return empty for invalid hex chars with cast.As")
}
}
// --- Base64 ---
func TestBase64(t *testing.T) {
data := []byte("hello world") data := []byte("hello world")
// Standard // Hex
enc := encoding.Base64ToString(data) encoded := Hex(data)
dec, err := encoding.UnBase64([]byte(enc)) decoded, err := UnHex(encoded)
if err != nil || !bytes.Equal(data, dec) { if err != nil || !bytes.Equal(decoded, data) {
t.Error("Base64 roundtrip failed") t.Errorf("Hex failed: got %v, error: %v", decoded, err)
} }
if !bytes.Equal(cast.As(encoding.UnBase64FromString(enc)), data) { // Base64
t.Error("UnBase64FromString with cast.As failed") enc := Base64(data)
dec, err := UnBase64(enc)
if err != nil || !bytes.Equal(dec, data) {
t.Errorf("Base64 failed: got %v, error: %v", dec, err)
} }
// Raw (Unpadded) // Base64Raw
rawEnc := encoding.Base64RawToString(data) rawEnc := Base64Raw(data)
if bytes.HasSuffix([]byte(rawEnc), []byte("=")) { rawDec, err := UnBase64(rawEnc)
t.Error("Base64Raw should not have padding") if err != nil || !bytes.Equal(rawDec, data) {
} t.Errorf("Base64Raw failed: got %v, error: %v", rawDec, err)
rawDec, err := encoding.UnBase64FromString(rawEnc)
if err != nil || !bytes.Equal(data, rawDec) {
t.Error("Base64Raw smart decoding failed")
} }
// URL // URLBase64
uData := []byte("hello/world+") uData := []byte("https://apigo.cc?a=1&b=2")
uEnc := encoding.UrlBase64ToString(uData) uEnc := URLBase64(uData)
uDec, _ := encoding.UnUrlBase64([]byte(uEnc)) uDec, _ := UnURLBase64(uEnc)
if !bytes.Equal(uData, uDec) { if !bytes.Equal(uDec, uData) {
t.Error("UrlBase64 roundtrip failed") t.Errorf("URLBase64 failed: got %v", uDec)
} }
if !bytes.Equal(cast.As(encoding.UnUrlBase64FromString(uEnc)), uData) { // URLBase64Raw
t.Error("UnUrlBase64FromString with cast.As failed") uRawEnc := URLBase64Raw(uData)
uRawDec, err := UnURLBase64(uRawEnc)
if err != nil || !bytes.Equal(uRawDec, uData) {
t.Errorf("URLBase64Raw failed: got %v, error: %v", uRawDec, err)
} }
// URL Raw (Unpadded) // URLEncode
uRawEnc := encoding.UrlBase64RawToString(uData) urlEnc := URLEncode(data)
if bytes.HasSuffix([]byte(uRawEnc), []byte("=")) { urlDec, err := UnURLEncode(urlEnc)
t.Error("UrlBase64Raw should not have padding") if err != nil || !bytes.Equal(urlDec, data) {
t.Errorf("URLEncode failed: got %v, error: %v", urlDec, err)
} }
uRawDec, err := encoding.UnUrlBase64FromString(uRawEnc)
if err != nil || !bytes.Equal(uData, uRawDec) { // HTMLEscape
t.Error("UrlBase64Raw smart decoding failed") htmlData := "<div>hello</div>"
escaped := HTMLEscape(htmlData)
if HTMLUnescape(escaped) != htmlData {
t.Errorf("HTMLEscape failed")
}
// UTF8Valid
if !UTF8Valid("你好") {
t.Error("UTF8Valid failed")
} }
} }
// --- Web ---
func TestWebEncoding(t *testing.T) {
// URL
data := []byte("a b+c")
enc := encoding.UrlEncode(data)
if !bytes.Equal(cast.As(encoding.UnUrlEncode(enc)), data) {
t.Error("UrlEncode roundtrip failed")
}
if len(cast.As(encoding.UnUrlEncode("%ZZ"))) != 0 {
t.Error("UnUrlEncode should return empty for invalid input with cast.As")
}
// HTML
htmlData := []byte("<script>")
escaped := encoding.HtmlEscape(htmlData)
if encoding.HtmlUnescape(escaped) != string(htmlData) {
t.Error("HtmlEscape roundtrip failed")
}
}
// --- Utf8 ---
func TestUtf8(t *testing.T) {
if !encoding.Utf8Valid([]byte("你好")) {
t.Error("Valid UTF-8 should pass")
}
if encoding.Utf8Valid([]byte{0xff, 0xff}) {
t.Error("Invalid UTF-8 should fail")
}
}
// --- SortJoin ---
func TestSortJoin(t *testing.T) { func TestSortJoin(t *testing.T) {
m := map[string]any{ m := map[string]any{
"B": 2, "b": 2,
"A": 1, "a": 1,
"C": "hello world", "c": "3",
}
res := SortJoin(m, "&", "=", true)
if res != "a=1&b=2&c=3" {
t.Errorf("SortJoin map failed: %s", res)
} }
// Test Map
res := encoding.SortJoin(m, "&", "=", true)
expected := "A=1&B=2&C=hello+world"
if res != expected {
t.Errorf("SortJoin Map failed: expected %s, got %s", expected, res)
}
// Test Struct
type User struct { type User struct {
Name string `json:"name"` ID int
Age int `json:"age"` Name string
ID string
} }
u := User{Name: "Alice", Age: 30, ID: "123"} u := User{ID: 1, Name: "sam"}
resStruct := encoding.SortJoin(u, ";", ":", false) resStruct := SortJoin(u, ";", ":", false)
// Keys: age, name, ID. Sorted: ID, age, name if resStruct != "ID:1;name:sam" {
expectedStruct := "ID:123;age:30;name:Alice" t.Errorf("SortJoin struct failed: %s", resStruct)
if resStruct != expectedStruct { }
t.Errorf("SortJoin Struct failed: expected %s, got %s", expectedStruct, resStruct) }
func TestIntEncoder(t *testing.T) {
val := uint64(123456789)
encoded := EncodeInt(val)
decoded := DecodeInt(encoded)
if val != decoded {
t.Errorf("IntEncoder failed: expected %d, got %d", val, decoded)
} }
} }

View File

@ -4,6 +4,8 @@ import (
"crypto/hmac" "crypto/hmac"
"crypto/sha512" "crypto/sha512"
"errors" "errors"
"apigo.cc/go/cast"
) )
// IntEncoder 提供整数与字节切片之间的自定义进制转换 // IntEncoder 提供整数与字节切片之间的自定义进制转换
@ -13,9 +15,9 @@ type IntEncoder struct {
decodeMap [256]int decodeMap [256]int
} }
// EncodeInt 将整数转换为字节切片 // EncodeInt 将整数转换为字符串
func (enc *IntEncoder) EncodeInt(u uint64) []byte { func (enc *IntEncoder) EncodeInt(u uint64) string {
return enc.AppendInt(nil, u) return string(enc.AppendInt(nil, u))
} }
// AppendInt 将整数追加到已有字节切片中 // AppendInt 将整数追加到已有字节切片中
@ -33,8 +35,9 @@ func (enc *IntEncoder) AppendInt(buf []byte, u uint64) []byte {
return buf return buf
} }
// FillInt 使用循环字符序列填充字节切片至指定长度 // FillInt 使用循环字符序列填充数据至指定长度
func (enc *IntEncoder) FillInt(buf []byte, length int) []byte { func (enc *IntEncoder) FillInt(data any, length int) []byte {
buf := cast.To[[]byte](data)
currLen := len(buf) currLen := len(buf)
if currLen >= length { if currLen >= length {
return buf return buf
@ -52,8 +55,9 @@ func (enc *IntEncoder) FillInt(buf []byte, length int) []byte {
return buf return buf
} }
// ExchangeInt 对字节切片进行位置交替重排 // ExchangeInt 对数据进行位置交替重排
func (enc *IntEncoder) ExchangeInt(buf []byte) []byte { func (enc *IntEncoder) ExchangeInt(data any) []byte {
buf := cast.To[[]byte](data)
size := len(buf) size := len(buf)
if size <= 1 { if size <= 1 {
return buf return buf
@ -76,15 +80,16 @@ func (enc *IntEncoder) ExchangeInt(buf []byte) []byte {
return buf2 return buf2
} }
// HashInt 对字节切片进行 HMAC-SHA512 哈希 // HashInt 对数据进行 HMAC-SHA512 哈希
func (enc *IntEncoder) HashInt(data []byte, key []byte) []byte { func (enc *IntEncoder) HashInt(data any, key any) []byte {
hash := hmac.New(sha512.New, key) hash := hmac.New(sha512.New, cast.To[[]byte](key))
hash.Write(data) hash.Write(cast.To[[]byte](data))
return hash.Sum([]byte{}) return hash.Sum([]byte{})
} }
// DecodeInt 从字节切片解码为整数 // DecodeInt 从数据解码为整数
func (enc *IntEncoder) DecodeInt(buf []byte) uint64 { func (enc *IntEncoder) DecodeInt(data any) uint64 {
buf := cast.To[[]byte](data)
radix := uint64(enc.radix) radix := uint64(enc.radix)
if buf == nil { if buf == nil {
return 0 return 0
@ -125,9 +130,9 @@ func NewIntEncoder(digits string, radix uint8) (*IntEncoder, error) {
var DefaultIntEncoder, _ = NewIntEncoder("9ukH1grX75TQS6LzpFAjIivsdZoO0mc8NBwnyYDhtMWEC2V3KaGxfJRPqe4lbU", 62) var DefaultIntEncoder, _ = NewIntEncoder("9ukH1grX75TQS6LzpFAjIivsdZoO0mc8NBwnyYDhtMWEC2V3KaGxfJRPqe4lbU", 62)
var OrderedIntEncoder, _ = NewIntEncoder("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz", 62) var OrderedIntEncoder, _ = NewIntEncoder("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz", 62)
// EncodeInt 使用默认编码器将整数转换为字节切片 // EncodeInt 使用默认编码器将整数转换为字符串
func EncodeInt(u uint64) []byte { func EncodeInt(u uint64) string {
return DefaultIntEncoder.AppendInt(nil, u) return DefaultIntEncoder.EncodeInt(u)
} }
// AppendInt 使用默认编码器将整数追加到已有字节切片中 // AppendInt 使用默认编码器将整数追加到已有字节切片中
@ -135,19 +140,22 @@ func AppendInt(buf []byte, u uint64) []byte {
return DefaultIntEncoder.AppendInt(buf, u) return DefaultIntEncoder.AppendInt(buf, u)
} }
// DecodeInt 使用默认编码器从字节切片解码为整数 // DecodeInt 使用默认编码器从数据解码为整数
func DecodeInt(buf []byte) uint64 { func DecodeInt(data any) uint64 {
return DefaultIntEncoder.DecodeInt(buf) return DefaultIntEncoder.DecodeInt(data)
} }
func ExchangeInt(buf []byte) []byte { // ExchangeInt 使用默认编码器对数据进行位置交替重排
return DefaultIntEncoder.ExchangeInt(buf) func ExchangeInt(data any) []byte {
return DefaultIntEncoder.ExchangeInt(data)
} }
func HashInt(data []byte, key []byte) []byte { // HashInt 对数据进行 HMAC-SHA512 哈希
func HashInt(data any, key any) []byte {
return DefaultIntEncoder.HashInt(data, key) return DefaultIntEncoder.HashInt(data, key)
} }
func FillInt(buf []byte, length int) []byte { // FillInt 使用默认编码器填充数据至指定长度
return DefaultIntEncoder.FillInt(buf, length) func FillInt(data any, length int) []byte {
return DefaultIntEncoder.FillInt(data, length)
} }

View File

@ -1,58 +1,58 @@
package encoding_test package encoding
import ( import (
"bytes" "bytes"
"testing" "testing"
"apigo.cc/go/encoding"
) )
// --- 正常逻辑测试 --- func TestIntEncoderInstance(t *testing.T) {
func TestIntEncoderNormal(t *testing.T) { enc := DefaultIntEncoder
enc := encoding.DefaultIntEncoder val := uint64(123456789)
nums := []uint64{0, 1, 100, 123456789, 18446744073709551615} encoded := enc.EncodeInt(val)
for _, n := range nums { decoded := enc.DecodeInt(encoded)
if enc.DecodeInt(enc.EncodeInt(n)) != n { if val != decoded {
t.Errorf("Roundtrip failed for %d", n) t.Errorf("IntEncoder instance failed: expected %d, got %d", val, decoded)
}
}
} }
// --- 边界与异常测试 --- // NewIntEncoder errors
func TestIntEncoderEdge(t *testing.T) { _, err := NewIntEncoder("12", 5) // 字符集不足
// 初始化异常 if err == nil {
_, err := encoding.NewIntEncoder("12", 5) // 字符集不足 t.Error("expected error for insufficient digits")
if err == nil { t.Error("NewIntEncoder failed to detect short digits") }
_, err = encoding.NewIntEncoder("112345", 2) // 重复字符
if err == nil { t.Error("NewIntEncoder failed to detect repeated digits") }
// 空输入
if encoding.DecodeInt(nil) != 0 { t.Error("DecodeInt(nil) != 0") }
// 填充逻辑边界
buf := encoding.EncodeInt(123)
filled := encoding.DefaultIntEncoder.FillInt(buf, 2) // 长度小于原长
if len(filled) != len(buf) {
t.Error("FillInt should not truncate data")
}
} }
// --- 混淆与哈希测试 --- _, err = NewIntEncoder("112345", 6) // 重复字符
func TestIntEncoderAdvanced(t *testing.T) { if err == nil {
enc := encoding.DefaultIntEncoder t.Error("expected error for repeated digits")
buf := enc.EncodeInt(12345) }
// Exchange // DecodeInt(nil)
exchanged := enc.ExchangeInt(buf) if DecodeInt(nil) != 0 {
t.Error("DecodeInt(nil) != 0")
}
// FillInt
buf := []byte(EncodeInt(123))
filled := FillInt(buf, 10)
if len(filled) != 10 {
t.Errorf("FillInt failed: expected len 10, got %d", len(filled))
}
if !bytes.HasPrefix(filled, buf) {
t.Error("FillInt prefix mismatch")
}
// ExchangeInt
buf = []byte("abcde")
exchanged := ExchangeInt(buf)
if len(exchanged) != len(buf) { if len(exchanged) != len(buf) {
t.Fatal("Exchange length mismatch") t.Error("ExchangeInt len mismatch")
}
if bytes.Equal(exchanged, buf) {
t.Error("ExchangeInt should change data")
} }
// Hash // HashInt
h1 := enc.HashInt(buf, []byte("key")) hashed := HashInt(buf, []byte("key"))
h2 := enc.HashInt(buf, []byte("key")) if len(hashed) == 0 {
if !bytes.Equal(h1, h2) { t.Error("HashInt failed")
t.Error("HashInt non-deterministic")
} }
} }

View File

@ -4,32 +4,24 @@ import "apigo.cc/go/jsmod"
func init() { func init() {
jsmod.Register("encoding", map[string]any{ jsmod.Register("encoding", map[string]any{
"base64": Base64, "Base64": Base64,
"base64ToString": Base64ToString, "Base64Raw": Base64Raw,
"base64Raw": Base64Raw, "UnBase64": UnBase64,
"base64RawToString": Base64RawToString, "URLBase64": URLBase64,
"unBase64": UnBase64, "URLBase64Raw": URLBase64Raw,
"unBase64FromString": UnBase64FromString, "UnURLBase64": UnURLBase64,
"urlBase64": UrlBase64, "Hex": Hex,
"urlBase64ToString": UrlBase64ToString, "UnHex": UnHex,
"urlBase64Raw": UrlBase64Raw, "URLEncode": URLEncode,
"urlBase64RawToString": UrlBase64RawToString, "UnURLEncode": UnURLEncode,
"unUrlBase64": UnUrlBase64, "HTMLEscape": HTMLEscape,
"unUrlBase64FromString": UnUrlBase64FromString, "HTMLUnescape": HTMLUnescape,
"hex": Hex, "UTF8Valid": UTF8Valid,
"hexToString": HexToString, "SortJoin": SortJoin,
"unHex": UnHex, "EncodeInt": EncodeInt,
"unHexFromString": UnHexFromString, "DecodeInt": DecodeInt,
"urlEncode": UrlEncode, "FillInt": FillInt,
"unUrlEncode": UnUrlEncode, "ExchangeInt": ExchangeInt,
"htmlEscape": HtmlEscape, "HashInt": HashInt,
"htmlUnescape": HtmlUnescape,
"utf8Valid": Utf8Valid,
"sortJoin": SortJoin,
"encodeInt": EncodeInt,
"decodeInt": DecodeInt,
"fillInt": FillInt,
"exchangeInt": ExchangeInt,
"hashInt": HashInt,
}) })
} }