feat: tag parsing

This commit is contained in:
2025-02-13 19:21:14 +07:00
parent 5380bd109a
commit a1df30a318
7 changed files with 51 additions and 17 deletions

2
.gitignore vendored Normal file
View File

@@ -0,0 +1,2 @@
main
main.exe

View File

@@ -1,4 +1,4 @@
package types package entities
type Field struct { type Field struct {
Name string Name string
@@ -6,7 +6,3 @@ type Field struct {
Medatada []Medatada Medatada []Medatada
} }
type Medatada struct {
Name string
Values []string
}

31
entities/metadata.go Normal file
View File

@@ -0,0 +1,31 @@
package entities
import "strings"
type Medatada struct {
Name string
Values []string
}
func NewMetadata(tag string) *Medatada {
tag = strings.TrimSpace(tag)
tagName := ""
var values []string
if strings.Contains(tag, "=") {
tagName = tag[:strings.Index(tag, "=")]
if tag[strings.Index(tag, "=") + 1] == '[' {
values = append(values, strings.Split(tag[strings.Index(tag, "=") + 2:len(tag)-1], ";")...)
for i := range values {
values[i] = strings.TrimSpace(values[i])
}
} else {
values = append(values, strings.TrimSpace(tag[strings.Index(tag, "=") + 1:]))
}
} else {
tagName = tag
}
return &Medatada{
Name: strings.TrimSpace(strings.ToLower(tagName)),
Values: values,
}
}

View File

@@ -1,5 +1,5 @@
package structs package structs
type Post struct { type Post struct {
title string `ui:",hidden,asd"` title string `ui:"hidden,asd,ass=[s;s]"`
} }

View File

@@ -18,5 +18,5 @@ func main() {
structFields := utils.GetStructFields(file, structName) structFields := utils.GetStructFields(file, structName)
fmt.Println(structFields) fmt.Printf("%+v\n", structFields)
} }

View File

@@ -2,17 +2,17 @@ package utils
import ( import (
"bufio" "bufio"
"nto_cli/types" "nto_cli/entities"
"os" "os"
"strings" "strings"
) )
func GetStructFields(file *os.File, structName string) []types.Field { func GetStructFields(file *os.File, structName string) []entities.Field {
bracketsCount := 1 bracketsCount := 1
structFound := false structFound := false
structFields := []types.Field{} structFields := []entities.Field{}
scanner := bufio.NewScanner(file) scanner := bufio.NewScanner(file)
for i := 1; scanner.Scan() && bracketsCount > 0; i++ { for i := 1; scanner.Scan() && bracketsCount > 0; i++ {

View File

@@ -1,21 +1,20 @@
package utils package utils
import ( import (
"fmt" "nto_cli/entities"
"nto_cli/types"
"strings" "strings"
"github.com/fatih/structtag" "github.com/fatih/structtag"
) )
func SplitStructField(field string) *types.Field { func SplitStructField(field string) *entities.Field {
if strings.Contains(field, "type") { if strings.Contains(field, "type") {
return nil return nil
} }
startBacktip := strings.Index(field, "`") startBacktip := strings.Index(field, "`")
endBacktip := -1 endBacktip := -1
var metadata []types.Medatada var metadata []entities.Medatada
if startBacktip > -1 { if startBacktip > -1 {
endBacktip = strings.Index(field[startBacktip + 1:], "`") endBacktip = strings.Index(field[startBacktip + 1:], "`")
if endBacktip > -1 { if endBacktip > -1 {
@@ -25,11 +24,17 @@ func SplitStructField(field string) *types.Field {
if err != nil { if err != nil {
panic(err) panic(err)
} }
uiTags, err := tags.Get("ui") uiTag, err := tags.Get("ui")
if err != nil { if err != nil {
panic(err) panic(err)
} }
fmt.Printf("%+v\n", uiTags.Options) uiTags := append([]string{uiTag.Name}, uiTag.Options...)
for _, t := range uiTags {
analyzed := entities.NewMetadata(t)
if analyzed != nil {
metadata = append(metadata, *analyzed)
}
}
} }
} else { } else {
startBacktip = len(field) startBacktip = len(field)
@@ -48,7 +53,7 @@ func SplitStructField(field string) *types.Field {
dataType := strings.TrimSpace(data[1]) dataType := strings.TrimSpace(data[1])
return &types.Field{ return &entities.Field{
Medatada: metadata, Medatada: metadata,
Type: dataType, Type: dataType,
Name: name, Name: name,