Skip to content

Commit

Permalink
Add changelog for DecoderResult
Browse files Browse the repository at this point in the history
  • Loading branch information
lydell committed Oct 27, 2023
1 parent 88ff27d commit 609b9d1
Showing 1 changed file with 24 additions and 0 deletions.
24 changes: 24 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,29 @@
Note: I’m currently working on several breaking changes to tiny-decoders, but I’m trying out releasing them piece by piece. The idea is that you can either upgrade version by version only having to deal with one or a few breaking changes at a time, or wait and do a bunch of them at the same time.

### Version 16.0.0 (2023-10-29)

This release changes decoders from throwing errors to returning a `DecoderResult`:

```ts
type Decoder<T> = (value: unknown) => DecoderResult<T>;

type DecoderResult<T> =
| {
tag: "DecoderError";
error: DecoderError;
}
| {
tag: "Valid";
value: T;
};
```

Because of that, `chain` has been removed and replaced with `map` and `flatMap`. In all places you used `chain`, you need to switch to `map` if the operation cannot fail (you just transform the data), or `flatMap` if it can. For `flatMap`, you should not throw errors but instead return a `DecoderResult`. You might need to add a `try-catch` to do this. Note that TypeScript won’t help you what you need to catch. Similarly, you also need to return a `DecoderError` instead of throwing in custom decoders.

`DecoderError` is now a plain object instead of a class. Use the new `format` function to turn a `DecoderError` into a string, similar to `DecoderError.prototype.format` did before.

This change is nice because it avoids `try-catch` when you run a decoder, which is annoying due to the caught error is typed as `any` or `unknown`, which required an `error instanceof DecoderError` check.

### Version 15.1.0 (2023-10-23)

This release adds the `Infer` utility type. It’s currently basically just an alias to the TypeScript built-in `ReturnType` utility type, but in a future version of tiny-decoders it’ll need to do a little bit more than just `ReturnType`. If you’d like to reduce the amount of migration work when upgrading to that future version, change all your `ReturnType<typeof myDecoder>` to `Infer<typeof myDecoder>` now!
Expand Down

0 comments on commit 609b9d1

Please sign in to comment.