2015-03-24 08:04:45 +01:00
|
|
|
package sha256
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/gob"
|
2015-05-22 03:44:08 +02:00
|
|
|
|
|
|
|
// import to ensure that our init function runs after the standard package
|
|
|
|
_ "crypto/sha256"
|
2015-03-24 08:04:45 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Len returns the number of bytes which have been written to the digest.
|
2015-05-21 08:44:08 +02:00
|
|
|
func (d *digest) Len() int64 {
|
|
|
|
return int64(d.len)
|
2015-03-24 08:04:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// State returns a snapshot of the state of the digest.
|
|
|
|
func (d *digest) State() ([]byte, error) {
|
|
|
|
var buf bytes.Buffer
|
|
|
|
encoder := gob.NewEncoder(&buf)
|
|
|
|
|
|
|
|
// We encode this way so that we do not have
|
|
|
|
// to export these fields of the digest struct.
|
|
|
|
vals := []interface{}{
|
|
|
|
d.h, d.x, d.nx, d.len, d.is224,
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, val := range vals {
|
|
|
|
if err := encoder.Encode(val); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return buf.Bytes(), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Restore resets the digest to the given state.
|
|
|
|
func (d *digest) Restore(state []byte) error {
|
|
|
|
decoder := gob.NewDecoder(bytes.NewReader(state))
|
|
|
|
|
|
|
|
// We decode this way so that we do not have
|
|
|
|
// to export these fields of the digest struct.
|
|
|
|
vals := []interface{}{
|
|
|
|
&d.h, &d.x, &d.nx, &d.len, &d.is224,
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, val := range vals {
|
|
|
|
if err := decoder.Decode(val); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|