-
Notifications
You must be signed in to change notification settings - Fork 155
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support for composite custom kinds #858
Comments
@thes01 Hi, thanks for the suggestion! I really like this idea so will mark for consideration and review. Unfortunately I don't anticipate I'll be able to make updates to the current error pipeline in the short to medium term (as there is some design work going on in this area which may change the way validation and error generation is handled going forward). But I do like the idea of being able to yield multiple errors if required for custom kind cases, ideally under a revised SetErrorFunction. I'm imagining something like the following where the SetErrorFunction is updated to accept a generator function, and where custom kinds can be intercepted and yielded. SetErrorFunction(function * (params) {
// intercept custom error
if(params.schema[Kind] === 'Foo') {
yield 'error1' // yield custom error messages.
yield 'error2'
yield 'error3'
}
// defer to default generation
yield * DefaultErrorFunction(params)
}) I'll leave this issue open for now (there might be a way to get this in under the current design, possibly on the next minor revision), but may move to into discussions. As mentioned, there's actually some architectural work going on atm to revise the Value, Error and Compiler submodule infrastructure (which is likely to take months to complete), but would like to discuss frontend API designs once the new architecture is a bit more concrete. Cheers! |
Hello, first of all, thank you for creating this package with such an extensive API!
However, I'm currently struggling with a specific case. I'd like to create a custom typebox Kind (let's say
Map
or generally any composite structure) that recursively checks the validity of its children (similarly to e.g.T.Record
orT.Array
).I can see that in the source code, the
FromKind
method only yields at most one error (for the object as a whole).Would you consider extending it with a custom iterator? Maybe something like:
and adding a
SetCompositeErrorIterator
, similar as with SetErrorFunction?This iterator would then call the
Visit
function (which would need to be exported fromerrors/errors.ts
) on all the children.Adding this would enable simple creation of custom composite kinds that validate their inner data while fully embracing the typebox's error mechanism.
Thank you!
The text was updated successfully, but these errors were encountered: