-
Notifications
You must be signed in to change notification settings - Fork 65
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
patternProperties? #522
Comments
You're right: #[derive(Clone, Debug, Deserialize, Serialize)]
#[serde(deny_unknown_fields)]
pub struct Snapshot {
pub repos: SnapshotRepos,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub variables: Option<SnapshotVariables>,
}
#[derive(Clone, Debug, Deserialize, Serialize)]
#[serde(deny_unknown_fields)]
pub struct SnapshotRepos {}
#[derive(Clone, Debug, Deserialize, Serialize)]
#[serde(deny_unknown_fields)]
pub struct SnapshotVariables {} The Rust type you do want is a bit tricky: a I think we might want something like this: pub struct SnapshotRepos(BTreeMap<SnapshotReposKey, SnapshotReposValue>); // note not pub inner
impl<'de> Deserialize<'de> for SnapshotRepos {
// custom deserializer that enforces minProperties = 1
}
impl TryFrom<BTreeMap<SnapshotReposKey, SnapshotReposValue>> for SnapshotRepos {
// enforce minProperties = 1
}
// easy...
impl From<SnapshotRepos> for BTreeMap<SnapshotReposKey, SnapshotReposValue> {
fn from(value: SnapshotRepos) -> Self {
value.0
}
}
pub struct SnapshotReposKey(String); // like other constrained string types
// pretty simple type
pub struct SnapshotReposValue {
branch: String,
commit: String
} This isn't very hard to implement, but I'd like to make sure we have some reasonable approach for dealing with constrained types in a generic fashion. If someone is interested, please follow up and I'll do some thinking about what might make this consistent with the direction we want to take here. |
Hey thanks for the quick response! That sounds entirely reasonable. Quick side notes:
|
Interesting! I had recently been checking out Sentry; was not aware that they were typify users. Maybe there should be some setting to use one or the other. I'm not fully sure why I might have used
Right; not a big deal, just a heads up. |
Hello:
Cool project! I started implementing it into a sort of repo-management-type software I'm working on. However,
typify
didn't quite do what I expected, and looking into it, doesn't seem to support JSON Schema'spatternProperties
. I'm using YAML, where for example, I have a file like this:I could argue for the
repos
section to convert that to a list instead of an object and add an extra "name: xyz" field, but that just adds more boilerplate, butvariables
definitely doesn't make much sense to do anything other than the current format.So the JSON schema looks like this:
I integrated typify with
build.rs
, but get the same results withcargo typify ./snapshot.json
, small example (which I believe is correct?):And panicking at the second line, as I now expect, since it doesn't know what to look for:
Also, various unused variable warnings in the generated code file:
Anyway, I didn't see an existing issue for this, so figured I'd open one! Thanks!
The text was updated successfully, but these errors were encountered: