mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Try handling different method signatures and blocks
This commit is contained in:
parent
211050650e
commit
27bc976ae3
1 changed files with 33 additions and 11 deletions
|
@ -25,6 +25,17 @@ module Spectator
|
||||||
end
|
end
|
||||||
%}
|
%}
|
||||||
|
|
||||||
|
{% if name.ends_with?('=') && name.id != "[]=" %}
|
||||||
|
def {{name}}(arg)
|
||||||
|
call = ::Spectator::MethodCall.new({{name.symbolize}}, {arg}, NamedTuple.new)
|
||||||
|
stub = @stubs.find(&.callable?(call))
|
||||||
|
if stub
|
||||||
|
stub.as(::Spectator::GenericMethodStub(typeof(%method(arg)))).call(call)
|
||||||
|
else
|
||||||
|
%method(arg)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
{% else %}
|
||||||
def {{name}}(*args, **options){% if definition.is_a?(TypeDeclaration) %} : {{definition.type}}{% end %}
|
def {{name}}(*args, **options){% if definition.is_a?(TypeDeclaration) %} : {{definition.type}}{% end %}
|
||||||
call = ::Spectator::MethodCall.new({{name.symbolize}}, args, options)
|
call = ::Spectator::MethodCall.new({{name.symbolize}}, args, options)
|
||||||
stub = @stubs.find(&.callable?(call))
|
stub = @stubs.find(&.callable?(call))
|
||||||
|
@ -35,9 +46,20 @@ module Spectator
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def {{name}}(*args, **options, &block){% if definition.is_a?(TypeDeclaration) %} : {{definition.type}}{% end %}
|
{% if name != "[]=" %}
|
||||||
%method(*args, **options, &block)
|
def {{name}}(*args, **options){% if definition.is_a?(TypeDeclaration) %} : {{definition.type}}{% end %}
|
||||||
|
call = ::Spectator::MethodCall.new({{name.symbolize}}, args, options)
|
||||||
|
stub = @stubs.find(&.callable?(call))
|
||||||
|
if stub
|
||||||
|
stub.as(::Spectator::GenericMethodStub(typeof(%method(*args, **options)))).call(call)
|
||||||
|
else
|
||||||
|
%method(*args, **options) do |*yield_args|
|
||||||
|
yield *yield_args
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
{% end %}
|
||||||
|
{% end %}
|
||||||
|
|
||||||
def %method({{params.splat}}){% if definition.is_a?(TypeDeclaration) %} : {{definition.type}}{% end %}
|
def %method({{params.splat}}){% if definition.is_a?(TypeDeclaration) %} : {{definition.type}}{% end %}
|
||||||
{% if body && !body.is_a?(Nop) %}
|
{% if body && !body.is_a?(Nop) %}
|
||||||
|
|
Loading…
Reference in a new issue