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.