summaryrefslogtreecommitdiff
path: root/docs/users_guide/using-warnings.rst
blob: 5118168a8c77a4c224625361058d7fa07c0cdca6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
.. _options-sanity:

Warnings and sanity-checking
----------------------------

.. index::
   single: sanity-checking options
   single: warnings

GHC has a number of options that select which types of non-fatal error
messages, otherwise known as warnings, can be generated during
compilation. By default, you get a standard set of warnings which are
generally likely to indicate bugs in your program. These are:
``-fwarn-overlapping-patterns``, ``-fwarn-warnings-deprecations``,
``-fwarn-deprecated-flags``, ``-fwarn-unrecognised-pragmas``,
``-fwarn-missed-specialisations``, ``-fwarn-duplicate-constraints``,
``-fwarn-duplicate-exports``, ``-fwarn-overflowed-literals``,
``-fwarn-empty-enumerations``, ``-fwarn-missing-fields``,
``-fwarn-missing-methods``, ``-fwarn-wrong-do-bind``,
``-fwarn-unsupported-calling-conventions``,
``-fwarn-dodgy-foreign-imports``, ``-fwarn-inline-rule-shadowing``,
``-fwarn-unsupported-llvm-version``, ``-fwarn-context-quantification``,
and ``-fwarn-tabs``. The following flags are simple ways to select
standard “packages” of warnings:

``-W``
    .. index::
       single: -W option

    Provides the standard warnings plus ``-fwarn-unused-binds``,
    ``-fwarn-unused-matches``, ``-fwarn-unused-imports``,
    ``-fwarn-incomplete-patterns``, ``-fwarn-dodgy-exports``, and
    ``-fwarn-dodgy-imports``.

``-Wall``
    .. index::
       single: -Wall

    Turns on all warning options that indicate potentially suspicious
    code. The warnings that are *not* enabled by ``-Wall`` are
    ``-fwarn-incomplete-uni-patterns``,
    ``-fwarn-incomplete-record-updates``,
    ``-fwarn-monomorphism-restriction``,
    ``-fwarn-implicit-prelude``, ``-fwarn-missing-local-sigs``,
    ``-fwarn-missing-exported-sigs``, ``-fwarn-missing-import-lists``
    and ``-fwarn-identities``.

``-w``
    .. index::
       single: -w

    Turns off all warnings, including the standard ones and those that
    ``-Wall`` doesn't enable.

``-Werror``
    .. index::
       single: -Werror

    Makes any warning into a fatal error. Useful so that you don't miss
    warnings when doing batch compilation.

``-Wwarn``
    .. index::
       single: -Wwarn

    Warnings are treated only as warnings, not as errors. This is the
    default, but can be useful to negate a ``-Werror`` flag.

The full set of warning options is described below. To turn off any
warning, simply give the corresponding ``-fno-warn-...`` option on the
command line.

``-fwarn-typed-holes``
    .. index::
       single: -fwarn-typed-holes
       single: warnings

    Determines whether the compiler reports typed holes warnings. Has no
    effect unless typed holes errors are deferred until runtime. See
    :ref:`typed-holes` and :ref:`defer-type-errors`

    This warning is on by default.

``-fwarn-type-errors``
    .. index::
       single: -fwarn-type-errors
       single: warnings

    Causes a warning to be reported when a type error is deferred until
    runtime. See :ref:`defer-type-errors`

    This warning is on by default.

``-fdefer-type-errors``
    .. index::
       single: -fdefer-type-errors
       single: warnings

    Defer as many type errors as possible until runtime. At compile time
    you get a warning (instead of an error). At runtime, if you use a
    value that depends on a type error, you get a runtime error; but you
    can run any type-correct parts of your code just fine. See
    :ref:`defer-type-errors`

