Skip to content

Commit

Permalink
chore: schema bump 7.0.0 license refactor
Browse files Browse the repository at this point in the history
Signed-off-by: Christopher Phillips <christopher.phillips@anchore.com>
Signed-off-by: Avi Deitcher <avi@deitcher.net>
  • Loading branch information
spiffcs authored and deitch committed Feb 13, 2023
1 parent eeb00db commit 0407f38
Show file tree
Hide file tree
Showing 37 changed files with 1,811 additions and 212 deletions.
2 changes: 1 addition & 1 deletion internal/constants.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,5 @@ const (

// JSONSchemaVersion is the current schema version output by the JSON encoder
// This is roughly following the "SchemaVer" guidelines for versioning the JSON schema. Please see schema/json/README.md for details on how to increment.
JSONSchemaVersion = "6.2.0"
JSONSchemaVersion = "7.0.0"
)
28 changes: 27 additions & 1 deletion internal/logicalstrings.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package internal
import (
"fmt"
"strings"

"github.com/invopop/jsonschema"
)

type Joiner string
Expand Down Expand Up @@ -47,6 +49,20 @@ func (l LogicalStrings) String() string {
return strings.Join(parts, fmt.Sprintf(" %s ", joiner))
}

func (l LogicalStrings) MarshalJSON() ([]byte, error) {
return []byte(fmt.Sprintf(`"%s"`, l.String())), nil
}

func (l *LogicalStrings) UnmarshalJSON(data []byte) error {
raw := strings.Trim(string(data), `"`)
ls, err := ParseLogicalStrings(raw)
if err != nil {
return err
}
*l = ls
return nil
}

// Process processes each simple element inside the LogicalStrings through a provided function,
// returning a new LogicalStrings with the fields replaced.
func (l LogicalStrings) Process(f func(string) string) LogicalStrings {
Expand All @@ -70,6 +86,14 @@ func (l LogicalStrings) Elements() []string {
return elements
}

func (l LogicalStrings) JSONSchema() *jsonschema.Schema {
return &jsonschema.Schema{
Type: "string",
Title: "Logical Strings",
Description: "strings with simple or complex logical combinations",
}
}

// ParseLogicalStrings parse strings joined by AND or OR, as well as compounded by ( and ), into a LogicalStrings struct
func ParseLogicalStrings(s string) (LogicalStrings, error) {
var (
Expand Down Expand Up @@ -105,7 +129,9 @@ func ParseLogicalStrings(s string) (LogicalStrings, error) {
}
if currentExpression != "" {
simple, joiner := parseSimpleExpression(currentExpression)
currentLS.Simple = append(currentLS.Simple, simple...)
if len(simple) > 0 {
currentLS.Simple = append(currentLS.Simple, simple...)
}
currentLS.Joiner = joiner
}
return currentLS, nil
Expand Down
Loading

0 comments on commit 0407f38

Please # to comment.