Comments (6)
OK, let's close this for now 👍
from sbt-tpolecat.
Ah I wasn't aware of this flag, this is a great idea - my only question is whether it would be problematic to cause warnings in expanded macros since users cannot do anything about it? Perhaps -Wwarn-macros:none might be the best choice?
from sbt-tpolecat.
That would not solve the first problem and would add extra problems.
The original problem is something like this:
import io.circe.Encoder
import io.circe.generic.semiauto.deriveEncoder
import io.circe.syntax._
final case class A(i: Int)
final case class B(name: String, a: A)
implicit val AEncoder: Encoder[A] = deriveEncoder
implicit val BEncoder: Encoder[B] = deriveEncoder
B(name = "Test", a = A(i = 10)).asJson.noSpaces
If you compile this snippet with the plugin. You would get an unused value warning for AEncoder
which will be turn on an error. Thus, it would not compile.
The problem is that AEncoder
is only used for the derivation of BEncoder
, which happens inside a macro, that has not being expanded when the unused analysis is executed.
To solve it, you would have to manually add the -Ywarn-macros:after flag. So the check for unused values is executed after the macros had been expanded.
As far as I know, this should not cause problems to final users, unless the macro is leaving unused values (I would hope that is uncommon). The only downside I see is, slower compilation times.
As I already said -Ywarn-macros:none would not only not solve this problems, but cause more.
Consider this code:
import com.typesafe.scalalogging.StrictLogging
object Main extends App with StrictLogging {
val testMessage = "Hello, World!"
logger.info(testMessage)
}
Since testMessage
is only used inside the logger.info
method, which is in turn a macro, it would be marked as an unused value.
from sbt-tpolecat.
It seems there are good reasons (at least from a theoretical point of view) for leaving before as the default.
from sbt-tpolecat.
In that case perhaps we should leave it as -Wmacros:before until such time as there is a -Wmacros:either option, which sounds like it would be the most ideal option here?
from sbt-tpolecat.
@DavidGregory084 I think the better is to just leave it as it is right now. That way if a user needs it, he / she can just add the setting explicitly.
I may be nice if the plugin offers some way to activate / deactivate this one.
Maybe something like: warnAfterMacros in tpolecat := true
but I am not sure how much of an improvement that would be.
(unless a similar flag is also added for #10 then it would be worth adding this)
from sbt-tpolecat.
Related Issues (20)
- Scala.js options overwritten on Scala 3 HOT 8
- Extract settings DSL into a library HOT 1
- Error when enabling scalafix in multi project build on versions > 0.3.1 HOT 4
- Is it possible to disable the unused warnings for generated src code in `target/src_manged`? HOT 7
- warnUnused is reporting on Assertions HOT 17
- Warn unused is reporting on XML literals HOT 3
- Set every tpolecatOptionsMode with tpolecatDevMode
- `-source` choices passed to scalac 3.* via space instead of colon and gets ignored. HOT 1
- New linting options for 3.3.0 HOT 1
- Change modes in intellij HOT 2
- Support `safe-init` in Scala 3
- warnNonUnitStatement has no effect in Scala 3.3.x HOT 1
- Scala 3's -Yexplicit-nulls HOT 5
- Consider verbose warnings
- `-Wnonunit-statement` seems not to work for scala-3 (3.3.3) HOT 3
- @nowarn annotations behavior change between 0.5.0 and 0.5.1 HOT 3
- Options for implicit conversions
- Add `-language:noAutoTupling` in Scala 3
- Write a Scalafix migration to migrate usages of the old package name
- Add this project to Typelevel Steward's repo list
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from sbt-tpolecat.