``-fdefer-typed-holes``
    .. index::
       single: -fdefer-typed-holes
       single: warnings

    Defer typed holes errors until runtime. This will turn the errors
    produced by :ref:`typed holes <typed-holes>` into warnings. Using a value
    that depends on a typed hole produces a runtime error, the same as
    ``-fdefer-type-errors`` (which implies this option). See :ref:`typed-holes`
    and :ref:`defer-type-errors`.

    Implied by ``-fdefer-type-errors``. See also ``-fwarn-typed-holes``.

``-fwarn-partial-type-signatures``
    .. index::
       single: -fwarn-partial-type-signatures
       single: warnings

    Determines whether the compiler reports holes in partial type
    signatures as warnings. Has no effect unless
    ``-XPartialTypeSignatures`` is enabled, which controls whether
    errors should be generated for holes in types or not. See
    :ref:`partial-type-signatures`.

    This warning is on by default.

``-fhelpful-errors``
    .. index::
       single: -fhelpful-errors
       single: warnings

    When a name or package is not found in scope, make suggestions for
    the name or package you might have meant instead.

    This option is on by default.

``-fwarn-unrecognised-pragmas``
    .. index::
       single: -fwarn-unrecognised-pragmas
       single: warnings
       single: pragmas

    Causes a warning to be emitted when a pragma that GHC doesn't
    recognise is used. As well as pragmas that GHC itself uses, GHC also
    recognises pragmas known to be used by other tools, e.g.
    ``OPTIONS_HUGS`` and ``DERIVE``.

    This option is on by default.

``-fwarn-missed-specialisations``, ``-fwarn-all-missed-specialisations``
    .. index::
       single: -fwarn-missed-specialisations
       single: -fwarn-all-missed-specialisations
       single: warnings
       single: pragmas

    Emits a warning if GHC cannot specialise an overloaded function, usually
    because the function needs an ``INLINEABLE`` pragma. The "all" form reports
    all such situations whereas the "non-all" form only reports when the
    situation arises during specialisation of an imported function.

    The "non-all" form is intended to catch cases where an imported function
    that is marked as ``INLINEABLE`` (presumably to enable specialisation) cannot
    be specialised as it calls other functions that are themselves not specialised.

    These options are both off by default.

``-fwarn-warnings-deprecations``
    .. index::
       single: -fwarn-warnings-deprecations
       single: warnings
       single: deprecations

    Causes a warning to be emitted when a module, function or type with
    a ``WARNING`` or ``DEPRECATED pragma`` is used. See
    :ref:`warning-deprecated-pragma` for more details on the pragmas.

    This option is on by default.

``-fwarn-amp``
    .. index::
       single: -fwarn-amp
       single: AMP
       single: Applicative-Monad Proposal

    This option is deprecated.

    Caused a warning to be emitted when a definition was in conflict with
    the AMP (Applicative-Monad proosal).

``-fwarn-noncanonical-monad-instances``
    .. index::
       single: -fwarn-noncanonical-monad-instances

    Warn if noncanonical ``Applicative`` or ``Monad`` instances
    declarations are detected.

    When this warning is enabled, the following conditions are verified:

    In ``Monad`` instances declarations warn if any of the following
    conditions does not hold:

     * If ``return`` is defined it must be canonical (i.e. ``return = pure``).
     * If ``(>>)`` is defined it must be canonical (i.e. ``(>>) = (*>)``).

    Moreover, in 'Applicative' instance declarations:

     * Warn if ``pure`` is defined backwards (i.e. ``pure = return``).
     * Warn if ``(*>)`` is defined backwards (i.e. ``(*>) = (>>)``).

    This option is off by default.

``-fwarn-missing-monadfail-instance``
    .. index::
       single: -fwarn-missing-monadfail-instance
       single: MFP
       single: MonadFail Proposal

    Warn when a failable pattern is used in a do-block that does not have a
    ``MonadFail`` instance.

    This option is off by default, but will be switched on in a future GHC
    release, as part of the MFP (MonadFail Proposal).

``-fwarn-deprecated-flags``
    .. index::
       single: -fwarn-deprecated-flags
       single: deprecated-flags

    Causes a warning to be emitted when a deprecated command-line flag
    is used.

    This option is on by default.

