mirror of
https://github.com/opbnq-q/nto-cli.git
synced 2025-12-06 16:20:34 +07:00
feat: tag parsing
This commit is contained in:
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
main
|
||||||
|
main.exe
|
||||||
@@ -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
31
entities/metadata.go
Normal 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,
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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]"`
|
||||||
}
|
}
|
||||||
2
main.go
2
main.go
@@ -18,5 +18,5 @@ func main() {
|
|||||||
|
|
||||||
structFields := utils.GetStructFields(file, structName)
|
structFields := utils.GetStructFields(file, structName)
|
||||||
|
|
||||||
fmt.Println(structFields)
|
fmt.Printf("%+v\n", structFields)
|
||||||
}
|
}
|
||||||
@@ -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++ {
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
Reference in New Issue
Block a user