I have a type class
trait ResponseHandler[+A, -B[_]] {
def handle[C](response: WSResponse, parser: A => B[C]): HTTPCallResult[C]
}
and its instance
type Identity[X] = X
implicit object JsonResponseHandler extends ResponseHandler[JsValue, Identity] {
def handle[C](response: WSResponse, parser: JsValue => C): HTTPCallResult[C] = {
// implementation
}
}
When calling function
post[A, In, Out[_]](parser: In => Out[A])(implicit handler: ResponseHandler[In, Out]) = {
// implementation
}
like this
post { resp: WSResponse =>
resp.body == "alive"
}
it throws a compile time error
[error] no type parameters for method post: (parser: In => Out[A])(implicit handler: ResponseHandler[In,Out]) exist so that it can be applied to arguments (WSResponse => Boolean)
[error] --- because ---
[error] argument expression's type is not compatible with formal parameter type;
[error] found : WSResponse => Boolean
[error] required: ?In => ?Out[?A]
[error] .post { resp: WSResponse =>
[error] ^
[error] type mismatch;
[error] found : play.api.libs.ws.WSResponse => Boolean
[error] required: In => Out[A]
[error] .post { resp: WSResponse =>
[error] ^
[error] ambiguous implicit values:
[error] both object WSResponseHandler in object ResponseHandler of type
[error] ResponseHandler.WSResponseHandler.type
[error] and object WSResponseWithErrorsHandler in object ResponseHandler of type ResponseHandler.WSResponseWithErrorsHandler.type
[error] match expected type ResponseHandler[Any,Out]
[error] .post { resp: WSResponse =>
[error] ^
[error] three errors found
However, when called like this
import ResponseHandler.Identity
post { resp: WSResponse =>
(resp.body == "alive").asInstanceOf[Identity[Boolean]]
}
it works. Is it possible to somehow help compiler infer the type? I tried def getIdtentity[A](a: A): Identity[A] = a.asInstanceOf[Identity[A]], but it didn't work.
Try
This should help to infer types.
The order of implicits
handler,evis significant.Other options: