模块警告

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;
}