Skip to content

Commit

Permalink
Use Go 1.13 error wrapping (#72)
Browse files Browse the repository at this point in the history
  • Loading branch information
cloudlena authored Oct 16, 2023
1 parent add1a1f commit 040b0c3
Show file tree
Hide file tree
Showing 5 changed files with 25 additions and 23 deletions.
2 changes: 1 addition & 1 deletion cmd/fitgen/internal/profile/generator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,7 @@ func readGoldenProfile(path string) (*profile.Profile, error) {
}

if !strings.HasPrefix(scanner.Text(), headings[i]) {
return nil, fmt.Errorf("first line should be '%s'", headings[i])
return nil, fmt.Errorf("first line should be %q", headings[i])
}

for scanner.Scan() {
Expand Down
3 changes: 2 additions & 1 deletion cmd/fitgen/internal/profile/transform.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package profile

import (
"errors"
"fmt"
"log"
"strconv"
Expand Down Expand Up @@ -331,7 +332,7 @@ func (f *Field) parseComponents(logger *log.Logger) error {

components := strings.Split(f.data[mCOMPS], ",")
if len(components) == 0 {
return fmt.Errorf("parseComponents: zero components after string split")
return errors.New("parseComponents: zero components after string split")
}

bitsFull := f.data[mBITS]
Expand Down
38 changes: 19 additions & 19 deletions reader.go
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ func DecodeChained(r io.Reader, opts ...DecodeOption) ([]*File, error) {
if d.file != nil {
fitFiles = append(fitFiles, d.file)
}
return fitFiles, fmt.Errorf("error parsing chained fit: file #%d: %v", i+1, err)
return fitFiles, fmt.Errorf("error parsing chained fit: file #%d: %w", i+1, err)
}
fitFiles = append(fitFiles, d.file)
i++
Expand All @@ -123,7 +123,7 @@ func (d *decoder) decode(r io.Reader, headerOnly, fileIDOnly, crcOnly bool) erro

err := d.decodeHeader()
if err != nil {
return fmt.Errorf("error decoding header: %v", err)
return fmt.Errorf("error decoding header: %w", err)
}

d.file = new(File)
Expand All @@ -141,7 +141,7 @@ func (d *decoder) decode(r io.Reader, headerOnly, fileIDOnly, crcOnly bool) erro
if crcOnly {
_, err = io.CopyN(d.crc, d.r, int64(d.h.DataSize))
if err != nil {
return fmt.Errorf("error parsing data: %v", err)
return fmt.Errorf("error parsing data: %w", err)
}
return d.checkCRC()
}
Expand All @@ -157,7 +157,7 @@ func (d *decoder) decode(r io.Reader, headerOnly, fileIDOnly, crcOnly bool) erro

err = d.parseFileIdMsg()
if err != nil {
return fmt.Errorf("error parsing file id message: %v", err)
return fmt.Errorf("error parsing file id message: %w", err)
}
if fileIDOnly {
return nil
Expand Down Expand Up @@ -193,28 +193,28 @@ func (d *decoder) decodeFileData() error {

b, err = d.readByte()
if err != nil {
return fmt.Errorf("error parsing record header: %v", err)
return fmt.Errorf("error parsing record header: %w", err)
}

switch {
case (b & compressedHeaderMask) == compressedHeaderMask:
msg, err = d.parseDataMessage(b, true)
if err != nil {
return fmt.Errorf("parsing compressed timestamp message: %v", err)
return fmt.Errorf("parsing compressed timestamp message: %w", err)
}
if msg.IsValid() {
d.file.add(msg)
}
case (b & mesgDefinitionMask) == mesgDefinitionMask:
dm, err = d.parseDefinitionMessage(b)
if err != nil {
return fmt.Errorf("parsing definition message: %v", err)
return fmt.Errorf("parsing definition message: %w", err)
}
d.defmsgs[dm.localMsgType] = dm
case (b & mesgDefinitionMask) == mesgHeaderMask:
msg, err = d.parseDataMessage(b, false)
if err != nil {
return fmt.Errorf("parsing data message: %v", err)
return fmt.Errorf("parsing data message: %w", err)
}
if msg.IsValid() {
d.file.add(msg)
Expand All @@ -233,7 +233,7 @@ func (d *decoder) checkCRC() error {
}
if _, err := io.ReadFull(d.r, d.tmp[:bytesForCRC]); err != nil {
err = noEOF(err)
return fmt.Errorf("error parsing file CRC: %v", err)
return fmt.Errorf("error parsing file CRC: %w", err)
}
d.crc.Write(d.tmp[:bytesForCRC])
d.file.CRC = le.Uint16(d.tmp[:bytesForCRC])
Expand Down Expand Up @@ -353,7 +353,7 @@ func (ddfd devDataFieldDesc) String() string {
func (d *decoder) parseFileIdMsg() error {
b, err := d.readByte()
if err != nil {
return fmt.Errorf("error parsing record header: %v", err)
return fmt.Errorf("error parsing record header: %w", err)
}

if !((b & mesgDefinitionMask) == mesgDefinitionMask) {
Expand All @@ -362,7 +362,7 @@ func (d *decoder) parseFileIdMsg() error {

dm, err := d.parseDefinitionMessage(b)
if err != nil {
return fmt.Errorf("error parsing definition message: %v", err)
return fmt.Errorf("error parsing definition message: %w", err)
}
if dm.globalMsgNum != MesgNumFileId {
return fmt.Errorf("parsed definition message was not for file_id (was %v)", dm.globalMsgNum)
Expand All @@ -371,15 +371,15 @@ func (d *decoder) parseFileIdMsg() error {

b, err = d.readByte()
if err != nil {
return fmt.Errorf("error parsing record header: %v", err)
return fmt.Errorf("error parsing record header: %w", err)
}

if !((b & mesgHeaderMask) == mesgHeaderMask) {
return fmt.Errorf("expected record header byte for data message, got %#x - %8b", b, b)
}
msg, err := d.parseDataMessage(b, false)
if err != nil {
return fmt.Errorf("error reading data message: %v", err)
return fmt.Errorf("error reading data message: %w", err)
}

_, ok := msg.Interface().(FileIdMsg)
Expand Down Expand Up @@ -426,7 +426,7 @@ func (d *decoder) parseDefinitionMessage(recordHeader byte) (*defmsg, error) {
}

if err = d.readFull(d.tmp[:2]); err != nil {
return nil, fmt.Errorf("error parsing global message number: %v", err)
return nil, fmt.Errorf("error parsing global message number: %w", err)
}
dm.globalMsgNum = MesgNum(dm.arch.Uint16(d.tmp[:2]))
if dm.globalMsgNum == MesgNumInvalid {
Expand All @@ -446,7 +446,7 @@ func (d *decoder) parseDefinitionMessage(recordHeader byte) (*defmsg, error) {
}

if err = d.readFull(d.tmp[0 : 3*uint16(dm.fields)]); err != nil {
return nil, fmt.Errorf("error parsing fields: %v", err)
return nil, fmt.Errorf("error parsing fields: %w", err)
}

dm.fieldDefs = make([]fieldDef, dm.fields)
Expand All @@ -458,7 +458,7 @@ func (d *decoder) parseDefinitionMessage(recordHeader byte) (*defmsg, error) {
if d.debug {
d.opts.logger.Println("illegal definition message:", dm)
}
return nil, fmt.Errorf("validating %v failed: %v", dm.globalMsgNum, err)
return nil, fmt.Errorf("validating %v failed: %w", dm.globalMsgNum, err)
}
dm.fieldDefs[i] = fd
}
Expand Down Expand Up @@ -650,7 +650,7 @@ func (d *decoder) parseDataFields(dm *defmsg, knownMsg bool, msgv reflect.Value)
err := d.readFull(d.tmp[0:dsize])
if err != nil {
return reflect.Value{}, fmt.Errorf(
"error parsing data message: %v (field %d [%v] for [%v])",
"error parsing data message: %w (field %d [%v] for [%v])",
err, i, dfield, dm)
}

Expand Down Expand Up @@ -682,7 +682,7 @@ func (d *decoder) parseDataFields(dm *defmsg, knownMsg bool, msgv reflect.Value)
if err == nil {
continue
}
return reflect.Value{}, fmt.Errorf("error parsing data message: %v", err)
return reflect.Value{}, fmt.Errorf("error parsing data message: %w", err)
case types.TimeUTC, types.TimeLocal:
d.parseTimeStamp(dm, fieldv, pfield)
case types.Lat:
Expand All @@ -701,7 +701,7 @@ func (d *decoder) parseDataFields(dm *defmsg, knownMsg bool, msgv reflect.Value)
for i, ddfd := range dm.devDataFieldDescs {
err := d.readFull(d.tmp[0:int(ddfd.size)])
if err != nil {
return reflect.Value{}, fmt.Errorf("error parsing data developer message: %v (field %d [%v] for [%v])", err, i, ddfd, dm)
return reflect.Value{}, fmt.Errorf("error parsing data developer message: %w (field %d [%v] for [%v])", err, i, ddfd, dm)
}
}

Expand Down
2 changes: 1 addition & 1 deletion reader_util_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ var decodeTestFiles = [...]struct {
preFormat := g.Bytes()
src, err := format.Source(preFormat)
if err != nil {
return fmt.Errorf("format.Source: %v on\n%s", err, preFormat)
return fmt.Errorf("format.Source: %w on\n%s", err, preFormat)
}

return os.WriteFile("reader_files_test.go", src, 0o644)
Expand Down
3 changes: 2 additions & 1 deletion writer.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package fit
import (
"bytes"
"encoding/binary"
"errors"
"fmt"
"io"
"reflect"
Expand Down Expand Up @@ -86,7 +87,7 @@ func (e *encoder) writeField(value reflect.Value, f *field) error {
}

if f.t.BaseType() == types.BaseString {
return fmt.Errorf("can't encode array of strings")
return errors.New("can't encode array of strings")
}

invalid := f.t.BaseType().Invalid()
Expand Down

0 comments on commit 040b0c3

Please sign in to comment.