Snakecase fields in records should be turned into camelCase
Opened this issue · 5 comments
Example input:
Banana:
type: object
required:
- banana_id
properties:
banana_id:
type: string
right now generates:
type alias BananaRecord =
{ banana_id: String
}
decodeBanana = ...
...
|> required "banana_id"
...
It should instead generate:
type alias BananaRecord =
{ bananaId: String
}
decodeBanana = ...
...
|> required "banana_id"
...
I think this is a nice-to-have, since _
, while not idiomatic, works. Also there's the issue of avoiding name collisions. Consider:
Banana:
type: object
properties:
banana_id:
type: string
bananaId:
type: string
which would be valid swagger.
I would argue that that example should actually be invalid swagger. If you have to things with the same name, the only difference being camelCase
and camel_case
, then you've duplicated the fields and made the API inconsistent
I agree it's a bad schema, but it's nonetheless a valid spec. Swagger is very unopinionated on how you name your fields. I suppose it's a separate issue though, since sanitization can already cause collisions.
I would think the ideal approach would be to make swagger-elm warn you when your API contains underscores, and provide a flag for auto-converting it to camelCase
That sounds like a good solution