Skip to content

Instantly share code, notes, and snippets.

@Liquidsoul
Last active March 15, 2023 08:02
Show Gist options
  • Star 8 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save Liquidsoul/efa4f65af055acfde64afed6cda0007d to your computer and use it in GitHub Desktop.
Save Liquidsoul/efa4f65af055acfde64afed6cda0007d to your computer and use it in GitHub Desktop.
A Sourcery template to generate a default initializer in your `struct`s (working in version 0.8.0)
{% for type in types.structs %}
{% if type|annotated:"AutoInit" %}
{% set spacing %}{% if type.parentName %} {% endif %}{% endset %}
{% map type.storedVariables into parameters using var %}{{ var.name }}: {{ var.typeName }}{% endmap %}
// sourcery:inline:auto:{{ type.name }}.AutoInit
{{spacing}} {{ type.accessLevel }} init({{ parameters|join:", " }}) { // swiftlint:disable:this line_length
{{spacing}} {% for variable in type.storedVariables %}
{{spacing}} self.{{ variable.name }} = {{ variable.name }}
{{spacing}} {% endfor %}
{{spacing}} }
// sourcery:end
{% endif %}
{% endfor %}
@ferologics
Copy link

Thank you so much @txuslee for the fix!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment