warning-flags.c revision ef8225444452a1486bd721f3285301fe84643b00
1RUN: diagtool list-warnings > %t 2>&1 2RUN: FileCheck --input-file=%t %s 3 4This test serves two purposes: 5 6(1) It documents all existing warnings that currently have no associated -W flag, 7 and ensures that the list never grows. 8 9 If take an existing warning and add a flag, this test will fail. To 10 fix this test, simply remove that warning from the list below. 11 12(2) It prevents us adding new warnings to Clang that have no -W flag. All 13 new warnings should have -W flags. 14 15 If you add a new warning without a flag, this test will fail. To fix 16 this test, simply add a warning group to that warning. 17 18 19The list of warnings below should NEVER grow. It should gradually shrink to 0. 20 21CHECK: Warnings without flags (105): 22CHECK-NEXT: ext_delete_void_ptr_operand 23CHECK-NEXT: ext_expected_semi_decl_list 24CHECK-NEXT: ext_explicit_specialization_storage_class 25CHECK-NEXT: ext_implicit_lib_function_decl 26CHECK-NEXT: ext_many_braces_around_scalar_init 27CHECK-NEXT: ext_missing_declspec 28CHECK-NEXT: ext_missing_whitespace_after_macro_name 29CHECK-NEXT: ext_new_paren_array_nonconst 30CHECK-NEXT: ext_plain_complex 31CHECK-NEXT: ext_template_arg_extra_parens 32CHECK-NEXT: ext_typecheck_comparison_of_pointer_integer 33CHECK-NEXT: ext_typecheck_cond_incompatible_operands 34CHECK-NEXT: ext_typecheck_cond_incompatible_operands_nonstandard 35CHECK-NEXT: ext_typecheck_ordered_comparison_of_function_pointers 36CHECK-NEXT: ext_typecheck_ordered_comparison_of_pointer_integer 37CHECK-NEXT: ext_using_undefined_std 38CHECK-NEXT: pp_include_next_absolute_path 39CHECK-NEXT: pp_include_next_in_primary 40CHECK-NEXT: pp_invalid_string_literal 41CHECK-NEXT: pp_out_of_date_dependency 42CHECK-NEXT: pp_poisoning_existing_macro 43CHECK-NEXT: pp_pragma_once_in_main_file 44CHECK-NEXT: pp_pragma_sysheader_in_main_file 45CHECK-NEXT: w_asm_qualifier_ignored 46CHECK-NEXT: warn_accessor_property_type_mismatch 47CHECK-NEXT: warn_anon_bitfield_width_exceeds_type_size 48CHECK-NEXT: warn_arcmt_nsalloc_realloc 49CHECK-NEXT: warn_asm_label_on_auto_decl 50CHECK-NEXT: warn_bitfield_width_exceeds_type_size 51CHECK-NEXT: warn_braces_around_scalar_init 52CHECK-NEXT: warn_c_kext 53CHECK-NEXT: warn_call_to_pure_virtual_member_function_from_ctor_dtor 54CHECK-NEXT: warn_call_wrong_number_of_arguments 55CHECK-NEXT: warn_case_empty_range 56CHECK-NEXT: warn_char_constant_too_large 57CHECK-NEXT: warn_collection_expr_type 58CHECK-NEXT: warn_conflicting_variadic 59CHECK-NEXT: warn_conv_to_base_not_used 60CHECK-NEXT: warn_conv_to_self_not_used 61CHECK-NEXT: warn_conv_to_void_not_used 62CHECK-NEXT: warn_delete_array_type 63CHECK-NEXT: warn_double_const_requires_fp64 64CHECK-NEXT: warn_drv_assuming_mfloat_abi_is 65CHECK-NEXT: warn_drv_clang_unsupported 66CHECK-NEXT: warn_drv_objc_gc_unsupported 67CHECK-NEXT: warn_drv_pch_not_first_include 68CHECK-NEXT: warn_dup_category_def 69CHECK-NEXT: warn_duplicate_protocol_def 70CHECK-NEXT: warn_enum_value_overflow 71CHECK-NEXT: warn_exception_caught_by_earlier_handler 72CHECK-NEXT: warn_excess_initializers 73CHECK-NEXT: warn_excess_initializers_in_char_array_initializer 74CHECK-NEXT: warn_expected_qualified_after_typename 75CHECK-NEXT: warn_extraneous_char_constant 76CHECK-NEXT: warn_fe_cc_log_diagnostics_failure 77CHECK-NEXT: warn_fe_cc_print_header_failure 78CHECK-NEXT: warn_fe_macro_contains_embedded_newline 79CHECK-NEXT: warn_file_asm_volatile 80CHECK-NEXT: warn_ignoring_ftabstop_value 81CHECK-NEXT: warn_implements_nscopying 82CHECK-NEXT: warn_incompatible_qualified_id 83CHECK-NEXT: warn_initializer_string_for_char_array_too_long 84CHECK-NEXT: warn_inline_namespace_reopened_noninline 85CHECK-NEXT: warn_invalid_asm_cast_lvalue 86CHECK-NEXT: warn_maynot_respond 87CHECK-NEXT: warn_method_param_redefinition 88CHECK-NEXT: warn_mismatched_exception_spec 89CHECK-NEXT: warn_missing_case_for_condition 90CHECK-NEXT: warn_missing_dependent_template_keyword 91CHECK-NEXT: warn_missing_exception_specification 92CHECK-NEXT: warn_missing_whitespace_after_macro_name 93CHECK-NEXT: warn_mt_message 94CHECK-NEXT: warn_multiple_method_decl 95CHECK-NEXT: warn_no_constructor_for_refconst 96CHECK-NEXT: warn_not_compound_assign 97CHECK-NEXT: warn_objc_property_copy_missing_on_block 98CHECK-NEXT: warn_objc_protocol_qualifier_missing_id 99CHECK-NEXT: warn_on_superclass_use 100CHECK-NEXT: warn_param_default_argument_redefinition 101CHECK-NEXT: warn_partial_specs_not_deducible 102CHECK-NEXT: warn_pp_convert_lhs_to_positive 103CHECK-NEXT: warn_pp_convert_rhs_to_positive 104CHECK-NEXT: warn_pp_expr_overflow 105CHECK-NEXT: warn_pp_line_decimal 106CHECK-NEXT: warn_pragma_pack_pop_identifer_and_alignment 107CHECK-NEXT: warn_pragma_pack_show 108CHECK-NEXT: warn_property_attr_mismatch 109CHECK-NEXT: warn_property_attribute 110CHECK-NEXT: warn_property_getter_owning_mismatch 111CHECK-NEXT: warn_property_types_are_incompatible 112CHECK-NEXT: warn_readonly_property 113CHECK-NEXT: warn_redeclaration_without_attribute_prev_attribute_ignored 114CHECK-NEXT: warn_register_objc_catch_parm 115CHECK-NEXT: warn_related_result_type_compatibility_class 116CHECK-NEXT: warn_related_result_type_compatibility_protocol 117CHECK-NEXT: warn_template_export_unsupported 118CHECK-NEXT: warn_template_spec_extra_headers 119CHECK-NEXT: warn_tentative_incomplete_array 120CHECK-NEXT: warn_typecheck_function_qualifiers 121CHECK-NEXT: warn_undef_interface 122CHECK-NEXT: warn_undef_interface_suggest 123CHECK-NEXT: warn_undef_protocolref 124CHECK-NEXT: warn_use_out_of_scope_declaration 125CHECK-NEXT: warn_weak_identifier_undeclared 126CHECK-NEXT: warn_weak_import 127 128The list of warnings in -Wpedantic should NEVER grow. 129 130CHECK: Number in -Wpedantic (not covered by other -W flags): 28 131