Next: Verbosity options, Previous: Invocation overview, Up: Invocation [Contents][Index]
-w
--inhibit-warnings
Disable all warning messages.
--inhibit-style-warnings
Disable all warning messages about programming style.
--halt-at-warn
This option causes the compiler to treat all warnings as if they were errors when generating target code. This means that if the compiler issues any warning, it will not generate target code — instead, it will return a non-zero exit status.
--halt-at-warn-make-int
--halt-at-warn-make-interface
This option causes the compiler to treat all warnings as if they were errors when generating an interface file (a ‘.int’, ‘.int0’, ‘.int2’ or ‘.int3’ file). This means that if the compiler issues any warnings at that time, it will not generate the interface file — instead, it will return a non-zero exit status.
--halt-at-warn-make-opt
This option causes the compiler to treat all warnings as if they were errors when generating an optimization file (a ‘.opt’ or ‘.trans_opt’ file). This means that if the compiler issues any warnings at that time, it will not generate the optimization file — instead, it will return a non-zero exit status.
--halt-at-syntax-error
This option causes the compiler to halt immediately after syntax checking and not do any semantic checking if it finds any syntax errors in the program.
--no-halt-at-invalid-interface
This option operates when the compiler is invoked with the –make–interface option to generate .int and .int2 files for one or more modules. In its default setting, ‘--halt-at-invalid-interface’, it causes the compiler to check the consistency of those parts of each of those modules that are intended to end up in the .int and .int2 files. If these checks find any problems, the compiler will stop without generating those files after printing an error message for each problem.
Users can prevent this behavior, and thus allow the generation of invalid interface files, by specifying ‘--no-halt-at-invalid-interface’.
--no-warn-accumulator-swaps
Do not warn about argument order rearrangement caused by ‘--introduce-accumulators’.
--no-warn-singleton-vars
--no-warn-singleton-variables
Do not warn about variables which only occur once, despite their names not starting with an underscore.
--no-warn-repeated-singleton-vars
--no-warn-repeated-singleton-variables
Do not warn about variables which occur more than once, despite their names starting with an underscore.
--no-warn-missing-det-decls
For predicates that are local to a module (those that are not exported), don’t issue a warning if the ‘pred’ or ‘mode’ declaration does not have a determinism annotation. Use this option if you want the compiler to perform automatic determinism inference for non-exported predicates.
--no-warn-det-decls-too-lax
Do not warn about determinism declarations which could have been stricter.
--no-warn-inferred-erroneous
Do not warn about procedures whose determinism is inferred erroneous but whose determinism declarations are laxer.
--no-warn-insts-without-matching-type
Do not warn about insts that are not consistent with any types in scope.
--warn-insts-with-functors-without-type
Warn about insts that do specify functors but do not specify what type they are for.
--warn-unused-imports
Warn about modules that are imported but not used.
--no-warn-nothing-exported
Do not warn about modules whose interface sections have no exported predicates, functions, insts, modes or types.
--warn-unused-args
Warn about predicate or function arguments which are not used.
--no-warn-interface-imports
Do not warn about modules imported in the interface which are not used in the interface.
--warn-interface-imports-in-parents
Warn about modules imported in the interface a parent module which are not used in the interface of that module.
--warn-missing-opt-files
Warn about ‘.opt’ files that cannot be opened.
--warn-missing-trans-opt-files
Warn about ‘.trans_opt’ files that cannot be opened.
--warn-inconsistent-pred-order
--warn-inconsistent-pred-order-clauses
Generate a warning if the order of the definitions does not match the order of the declarations for either the exported predicates and functions of the module, or for the nonexported predicates and functions of the module. Applies for definitions by Mercury clauses.
--warn-inconsistent-pred-order-foreign-procs
Generate a warning if the order of the definitions does not match the order of the declarations for either the exported predicates and functions of the module, or for the nonexported predicates and functions of the module. Applies for definitions by either Mercury clauses or foreign_proc pragmas.
--no-warn-non-contiguous-decls
Do not generate a warning if the mode declarations of a predicate or function don’t all immediately follow its predicate or function declaration.
--no-warn-non-contiguous-clauses
Do not generate a warning if the clauses of a predicate or function are not contiguous.
--warn-non-contiguous-foreign-procs
Generate a warning if the clauses and foreign_procs of a predicate or function are not contiguous.
--warn-non-stratification
Warn about possible non-stratification of the predicates and/or functions in the module. Non-stratification occurs when a predicate or function can call itself negatively through some path along its call graph.
--no-warn-simple-code
Disable warnings about constructs which are so simple that they are likely to be programming errors.
--warn-duplicate-calls
Warn about multiple calls to a predicate with the same input arguments.
--warn-implicit-stream-calls
Warn about calls to I/O predicates that could take explicit stream arguments, but do not do so.
--no-warn-missing-module-name
Disable warnings for modules that do not start with a ‘:- module’ declaration.
--no-warn-wrong-module-name
Disable warnings for modules whose ‘:- module’ declaration does not match the module’s file name.
--no-warn-smart-recompilation
Disable warnings from the smart recompilation system.
--no-warn-undefined-options-vars
--no-warn-undefined-options-variables
Do not warn about references to undefined variables in options files with ‘--make’.
--warn-suspicious-recursion
Warn about recursive calls which are likely to have problems, such as leading to infinite recursion.
--warn-non-tail-recursion type
Warn about any recursive calls that are not tail recursive. Implies the next two options. Warn about any recursive calls that are not tail recursive. type may be ‘self’, ‘self-and-mutual’ or ‘none’.
--warn-obvious-non-tail-recursion
Warn about recursive calls that are not tail calls even if they obviously cannot be tail calls, because they are followed by other recursive calls.
--no-warn-target-code
Disable warnings from the compiler used to process the target code (e.g. gcc).
--no-warn-up-to-date
Do not warn if targets specified on the command line with ‘--make’ are already up-to-date.
--no-warn-stubs
Disable warnings about procedures for which there are no clauses. Note that this option only has any effect if the ‘--allow-stubs’ option (see Language semantics options) is enabled.
--warn-dead-procs
--warn-dead-procedures
Warn about procedures which are never called.
--warn-dead-preds
--warn-dead-predicates
Warn about predicates that have no procedures which are ever called.
--no-warn-table-with-inline
Disable warnings about tabled procedures that also have a ‘pragma inline’ declaration.
--no-warn-non-term-special-preds
Do not warn about types that have user-defined equality or comparison predicates that cannot be proved to terminate. This option is only enabled when termination analysis is enabled. (See Termination analysis options for further details).
--no-warn-known-bad-format-calls
Do not warn about calls to string.format or io.format that the compiler knows for sure contain mismatches between the format string and the supplied values.
--no-warn-only-one-format-string-error
If a format string has more than one mismatch with the supplied values, generate a warning for all mismatches, not just the first. The later mismatches may be avalanche errors caused by earlier mismatches.
--warn-unknown-format-calls
Warn about calls to
string.format
, io.format
or stream.string_writer.format
for which the compiler cannot tell whether there are any mismatches
between the format string and the supplied values.
--no-warn-obsolete
Do not warn about calls to predicates or functions that have been marked as obsolete.
--inform-ite-instead-of-switch
Generate informational messages for if-then-elses that could be replaced by switches.
--inform-incomplete-switch
Generate informational messages for switches that do not cover all the function symbols that the switched-on variable could be bound to.
--inform-incomplete-switch-threshold n
–inform-incomplete-switch-threshold <N>
Have the --inform-incomplete-switch
option generate its messages
only for switches that do cover at least n percent of the function
symbols that the switched-on variable could be bound to.
--no-warn-unresolved-polymorphism
Do not warn about unresolved polymorphism.
--warn-suspicious-foreign-procs
Warn about possible errors in the bodies of foreign procedures.
When enabled, the compiler attempts to determine whether the success
indicator for a foreign procedure is correctly set, and whether
the foreign procedure body contains operations that are not allowed
(for example, return
statements in a C foreign procedure).
Note that since the compiler’s ability to parse foreign language code
is limited, some warnings reported by this option may be spurious, and
some actual errors may not be detected at all.
--warn-suspicious-foreign-code
Warn about possible errors in the bodies of foreign code pragmas. Note that since the compiler’s ability to parse foreign language code is limited, some warnings reported by this option may be spurious, and some actual errors may not be detected at all.
--no-warn-state-var-shadowing
Do not warn about one state variable shadowing another.
--no-warn-unneeded-mode-specific-clause
Do not warn about clauses that needlessly specify the modes of their arguments.
--no-warn-suspected-occurs-check-failure
Do not warn about code that looks like it unifies a variable with a term that contains that same variable. Such code cannot succeed because it fails what is called the ‘occurs check’.
--warn-potentially-ambiguous-pragma
Generate warnings for pragmas that do not specify whether they are for a predicate or a function.
--warn-ambiguous-pragma
Generate warnings for pragmas that do not specify whether they are for a predicate or a function, when there is both a predicate and a function with the given name and arity.
--no-inform-inferred
Do not generate messages about inferred types or modes.
--no-inform-inferred-types
Do not generate messages about inferred types.
--no-inform-inferred-modes
Do not generate messages about inferred modes.
--inform-suboptimal-packing
Generate messages if the arguments of a data constructor could be packed more tightly if they were reordered.
--no-warn-redundant-coerce
Do not warn about redundant type conversions, i.e. when the type of a ‘coerce’ expression is the same as the argument type.
--warn-can-fail-function
Warn about functions that can fail.
Next: Verbosity options, Previous: Invocation overview, Up: Invocation [Contents][Index]