如何拥有固定的“锚定”到主要功能环境?
在包装中,我有一个主函数,该功能称为许多其他未出现的功能,到处都有很多条件检查。
使用tidyverse错误处理时,例如,使用Awesome {cli} 软件包,您可以附加一个呼叫者环境,该环境将用于装饰该功能。该文档可用在这里。
这是一些示例代码:
main = function() f1()
f1 = function() f2()
f2 = function() cli::cli_abort("foobar", call=rlang::caller_env())
main()
#> Error in `f1()`:
#> ! foobar
在2022-07-03创建的 reprex package (v2.0.1.1) )
呼叫者不是f2()
而是其父f1()
,但是错误是仍然没有信息,因为最终用户也不知道内部f1()
函数。
要拥有main()
作为结束呼叫者,我可以编写call = rlang :: Caller_env(2)
,它不是很可维护的,或者将呼叫者传递给呼叫者在堆叠的每个功能中的参数,这需要重构重构。
有没有办法拥有一个全局变量,该变量可以作为main()
的引用,并且可以在代码中的任何地方使用?
In a package, I have a main function that calls a lot of other, unexported functions, with a lot of condition checks everywhere.
When using tidyverse error handling, for instance using the awesome {cli} package, you can attach a caller environment that will be used to decorate the function. The documentation is available here.
Here is some example code:
main = function() f1()
f1 = function() f2()
f2 = function() cli::cli_abort("foobar", call=rlang::caller_env())
main()
#> Error in `f1()`:
#> ! foobar
Created on 2022-07-03 by the reprex package (v2.0.1)
The caller is not f2()
but its parent f1()
, but the error is still not informative as the end-user is not aware of the internal f1()
function either.
To have main()
as the end caller, I can either write call=rlang::caller_env(2)
, which is not very maintainable, or pass the caller as an argument in each and every function that stack, which would require a heavy refactor.
Is there a way to have a global variable that would act as a reference to main()
, and which I could use anywhere in my code?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我只能想到的(hacky)选项:
1:一次继续上升1个父环境,直到您达到
r_globalenv
,然后返回1步。2:自己创建某种标识符,您可以搜索这些标识符
Only (hacky) options I can think of:
1: Keep going up 1 parent environment at a time, until you've reached
R_GlobalEnv
, then go back 1 step.2: Create some sort of identifier yourself, which you can search for
我终于设法完成了。
我在软件包中声明了一个全局环境,但还不够,因为
my_caller
变量再次造成了很多错误。在主函数的开头,我将当前环境保存在全球环境中,作为变量,然后可以在以下子女功能中呼叫任何地方。
这是代码:
I finally managed to get it done.
I declare a global environment in my package, but it was not enough as attributing the
my_caller
variable again caused a lot of bugs.At the beginning of the main function, I save the current environment in the global environment as a variable, which I can then call anywhere in the following children functions.
Here is the code: