Unused warnings: for macros, by default, look for usages in expansion #10693
+233
−26
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
By default,
-Wunused
can be satisfied by a usage introduced by a macro expansion.This is the revised behavior under
-Wmacros:default
. Previously, the default setting was-Wmacros:before
, to lint only before any macros are expanded. The new behavior may reduce the need to suppress warnings.Previously,
-Wmacros:after
could be used to lint only the expansion, but if the expansion introduces more unused definitions, then those will generate warnings under that mode.Note that linting the macro expansion will also warn for
-Xlint:missing-interpolator
, since 2.13.14. Macros for test assertions that capture interpolations as regular string literals will warn. For example, if a macro transformsinto
Fixes scala/bug#12953