-
Notifications
You must be signed in to change notification settings - Fork 148
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
Anchors with circular references #274
Comments
The error thrown is:
|
The offending code begins at line 278 in Parser.swift: func loadAlias(from event: Event) throws -> Node {
guard let alias = event.aliasAnchor else {
fatalError("unreachable")
}
guard let node = anchors[alias] else {
throw YamlError.composer(context: nil,
problem: "found undefined alias", event.startMark,
yaml: yaml)
}
return node
} If there were a way for the call to cc/ @sacheu |
Alternatively, if the parser could simply do an initial pass and NOT throw an error on unresolved aliases, then the alias would be constructed. If the parser could then reparse the document using the anchors from the previous pass, there shouldn't be any unresolved aliases. |
It seems like other parsers also fail on the sample input you provided. yamllint.com experiences an internal server error when you give it that input. It also crashes when giving this simpler circular reference: - &ref_0
parents:
- *ref_0 |
This online tool also fails: codebeautify.org/yaml-validator With this input: - &ref_0
parents:
- *ref_0 It produces this error:
|
I'm looking at how this javascript yaml parser added support for circular references: eemeli/yaml#84 I'm also thinking that we'd need to change quite a few of the internals of Yams would need to change to allow for references rather than our current value-type based approach. Finally, I'm trying to think through the implications of our Codable support and how that would interoperate with a reference-based approach. This thread has some useful discussion around that: https://forums.swift.org/t/codable-with-references/13885/4 |
I have a draft PR in my local fork that is mostly working for me. |
Interesting take. Thanks for taking charge on it. Are you planning on supporting decoding Codable types with references or would that be unsupported? It might be possible to check to see if the type being decoded is a reference type and only decode circular references in that case. |
We are using this in our code generator and making heavy use of Codable. Right now it seems to be working for our purposes (we are unblocked) but I'm sure there are edge cases we aren't detecting. |
I’m glad to hear that! I’ll happily review a PR once you’re happy with your solution. |
Just out of curiosity where did you land with this @tjprescott ? |
We have a hacky workaround in my fork that we are using. It by no means is a general solution. I think that would require, as you noted, a fundamental change from using structs to classes, but it did unblock our scenario. It's the same PR linked above and we just take a source dependency on that branch. |
Yeah that makes sense. Let me know if you can think of a good way that Yams could offer hooks into its parsing to allow users to do this kind of thing without having to fork the project. |
We have a generated YAML file that looks like this snippet:
YAMS is unable to parse this, though we are able to parse this successfully in other languages we support (C#, Java, Python).
cc/ @sacheu
The text was updated successfully, but these errors were encountered: