mirror of
https://github.com/stashapp/stash.git
synced 2025-12-18 12:54:38 +03:00
* Upgrade gqlgen to v0.17.2 This enables builds on Go 1.18. github.com/vektah/gqlparser is upgraded to the newest version too. Getting this to work is a bit of a hazzle. I had to first remove vendoring from the repository, perform the upgrade and then re-introduce the vendor directory. I think gqlgens analysis went wrong for some reason on the upgrade. It would seem a clean-room installation fixed it. * Bump project to 1.18 * Update all packages, address gqlgenc breaking changes * Let `go mod tidy` handle the go.mod file * Upgrade linter to 1.45.2 * Introduce v1.45.2 of the linter The linter now correctly warns on `strings.Title` because it isn't unicode-aware. Fix this by using the suggested fix from x/text/cases to produce unicode-aware strings. The mapping isn't entirely 1-1 as this new approach has a larger iface: it spans all of unicode rather than just ASCII. It coincides for ASCII however, so things should be largely the same. * Ready ourselves for errchkjson and contextcheck. * Revert dockerfile golang version changes for now Co-authored-by: Kermie <kermie@isinthe.house> Co-authored-by: WithoutPants <53250216+WithoutPants@users.noreply.github.com>
87 lines
1.7 KiB
Go
87 lines
1.7 KiB
Go
// Copyright 2018 Frank Schroeder. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package properties
|
|
|
|
import (
|
|
"fmt"
|
|
"runtime"
|
|
)
|
|
|
|
type parser struct {
|
|
lex *lexer
|
|
}
|
|
|
|
func parse(input string) (properties *Properties, err error) {
|
|
p := &parser{lex: lex(input)}
|
|
defer p.recover(&err)
|
|
|
|
properties = NewProperties()
|
|
key := ""
|
|
comments := []string{}
|
|
|
|
for {
|
|
token := p.expectOneOf(itemComment, itemKey, itemEOF)
|
|
switch token.typ {
|
|
case itemEOF:
|
|
goto done
|
|
case itemComment:
|
|
comments = append(comments, token.val)
|
|
continue
|
|
case itemKey:
|
|
key = token.val
|
|
if _, ok := properties.m[key]; !ok {
|
|
properties.k = append(properties.k, key)
|
|
}
|
|
}
|
|
|
|
token = p.expectOneOf(itemValue, itemEOF)
|
|
if len(comments) > 0 {
|
|
properties.c[key] = comments
|
|
comments = []string{}
|
|
}
|
|
switch token.typ {
|
|
case itemEOF:
|
|
properties.m[key] = ""
|
|
goto done
|
|
case itemValue:
|
|
properties.m[key] = token.val
|
|
}
|
|
}
|
|
|
|
done:
|
|
return properties, nil
|
|
}
|
|
|
|
func (p *parser) errorf(format string, args ...interface{}) {
|
|
format = fmt.Sprintf("properties: Line %d: %s", p.lex.lineNumber(), format)
|
|
panic(fmt.Errorf(format, args...))
|
|
}
|
|
|
|
func (p *parser) expectOneOf(expected ...itemType) (token item) {
|
|
token = p.lex.nextItem()
|
|
for _, v := range expected {
|
|
if token.typ == v {
|
|
return token
|
|
}
|
|
}
|
|
p.unexpected(token)
|
|
panic("unexpected token")
|
|
}
|
|
|
|
func (p *parser) unexpected(token item) {
|
|
p.errorf(token.String())
|
|
}
|
|
|
|
// recover is the handler that turns panics into returns from the top level of Parse.
|
|
func (p *parser) recover(errp *error) {
|
|
e := recover()
|
|
if e != nil {
|
|
if _, ok := e.(runtime.Error); ok {
|
|
panic(e)
|
|
}
|
|
*errp = e.(error)
|
|
}
|
|
}
|