mirror of https://github.com/go-redis/redis.git
Merge cefa7c0daf
into e63669e170
This commit is contained in:
commit
37e394e4c7
|
@ -73,6 +73,9 @@ func Struct(dst interface{}) (StructValue, error) {
|
||||||
|
|
||||||
// Scan scans the results from a key-value Redis map result set to a destination struct.
|
// Scan scans the results from a key-value Redis map result set to a destination struct.
|
||||||
// The Redis keys are matched to the struct's field with the `redis` tag.
|
// The Redis keys are matched to the struct's field with the `redis` tag.
|
||||||
|
// This method will attempt to unmarshal each field and will return an error if any of the
|
||||||
|
// fields cannot be unmarshalled. The destination struct will have the failed fields set to
|
||||||
|
// their zero value.
|
||||||
func Scan(dst interface{}, keys []interface{}, vals []interface{}) error {
|
func Scan(dst interface{}, keys []interface{}, vals []interface{}) error {
|
||||||
if len(keys) != len(vals) {
|
if len(keys) != len(vals) {
|
||||||
return errors.New("args should have the same number of keys and vals")
|
return errors.New("args should have the same number of keys and vals")
|
||||||
|
@ -83,6 +86,8 @@ func Scan(dst interface{}, keys []interface{}, vals []interface{}) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scanErrors := []error{}
|
||||||
|
|
||||||
// Iterate through the (key, value) sequence.
|
// Iterate through the (key, value) sequence.
|
||||||
for i := 0; i < len(vals); i++ {
|
for i := 0; i < len(vals); i++ {
|
||||||
key, ok := keys[i].(string)
|
key, ok := keys[i].(string)
|
||||||
|
@ -96,10 +101,14 @@ func Scan(dst interface{}, keys []interface{}, vals []interface{}) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := strct.Scan(key, val); err != nil {
|
if err := strct.Scan(key, val); err != nil {
|
||||||
return err
|
scanErrors = append(scanErrors, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(scanErrors) > 0 {
|
||||||
|
return fmt.Errorf("scan errors: %v", scanErrors)
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -196,6 +196,22 @@ var _ = Describe("Scan", func() {
|
||||||
Expect(Scan(&d, i{"bool"}, i{"123"})).To(HaveOccurred())
|
Expect(Scan(&d, i{"bool"}, i{"123"})).To(HaveOccurred())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("does not stop scanning on first failure", func() {
|
||||||
|
var d data
|
||||||
|
|
||||||
|
keys := i{"bool", "string", "int"}
|
||||||
|
vals := i{"-1", "foobar", "123"}
|
||||||
|
|
||||||
|
err := Scan(&d, keys, vals)
|
||||||
|
Expect(err).To(HaveOccurred())
|
||||||
|
|
||||||
|
Expect(d).To(Equal(data{
|
||||||
|
Bool: false,
|
||||||
|
String: "foobar",
|
||||||
|
Int: 123,
|
||||||
|
}))
|
||||||
|
})
|
||||||
|
|
||||||
It("Implements Scanner", func() {
|
It("Implements Scanner", func() {
|
||||||
var td TimeData
|
var td TimeData
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue