Fix struct tagging by just using string keys

This commit is contained in:
comp500 2019-05-11 14:40:59 +01:00
parent ef98591d02
commit f23f99b5be
No known key found for this signature in database
GPG Key ID: 214C822FFEC586B5
3 changed files with 28 additions and 15 deletions

View File

@ -5,7 +5,7 @@ var UpdateParsers = make(map[string]UpdateParser)
// UpdateParser takes an unparsed interface{} (as a map[string]interface{}), and returns an Updater for a mod file.
// This can be done using the mapstructure library or your own parsing methods.
type UpdateParser interface {
ParseUpdate(interface{}) (Updater, error)
ParseUpdate(map[string]interface{}) (Updater, error)
}
// Updater checks for and does updates on a mod

View File

@ -14,7 +14,9 @@ type Mod struct {
Side string `toml:"side,omitempty"`
Optional bool `toml:"optional,omitempty"`
Download ModDownload `toml:"download"`
Update map[string]interface{} `toml:"update"`
// Update is a map of map of stuff, so you can store arbitrary values on string keys to define updating
Update map[string]map[string]interface{} `toml:"update"`
updaters map[string]Updater
}
// ModDownload specifies how to download the mod file
@ -37,6 +39,7 @@ func LoadMod(modFile string) (Mod, error) {
if _, err := toml.DecodeFile(modFile, &mod); err != nil {
return Mod{}, err
}
mod.updaters = make(map[string]Updater)
// Horrible reflection library to convert to Updaters
for k, v := range mod.Update {
updateParser, ok := UpdateParsers[k]
@ -45,7 +48,7 @@ func LoadMod(modFile string) (Mod, error) {
if err != nil {
return mod, err
}
mod.Update[k] = updater
mod.updaters[k] = updater
} else {
return mod, errors.New("Update plugin " + k + " not found!")
}

View File

@ -1,4 +1,5 @@
package curseforge
import (
"errors"
"fmt"
@ -147,13 +148,16 @@ func cmdInstall(flags core.Flags, mod string, modArgsTail []string) error {
fileInfo, err := getFileInfo(modID, fileID)
updateMap := make(map[string]interface{})
updateMap := make(map[string]map[string]interface{})
updateMap["curseforge"] = cfUpdater{
updateMap["curseforge"], err = cfUpdater{
ProjectID: modID,
FileID: fileID,
// TODO: determine update channel
ReleaseChannel: "release",
}.ToMap()
if err != nil {
return err
}
modMeta := core.Mod{
@ -176,19 +180,25 @@ func cmdInstall(flags core.Flags, mod string, modArgsTail []string) error {
type cfUpdateParser struct{}
func (u cfUpdateParser) ParseUpdate(updateUnparsed interface{}) (core.Updater, error) {
func (u cfUpdateParser) ParseUpdate(updateUnparsed map[string]interface{}) (core.Updater, error) {
var updater cfUpdater
err := mapstructure.Decode(updateUnparsed, &updater)
return updater, err
}
type cfUpdater struct {
ProjectID int `mapstructure:"project-id" toml:"project-id"`
FileID int `mapstructure:"file-id" toml:"file-id"`
ReleaseChannel string `mapstructure:"release-channel" toml:"release-channel"`
ProjectID int `mapstructure:"project-id"`
FileID int `mapstructure:"file-id"`
ReleaseChannel string `mapstructure:"release-channel"`
}
func (u cfUpdater) DoUpdate(mod core.Mod) (bool, error) {
return false, nil
}
func (u cfUpdater) ToMap() (map[string]interface{}, error) {
newMap := make(map[string]interface{})
err := mapstructure.Decode(u, &newMap)
return newMap, err
}