Hi Marten,
You will find this PR interesting
https://github.com/elixir-lang/elixir/issues/10352

Cheers,
- Eks

On Fri, 19 Nov 2021 14:00:40 -0800 (PST)
"w...@resilia.nl" <w...@resilia.nl> wrote:

> Hi all!
> 
> I recently needed to check what fields for a struct were defined (if
> any) for a particular module, at compile-time (potentially in the
> body of that module, i.e. while the module was still 'open').
> *(for the curious, it's part of code that builds a runtime type-check
> from a typespec, see here 
> <https://github.com/Qqwy/elixir-type_check/blob/21d5de5a1979ebd10d0f30818b6e837062027269/lib/type_check/internals/pre_expander.ex#L265-L270>)*
> 
> There was no information in Elixir's documentation about this.
> Looking at the source of `defstruct` 
> <https://github.com/elixir-lang/elixir/blob/79cd891eb86ecb7654a7acdb63769cfdd950a5c0/lib/elixir/lib/kernel.ex#L5037-L5046>
>  
> we however find that it defines a `@__struct__` module attribute
> (which is then later on used to implement the introspection method
> `__struct__/0`).
> 
> Now the question is: Is it OK for libraries to depend on
> `@__struct__` or should it be considered an implementation detail
> which is subject to change?
> 
> -If it's OK: Should we maybe add a sentence to the module
> documentation of `Module`? Or the documentation of
> `Kernel.SpecialForms.%/2`?
> - If it's not: Is there a 'proper' way to obtain this information for
> an 'open' module instead?
> 
> Thank you all,
> 
> ~Marten/Qqwy
> 

-- 
You received this message because you are subscribed to the Google Groups 
"elixir-lang-core" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to elixir-lang-core+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/elixir-lang-core/619820bd.1c69fb81.8c1b5.36d4SMTPIN_ADDED_MISSING%40gmr-mx.google.com.

Reply via email to