mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Workaround for mashup of compile-time types
This commit is contained in:
parent
018e3232cd
commit
a9d1f1aabc
2 changed files with 31 additions and 8 deletions
23
spec/helpers/matchers_helper.cr
Normal file
23
spec/helpers/matchers_helper.cr
Normal file
|
@ -0,0 +1,23 @@
|
|||
# Retrieves a value from the `NamedTuple` returned by `Spectator::Matchers::MatchData#values`.
|
||||
def match_data_value(match_data, key, t : T.class) forall T
|
||||
match_data.values.fetch(key) { raise "#{key} is missing" }.as(T)
|
||||
end
|
||||
|
||||
# Retrieves the string representation and base value
|
||||
# from a `Spectator::Matchers::PrefixedValue`
|
||||
# in a `NamedTuple` returned by `Spectator::Matchers::MatchData#values`.
|
||||
def match_data_prefix(match_data, key, t : T.class) forall T
|
||||
prefix = match_data_value(match_data, key, Spectator::Matchers::PrefixGrabber.get(t))
|
||||
{to_s: prefix.to_s, value: prefix.value}
|
||||
end
|
||||
|
||||
# Dirty cheat to get around visibility restriction.
|
||||
module Spectator::Matchers
|
||||
module PrefixGrabber
|
||||
extend self
|
||||
|
||||
def get(t : T.class) forall T
|
||||
PrefixedValue(T)
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue