模块警告
Warning
模块包含一个名为 warn
的方法,并且该模块扩展自身,使 Warning.warn
可用。 Warning.warn
用于 Ruby 发出的所有警告。默认情况下,警告将打印到 $stderr。
更改 Warning.warn
的行为对于自定义 Ruby 处理警告的方式很有用,例如过滤某些警告,以及/或将警告输出到 $stderr
以外的地方。
如果您想更改 Warning.warn
的行为,您应该使用 Warning.extend(MyNewModuleWithWarnMethod)
,并且可以使用 super
来获取将警告打印到 $stderr
的默认行为。
示例
module MyWarningFilter def warn(message, category: nil, **kwargs) if /some warning I want to ignore/.match?(message) # ignore else super end end end Warning.extend MyWarningFilter
您永远不应该重新定义 Warning#warn
(实例方法),因为那样将不再提供使用默认行为的方式。
warning gem 提供了自定义 Warning.warn
的便捷方法。
公共类方法
Warning[category] → true 或 false 点击切换源代码
返回显示 category
警告消息的标志。支持的类别是
:deprecated
-
弃用警告
-
将非空值分配给
$,
和$;
-
关键字参数
等等。
-
:experimental
-
实验性功能
-
模式匹配
-
:performance
-
性能提示
-
形状变化限制
-
static VALUE rb_warning_s_aref(VALUE mod, VALUE category) { rb_warning_category_t cat = rb_warning_category_from_name(category); return RBOOL(rb_warning_category_enabled_p(cat)); }
Warning[category] = flag → flag 点击切换源代码
设置 category
的警告标志。有关类别,请参见 Warning.[]
。
static VALUE rb_warning_s_aset(VALUE mod, VALUE category, VALUE flag) { unsigned int mask = rb_warning_category_mask(category); unsigned int disabled = warning_disabled_categories; if (!RTEST(flag)) disabled |= mask; else disabled &= ~mask; warning_disabled_categories = disabled; return flag; }
公共实例方法
warn(msg, category: nil) → nil 点击切换源代码
将警告消息 msg
写入 $stderr。此方法由 Ruby 用于所有发出的警告。警告中可以包含 category
。
有关如何自定义此方法,请参见 Warning
模块的文档。
static VALUE rb_warning_s_warn(int argc, VALUE *argv, VALUE mod) { VALUE str; VALUE opt; VALUE category = Qnil; rb_scan_args(argc, argv, "1:", &str, &opt); if (!NIL_P(opt)) rb_get_kwargs(opt, &id_category, 0, 1, &category); Check_Type(str, T_STRING); rb_must_asciicompat(str); if (!NIL_P(category)) { rb_warning_category_t cat = rb_warning_category_from_name(category); if (!rb_warning_category_enabled_p(cat)) return Qnil; } rb_write_error_str(str); return Qnil; }