``-fwarn-unsupported-calling-conventions``
    .. index::
       single: -fwarn-unsupported-calling-conventions

    Causes a warning to be emitted for foreign declarations that use
    unsupported calling conventions. In particular, if the ``stdcall``
    calling convention is used on an architecture other than i386 then
    it will be treated as ``ccall``.

``-fwarn-dodgy-foreign-imports``
    .. index::
       single: -fwarn-dodgy-foreign-imports

    Causes a warning to be emitted for foreign imports of the following
    form:

    ::

        foreign import "f" f :: FunPtr t

    on the grounds that it probably should be

    ::

        foreign import "&f" f :: FunPtr t

    The first form declares that \`f\` is a (pure) C function that takes
    no arguments and returns a pointer to a C function with type \`t\`,
    whereas the second form declares that \`f\` itself is a C function
    with type \`t\`. The first declaration is usually a mistake, and one
    that is hard to debug because it results in a crash, hence this
    warning.

``-fwarn-dodgy-exports``
    .. index::
       single: -fwarn-dodgy-exports

    Causes a warning to be emitted when a datatype ``T`` is exported
    with all constructors, i.e. ``T(..)``, but is it just a type
    synonym.

    Also causes a warning to be emitted when a module is re-exported,
    but that module exports nothing.

``-fwarn-dodgy-imports``
    .. index::
       single: -fwarn-dodgy-imports

    Causes a warning to be emitted in the following cases:

    -  When a datatype ``T`` is imported with all constructors, i.e.
       ``T(..)``, but has been exported abstractly, i.e. ``T``.

    -  When an ``import`` statement hides an entity that is not
       exported.

``-fwarn-overflowed-literals``
    .. index::
       single: -fwarn-overflowed-literals

    Causes a warning to be emitted if a literal will overflow, e.g.
    ``300 :: Word8``.

``-fwarn-empty-enumerations``
    .. index::
       single: -fwarn-empty-enumerations

    Causes a warning to be emitted if an enumeration is empty, e.g.
    ``[5 .. 3]``.

``-fwarn-lazy-unlifted-bindings``
    .. index::
       single: -fwarn-lazy-unlifted-bindings

    This flag is a no-op, and will be removed in GHC 7.10.

``-fwarn-duplicate-constraints``
    .. index::
       single: -fwarn-duplicate-constraints
       single: duplicate constraints, warning

    Have the compiler warn about duplicate constraints in a type
    signature. For example

    ::

        f :: (Eq a, Show a, Eq a) => a -> a

    The warning will indicate the duplicated ``Eq a`` constraint.

    This option is now deprecated in favour of
    ``-fwarn-redundant-constraints``.

``-fwarn-redundant-constraints``
    .. index::
       single: -fwarn-redundant-constraints
       single: redundant constraints, warning

    Have the compiler warn about redundant constraints in a type
    signature. In particular:

    -  A redundant constraint within the type signature itself:

       ::

            f :: (Eq a, Ord a) => a -> a

       The warning will indicate the redundant ``Eq a`` constraint: it
       is subsumed by the ``Ord a`` constraint.

    -  A constraint in the type signature is not used in the code it
       covers:

       ::

            f :: Eq a => a -> a -> Bool
            f x y = True

       The warning will indicate the redundant ``Eq a`` constraint: : it
       is not used by the definition of ``f``.)

    Similar warnings are given for a redundant constraint in an instance
    declaration.

    This option is on by default. As usual you can suppress it on a
    per-module basis with ``-fno-warn-redundant-constraints``.
    Occasionally you may specifically want a function to have a more
    constrained signature than necessary, perhaps to leave yourself
    wiggle-room for changing the implementation without changing the
    API. In that case, you can suppress the warning on a per-function
    basis, using a call in a dead binding. For example:

    ::

        f :: Eq a => a -> a -> Bool
        f x y = True
        where
            _ = x == x  -- Suppress the redundant-constraint warning for (Eq a)

    Here the call to ``(==)`` makes GHC think that the ``(Eq a)``
    constraint is needed, so no warning is issued.

``-fwarn-duplicate-exports``
    .. index::
       single: -fwarn-duplicate-exports
       single: duplicate exports, warning
       single: export lists, duplicates

    Have the compiler warn about duplicate entries in export lists. This
    is useful information if you maintain large export lists, and want
    to avoid the continued export of a definition after you've deleted
    (one) mention of it in the export list.

    This option is on by default.

``-fwarn-hi-shadowing``
    .. index::
       single: -fwarn-hi-shadowing
       single: shadowing; interface files

    Causes the compiler to emit a warning when a module or interface
    file in the current directory is shadowing one with the same module
    name in a library or other directory.

``-fwarn-identities``
    .. index::
       single: -fwarn-identities

    Causes the compiler to emit a warning when a Prelude numeric
    conversion converts a type T to the same type T; such calls are
    probably no-ops and can be omitted. The functions checked for are:
    ``toInteger``, ``toRational``, ``fromIntegral``, and ``realToFrac``.

``-fwarn-implicit-prelude``
    .. index::
       single: -fwarn-implicit-prelude
       single: implicit prelude, warning

    Have the compiler warn if the Prelude is implicitly imported. This
    happens unless either the Prelude module is explicitly imported with
    an ``import ... Prelude ...`` line, or this implicit import is
    disabled (either by ``-XNoImplicitPrelude`` or a
    ``LANGUAGE NoImplicitPrelude`` pragma).

    Note that no warning is given for syntax that implicitly refers to
    the Prelude, even if ``-XNoImplicitPrelude`` would change whether it
    refers to the Prelude. For example, no warning is given when ``368``
    means ``Prelude.fromInteger (368::Prelude.Integer)`` (where
    ``Prelude`` refers to the actual Prelude module, regardless of the
    imports of the module being compiled).

    This warning is off by default.

``-fwarn-incomplete-patterns``, ``-fwarn-incomplete-uni-patterns``
    .. index::
       single: -fwarn-incomplete-patterns
       single: -fwarn-incomplete-uni-patterns
       single: incomplete patterns, warning
       single: patterns, incomplete

    The option ``-fwarn-incomplete-patterns`` warns about places where a
    pattern-match might fail at runtime. The function ``g`` below will
    fail when applied to non-empty lists, so the compiler will emit a
    warning about this when ``-fwarn-incomplete-patterns`` is enabled.

    ::

        g [] = 2

    This option isn't enabled by default because it can be a bit noisy,
    and it doesn't always indicate a bug in the program. However, it's
    generally considered good practice to cover all the cases in your
    functions, and it is switched on by ``-W``.

    The flag ``-fwarn-incomplete-uni-patterns`` is similar, except that
    it applies only to lambda-expressions and pattern bindings,
    constructs that only allow a single pattern:

    ::

        h = \[] -> 2
        Just k = f y

``-fwarn-incomplete-record-updates``
    .. index::
       single: -fwarn-incomplete-record-updates
       single: incomplete record updates, warning
       single: record updates, incomplete

    The function ``f`` below will fail when applied to ``Bar``, so the
    compiler will emit a warning about this when
    ``-fwarn-incomplete-record-updates`` is enabled.

    ::

        data Foo = Foo { x :: Int }
                 | Bar

        f :: Foo -> Foo
        f foo = foo { x = 6 }

    This option isn't enabled by default because it can be very noisy,
    and it often doesn't indicate a bug in the program.

``-fwarn-missing-fields``
    .. index::
       single: -fwarn-missing-fields
       single: missing fields, warning
       single: fields, missing

    This option is on by default, and warns you whenever the
    construction of a labelled field constructor isn't complete, missing
    initialisers for one or more fields. While not an error (the missing
    fields are initialised with bottoms), it is often an indication of a
    programmer error.

``-fwarn-missing-import-lists``
    .. index::
       single: -fwarn-import-lists
       single: missing import lists, warning
       single: import lists, missing

    This flag warns if you use an unqualified ``import`` declaration
    that does not explicitly list the entities brought into scope. For
    example

    ::

        module M where
          import X( f )
          import Y
          import qualified Z
          p x = f x x

    The ``-fwarn-import-lists`` flag will warn about the import of ``Y``
    but not ``X`` If module ``Y`` is later changed to export (say)
    ``f``, then the reference to ``f`` in ``M`` will become ambiguous.
    No warning is produced for the import of ``Z`` because extending
    ``Z``\'s exports would be unlikely to produce ambiguity in ``M``.

``-fwarn-missing-methods``
    .. index::
       single: -fwarn-missing-methods
       single: missing methods, warning
       single: methods, missing

    This option is on by default, and warns you whenever an instance
    declaration is missing one or more methods, and the corresponding
    class declaration has no default declaration for them.

    The warning is suppressed if the method name begins with an
    underscore. Here's an example where this is useful:

    ::

        class C a where
            _simpleFn :: a -> String
            complexFn :: a -> a -> String
            complexFn x y = ... _simpleFn ...

    The idea is that: (a) users of the class will only call
    ``complexFn``; never ``_simpleFn``; and (b) instance declarations
    can define either ``complexFn`` or ``_simpleFn``.

    The ``MINIMAL`` pragma can be used to change which combination of
    methods will be required for instances of a particular class. See
    :ref:`minimal-pragma`.

``-fwarn-missing-signatures``
    .. index::
       single: -fwarn-missing-signatures
       single: type signatures, missing

    If you would like GHC to check that every top-level function/value
    has a type signature, use the ``-fwarn-missing-signatures`` option.
    As part of the warning GHC also reports the inferred type. The
    option is off by default.

``-fwarn-missing-exported-sigs``
    .. index::
       single: -fwarn-missing-exported-sigs
       single: type signatures, missing

    If you would like GHC to check that every exported top-level
    function/value has a type signature, but not check unexported
    values, use the ``-fwarn-missing-exported-sigs`` option. This option
    takes precedence over ``-fwarn-missing-signatures``. As part of the
    warning GHC also reports the inferred type. The option is off by
    default.

``-fwarn-missing-local-sigs``
    .. index::
       single: -fwarn-missing-local-sigs
       single: type signatures, missing

    If you use the ``-fwarn-missing-local-sigs`` flag GHC will warn you
    about any polymorphic local bindings. As part of the warning GHC
    also reports the inferred type. The option is off by default.

``-fwarn-name-shadowing``
    .. index::
       single: -fwarn-name-shadowing
       single: shadowing, warning

    This option causes a warning to be emitted whenever an inner-scope
    value has the same name as an outer-scope value, i.e. the inner
    value shadows the outer one. This can catch typographical errors
    that turn into hard-to-find bugs, e.g., in the inadvertent capture
    of what would be a recursive call in
    ``f = ... let f = id in ... f ...``.

    The warning is suppressed for names beginning with an underscore.
    For example

    ::

        f x = do { _ignore <- this; _ignore <- that; return (the other) }

``-fwarn-orphans``
    .. index::
       single: -fwarn-orphans
       single: orphan instances, warning
       single: orphan rules, warning

    These flags cause a warning to be emitted whenever the module
    contains an "orphan" instance declaration or rewrite rule. An
    instance declaration is an orphan if it appears in a module in which
    neither the class nor the type being instanced are declared in the
    same module. A rule is an orphan if it is a rule for a function
    declared in another module. A module containing any orphans is
    called an orphan module.

    The trouble with orphans is that GHC must pro-actively read the
    interface files for all orphan modules, just in case their instances
    or rules play a role, whether or not the module's interface would
    otherwise be of any use. See :ref:`orphan-modules` for details.

    The flag ``-fwarn-orphans`` warns about user-written orphan rules or
    instances.

``-fwarn-overlapping-patterns``
    .. index::
       single: -fwarn-overlapping-patterns
       single: overlapping patterns, warning
       single: patterns, overlapping

    By default, the compiler will warn you if a set of patterns are
    overlapping, e.g.,

    ::

        f :: String -> Int
        f []     = 0
        f (_:xs) = 1
        f "2"    = 2

    where the last pattern match in ``f`` won't ever be reached, as the
    second pattern overlaps it. More often than not, redundant patterns
    is a programmer mistake/error, so this option is enabled by default.

``-fwarn-tabs``
    .. index::
       single: -fwarn-tabs
       single: tabs, warning

    Have the compiler warn if there are tabs in your source file.

``-fwarn-type-defaults``
    .. index::
       single: -fwarn-type-defaults
       single: defaulting mechanism, warning

    Have the compiler warn/inform you where in your source the Haskell
    defaulting mechanism for numeric types kicks in. This is useful
    information when converting code from a context that assumed one
    default into one with another, e.g., the ‘default default’ for
    Haskell 1.4 caused the otherwise unconstrained value ``1`` to be
    given the type ``Int``, whereas Haskell 98 and later defaults it to
    ``Integer``. This may lead to differences in performance and
    behaviour, hence the usefulness of being non-silent about this.

    This warning is off by default.

``-fwarn-monomorphism-restriction``
    .. index::
       single: -fwarn-monomorphism-restriction
       single: monomorphism restriction, warning

    Have the compiler warn/inform you where in your source the Haskell
    Monomorphism Restriction is applied. If applied silently the MR can
    give rise to unexpected behaviour, so it can be helpful to have an
    explicit warning that it is being applied.

    This warning is off by default.

``-fwarn-unticked-promoted-constructors``
    .. index::
       single: -fwarn-unticked-promoted-constructors
       single: promoted constructor, warning

    Warn if a promoted data constructor is used without a tick preceding
    its name.

    For example:

    ::

        data Nat = Succ Nat | Zero

        data Vec n s where
          Nil  :: Vec Zero a
          Cons :: a -> Vec n a -> Vec (Succ n) a

    Will raise two warnings because ``Zero`` and ``Succ`` are not
    written as ``'Zero`` and ``'Succ``.

    This warning is is enabled by default in ``-Wall`` mode.

``-fwarn-unused-binds``
    .. index::
       single: -fwarn-unused-binds
       single: unused binds, warning
       single: binds, unused

    Report any function definitions (and local bindings) which are
    unused. An alias for

    -  ``-fwarn-unused-top-binds``
    -  ``-fwarn-unused-local-binds``
    -  ``-fwarn-unused-pattern-binds``

``-fwarn-unused-top-binds``
    .. index::
       single: -fwarn-unused-top-binds
       single: unused binds, warning
       single: binds, unused

    Report any function definitions which are unused.

    More precisely, warn if a binding brings into scope a variable that
    is not used, except if the variable's name starts with an
    underscore. The "starts-with-underscore" condition provides a way to
    selectively disable the warning.

    A variable is regarded as "used" if

    -  It is exported, or

    -  It appears in the right hand side of a binding that binds at
       least one used variable that is used

    For example

    ::

        module A (f) where
        f = let (p,q) = rhs1 in t p  -- No warning: q is unused, but is locally bound
        t = rhs3                     -- No warning: f is used, and hence so is t
        g = h x                      -- Warning: g unused
        h = rhs2                     -- Warning: h is only used in the
                                     -- right-hand side of another unused binding
        _w = True                    -- No warning: _w starts with an underscore

``-fwarn-unused-local-binds``
    .. index::
       single: -fwarn-unused-local-binds
       single: unused binds, warning
       single: binds, unused

    Report any local definitions which are unused. For example

    ::

        module A (f) where
        f = let (p,q) = rhs1 in t p  -- Warning: q is unused
        g = h x                      -- No warning: g is unused, but is a top-level binding

``-fwarn-unused-pattern-binds``
    .. index::
       single: -fwarn-unused-pattern-binds
       single: unused binds, warning
       single: binds, unused

    Warn if a pattern binding binds no variables at all, unless it is a
    lone, possibly-banged, wild-card pattern. For example:

    ::

        Just _ = rhs3    -- Warning: unused pattern binding
        (_, _) = rhs4    -- Warning: unused pattern binding
        _  = rhs3        -- No warning: lone wild-card pattern
        !_ = rhs4        -- No warning: banged wild-card pattern; behaves like seq

    The motivation for allowing lone wild-card patterns is they are not
    very different from ``_v = rhs3``, which elicits no warning; and
    they can be useful to add a type constraint, e.g. ``_ = x::Int``. A
    lone banged wild-card pattern is useful as an alternative (to
    ``seq``) way to force evaluation.

``-fwarn-unused-imports``
    .. index::
       single: -fwarn-unused-imports
       single: unused imports, warning
       single: imports, unused

    Report any modules that are explicitly imported but never used.
    However, the form ``import M()`` is never reported as an unused
    import, because it is a useful idiom for importing instance
    declarations, which are anonymous in Haskell.

``-fwarn-unused-matches``
    .. index::
       single: -fwarn-unused-matches
       single: unused matches, warning
       single: matches, unused

    Report all unused variables which arise from pattern matches,
    including patterns consisting of a single variable. For instance
    ``f x y = []`` would report ``x`` and ``y`` as unused. The warning
    is suppressed if the variable name begins with an underscore, thus:

    ::

        f _x = True

``-fwarn-unused-do-bind``
    .. index::
       single: -fwarn-unused-do-bind
       single: unused do binding, warning
       single: do binding, unused

    Report expressions occurring in ``do`` and ``mdo`` blocks that
    appear to silently throw information away. For instance
    ``do { mapM popInt xs ; return 10 }`` would report the first
    statement in the ``do`` block as suspicious, as it has the type
    ``StackM [Int]`` and not ``StackM ()``, but that ``[Int]`` value is
    not bound to anything. The warning is suppressed by explicitly
    mentioning in the source code that your program is throwing
    something away:

    ::

        do { _ <- mapM popInt xs ; return 10 }

    Of course, in this particular situation you can do even better:

    ::

        do { mapM_ popInt xs ; return 10 }

``-fwarn-context-quantification``
    .. index::
       single: -fwarn-context-quantification
       single: implicit context quantification, warning
       single: context, implicit quantification

    Report if a variable is quantified only due to its presence in a
    context (see :ref:`universal-quantification`). For example,

    ::

        type T a = Monad m => a -> f a

    It is recommended to write this polymorphic type as

    ::

        type T a = forall m. Monad m => a -> f a

    instead.

``-fwarn-wrong-do-bind``
    .. index::
       single: -fwarn-wrong-do-bind
       single: apparently erroneous do binding, warning
       single: do binding, apparently erroneous

    Report expressions occurring in ``do`` and ``mdo`` blocks that
    appear to lack a binding. For instance
    ``do { return (popInt 10) ; return 10 }`` would report the first
    statement in the ``do`` block as suspicious, as it has the type
    ``StackM (StackM Int)`` (which consists of two nested applications
    of the same monad constructor), but which is not then "unpacked" by
    binding the result. The warning is suppressed by explicitly
    mentioning in the source code that your program is throwing
    something away:

    ::

        do { _ <- return (popInt 10) ; return 10 }

    For almost all sensible programs this will indicate a bug, and you
    probably intended to write:

    ::

        do { popInt 10 ; return 10 }

``-fwarn-inline-rule-shadowing``
    .. index::
       single: -fwarn-inline-rule-shadowing

    Warn if a rewrite RULE might fail to fire because the function might
    be inlined before the rule has a chance to fire. See
    :ref:`rules-inline`.

If you're feeling really paranoid, the ``-dcore-lint`` option is a good choice.
It turns on heavyweight intra-pass sanity-checking within GHC. (It checks GHC's
sanity, not yours.)