-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Record failures to adapt application arguments (#18269)
In tests/pos/i18163.scala, we don't want the ambiguous implicit of `Inv[J]` to cause the selection of `LogOps` to fail. The logic is there because it think the user's implicits "seem to be used to implement a local failure in order to negate an implicit search". But that's not the case here. The regular arguments aren't correct to start with (type kindness error), so we shouldn't even get to the implicit search and ambiguity.
- Loading branch information
Showing
17 changed files
with
105 additions
and
24 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,19 @@ | ||
-- [E007] Type Mismatch Error: tests/neg-macros/i16522.scala:10:45 ----------------------------------------------------- | ||
10 | case '{HCons($h1: hd1, HCons($h2: hd2, $_ : tl))} => '{$h1.toString ++ $h2.toString} // error | ||
10 | case '{HCons($h1: hd1, HCons($h2: hd2, $_ : tl))} => '{$h1.toString ++ $h2.toString} // error // error // error | ||
| ^^^^^^^ | ||
| Found: tl | ||
| Required: HList | ||
| | ||
| longer explanation available when compiling with `-explain` | ||
-- [E006] Not Found Error: tests/neg-macros/i16522.scala:10:62 --------------------------------------------------------- | ||
10 | case '{HCons($h1: hd1, HCons($h2: hd2, $_ : tl))} => '{$h1.toString ++ $h2.toString} // error // error // error | ||
| ^^ | ||
| Not found: h1 | ||
| | ||
| longer explanation available when compiling with `-explain` | ||
-- [E006] Not Found Error: tests/neg-macros/i16522.scala:10:78 --------------------------------------------------------- | ||
10 | case '{HCons($h1: hd1, HCons($h2: hd2, $_ : tl))} => '{$h1.toString ++ $h2.toString} // error // error // error | ||
| ^^ | ||
| Not found: h2 | ||
| | ||
| longer explanation available when compiling with `-explain` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -58,5 +58,5 @@ object Test2: | |
def foo5(x: Int) = | ||
foo2(foo2(,) // error // error | ||
|
||
println(bam) // error | ||
println(bam) | ||
// error |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
import scala.language.implicitConversions | ||
|
||
// We do have 2 `contramap` functions, one provided via `LoggerSyntax` other via `Contravariant.Ops` | ||
// `ContravariantMonoidal` given instances are not used, and they do not match our type. Code fails when we have at least 2 instances of them | ||
// Removal of `import catsSyntax._` allow to compile code | ||
// Removal of `import odinSyntax.LoggerSyntax` and remaining `catsSyntax` would fail to compile the `def fails` | ||
|
||
trait Foo[A] | ||
trait Bar[A] | ||
|
||
trait WriterT[F[_]: Contravariant, L, V]: | ||
def contramap[Z](fn: Z => V): WriterT[F, L, Z] = ??? | ||
trait Logger[F[_]] | ||
class WriterTLogger[F[_]] extends Logger[[G] =>> WriterT[F, List[String], G]] | ||
|
||
trait ContravariantMonoidal[F[_]] extends Invariant[F] with Contravariant[F] | ||
trait Invariant[F[_]] | ||
object Invariant: | ||
given ContravariantMonoidal[Foo] = ??? | ||
given ContravariantMonoidal[Bar] = ??? | ||
|
||
trait Contravariant[F[_]] extends Invariant[F] | ||
object Contravariant: | ||
trait Ops[F[_], A]: | ||
def contramap[B](f: B => A): F[B] = ??? | ||
|
||
object catsSyntax: | ||
implicit def toContravariantOps[F[_]: Contravariant, A](target: F[A]): Contravariant.Ops[F, A] = ??? | ||
|
||
object odinSyntax: | ||
implicit class LoggerSyntax[F[_]](logger: Logger[F]): | ||
def contramap(f: String => String): Logger[F] = ??? | ||
|
||
import catsSyntax._ | ||
import odinSyntax.LoggerSyntax | ||
|
||
class Test: | ||
def fails = new WriterTLogger[Option].contramap(identity) | ||
def works = LoggerSyntax(new WriterTLogger[Option]).contramap(identity) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import scala.language.implicitConversions | ||
|
||
trait Foo[A] | ||
trait Bar[B] | ||
trait Qux[C] | ||
class Log[K[_]] | ||
|
||
trait Inv[F[_]] | ||
object Inv: | ||
given monFoo: Inv[Foo] = ??? | ||
given monBar: Inv[Bar] = ??? | ||
|
||
trait InvOps[H[_], D] { def desc(s: String): H[D] = ??? } | ||
trait LogOps[L[_]] { def desc(s: String): Log[L] = ??? } | ||
|
||
class Test: | ||
implicit def LogOps[Q[_]](l: Log[Q]): LogOps[Q] = ??? | ||
implicit def InvOps[J[_], E](j11: J[E])(implicit z: Inv[J]): InvOps[J, E] = ??? | ||
|
||
def fails = new Log[Qux].desc("fails") | ||
def works = LogOps[Qux](new Log[Qux]).desc("works") |