data:image/s3,"s3://crabby-images/85719/85719c083d8bcd1915fc77fbff43053211155d59" alt="GoReportCard"
Tags is a simple string parser used for extracting keyword/arguments pairs from structure tags.
Why
I was recreating this feature for a few libraries i'm maintaining and developing (such as validation, binding and a ORM).
So i felt the need to create a common library to take care of this job and keeps me stopping repeating my self ;).
Examples
Tags can parse a few formats
Single keyword tag
tags.Parse(`required`)
// outputs map
// []Param{ Param{ Name: "required", Args:nil }
Multiple keywords
You can delimit keywords with a comma ,
or a semicolon ;
tags.Parse(`required;email`)
tags.Parse(`required,email`)
// outputs map
// []Param{
// Param{ Name: "required", Args:nil },
// Param{ Name: "email", Args:nil },
// }
Keywords with params
You can delimit keywords with a comma ,
or a semicolon ;
tags.Parse(`between(10,20);in("foo", "bar", "foo bar")`)
// outputs map
// []Param{
// Param{ Name: "between", Args:[]string{"10", "20"} },
// Param{ Name: "in", Args:[]string{"foo", "bar", "foo bar"} },
// }
Ignored keywords
You can delimit keywords with a comma ,
or a semicolon ;
tags.Parse(`-`)
// gives nil pointer back
Error handling
When a malformed tag is provided the parse function will return a error with the reason why.
This could be a unexpected end of string (EOF) or badly closed statements.