mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Fix described_class
Must be a macro, otherwise the return type becomes a union of all nested described_class methods, which can cause weird errors.
This commit is contained in:
parent
a20b7cad80
commit
0363c43dff
1 changed files with 8 additions and 8 deletions
|
@ -86,17 +86,17 @@ module Spectator::DSL
|
|||
what.is_a?(TypeNode) ||
|
||||
what.is_a?(Union)) &&
|
||||
(described_type = what.resolve?).is_a?(TypeNode) %}
|
||||
private def described_class
|
||||
{{described_type}}
|
||||
private macro described_class
|
||||
{{what}}
|
||||
end
|
||||
|
||||
{% if described_type < Reference || described_type < Value %}
|
||||
subject { described_class.new }
|
||||
subject do
|
||||
{% if described_type.class? || described_type.struct? %}
|
||||
described_class.new
|
||||
{% else %}
|
||||
private def subject
|
||||
described_class
|
||||
end
|
||||
{% end %}
|
||||
end
|
||||
{% else %}
|
||||
private def _spectator_implicit_subject
|
||||
{{what}}
|
||||
|
|
Loading…
Reference in a new issue