gomod2nix/schema/schema.go
adisbladis 509b97c288 Build non-development packages in the same way as development packages
The difference in behaviour was unfortunate.

The only downside I can see is that this doesn't allow for mixed
origins in the same package, which probably shouldn't be done anyway.
2022-06-14 08:19:42 +08:00

79 lines
1.5 KiB
Go

package types
import (
"bytes"
"github.com/BurntSushi/toml"
"os"
)
const SchemaVersion = 3
type Package struct {
GoPackagePath string `toml:"-"`
Version string `toml:"version"`
Hash string `toml:"hash"`
ReplacedPath string `toml:"replaced,omitempty"`
}
type Output struct {
SchemaVersion int `toml:"schema"`
Mod map[string]*Package `toml:"mod"`
// Packages with passed import paths trigger `go install` based on this list
SubPackages []string `toml:"subPackages,omitempty"`
// Packages with passed import paths has a "default package" which pname & version is inherit from
GoPackagePath string `toml:"goPackagePath,omitempty"`
}
func Marshal(pkgs []*Package, goPackagePath string, subPackages []string) ([]byte, error) {
out := &Output{
SchemaVersion: SchemaVersion,
Mod: make(map[string]*Package),
SubPackages: subPackages,
GoPackagePath: goPackagePath,
}
for _, pkg := range pkgs {
out.Mod[pkg.GoPackagePath] = pkg
}
var buf bytes.Buffer
e := toml.NewEncoder(&buf)
err := e.Encode(out)
if err != nil {
return nil, err
}
return buf.Bytes(), nil
}
func ReadCache(filePath string) map[string]*Package {
ret := make(map[string]*Package)
if filePath == "" {
return ret
}
b, err := os.ReadFile(filePath)
if err != nil {
return ret
}
var output Output
_, err = toml.Decode(string(b), &output)
if err != nil {
return ret
}
if output.SchemaVersion != SchemaVersion {
return ret
}
for k, v := range output.Mod {
v.GoPackagePath = k
ret[k] = v
}
return ret
}