On Wed, 2022-06-22 at 18:34 -0400, David Malcolm wrote: > gcc/ChangeLog: > * common.opt (fdiagnostics-show-rules): New option. > * diagnostic-format-json.cc > (diagnostic_output_format_init_json): > Fix up context->show_rules. > * diagnostic-format-sarif.cc > (diagnostic_output_format_init_sarif): Likewise. > * diagnostic-metadata.h (diagnostic_metadata::rule): New > class. > (diagnostic_metadata::precanned_rule): New class. > (diagnostic_metadata::add_rule): New. > (diagnostic_metadata::get_num_rules): New. > (diagnostic_metadata::get_rule): New. > (diagnostic_metadata::m_rules): New field. > * diagnostic.cc (diagnostic_initialize): Initialize > show_rules. > (print_any_rules): New. > (diagnostic_report_diagnostic): Call it. > * diagnostic.h (diagnostic_context::show_rules): New field. > * doc/invoke.texi (-fno-diagnostics-show-rules): New option. > * opts.cc (common_handle_option): Handle > OPT_fdiagnostics_show_rules. > * toplev.cc (general_init): Set up global_dc->show_rules. > > gcc/testsuite/ChangeLog: > * gcc.dg/plugin/diagnostic-test-metadata.c: Expect " [STR34- > C]" to > be emitted at the "gets" call. > * gcc.dg/plugin/diagnostic_plugin_test_metadata.c > (pass_test_metadata::execute): Associate the "gets" > diagnostic > with a rule named "STR34-C". > > Signed-off-by: David Malcolm <dmalc...@redhat.com>
This one seems potentially useful to plugin authors without the rest of the patch kit, so I've pushed it to trunk as: r13-1221-g0b14f590e3e9d9 (after a successful bootstrap & regression test on x86_64-pc-linux-gnu) Dave