如何解决Raku的自省可以列出不同文件/模块中的所有多个候选对象吗?
在同一模块中定义了原型和多重时,Type.^lookup('method').candidates
返回所有多重候选的列表。但是,当原型位于与multis不同的文件/模块中时,这似乎不起作用。
say Setty.^lookup('grab').candidates; # OUTPUT: ()
有什么办法可以通过Raku的内省来找到多名候选人的完整名单吗?还是没有办法替代源代码? (我问,因为拥有适用于给定原型的多种候选物的完整列表将是helpful for documentation purposes。)
解决方法
到目前为止,withCredentials([[$class: 'UsernamePasswordMultiBinding',credentialsId: 'mssql-win',usernameVariable: 'USERNAME',passwordVariable: 'PASSWORD']]
echo "Username" %USERNAME%
echo "Password" %PASSWORD%
)
multi
根本就不在同一个模块或文件中。考虑以下类:
methods
每当我们组成一个包含多个方法的类时,就需要将它们附加到控件class Base {
proto method m(|) { * }
multi method m() { 1 }
}
class Derived is Base {
multi method m() { 2 }
}
上。在proto
的情况下,这是明确编写的,因此除了将Base
候选者添加到其候选者列表之外,没有其他事情要做。如果我们没有在multi
中显式地编写一个proto
,那么将为我们生成一个候选列表为空的结果,最终结果相同。
不过,我刚刚描述的过程有点简化了实际发生的事情。这些步骤是:
- 查看此类是否已经具有
Base
;如果是这样,请向其中添加proto
- 否则,请查看是否有任何基类具有
multi
;如果是这样,请将其克隆(在克隆候选列表之前),然后在其中添加proto
。 - 否则,生成一个新的
multi
。
步骤2确实是您问题的答案。如果这样做:
proto
然后输出为:
say "Base:";
.raku.say for Base.^lookup('m').candidates;
say "Derived:";
.raku.say for Derived.^lookup('m').candidates;
也就是说,Base:
multi method m (Base: *%_) { #`(Method|82762064) ... }
Derived:
multi method m (Base: ) { #`(Method|82762064) ... }
multi method m (Derived: ) { #`(Method|82762208) ... }
中的候选列表具有一个条目,而Base
中的候选列表具有从Derived
克隆的条目以及一个新条目。
几乎所有事情都遵循这一原理:派生类引用其基类(及其作用),但是基类(及其角色)不了解其后代。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。