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