我在Play
,Silhouette
,Cassandra
应用
class UsersRepository needs to be abstract, since: it has 6 unimplemented members.
/** As seen from class UsersRepository, the missing signatures are as follows. * For convenience, these are usable as stub implementations. */ // Members declared in com.mohiva.play.silhouette.api.repositories.AuthInfoRepository
def add[T <: com.mohiva.play.silhouette.api.AuthInfo](loginInfo: com.mohiva.play.silhouette.api.LoginInfo,authInfo: T): scala.concurrent.Future[T] = ???
def find[T <: com.mohiva.play.silhouette.api.AuthInfo](loginInfo: com.mohiva.play.silhouette.api.LoginInfo)(implicit tag: scala.reflect.ClassTag[T]): scala.concurrent.Future[Option[T]] = ???
def remove[T <: com.mohiva.play.silhouette.api.AuthInfo](loginInfo: com.mohiva.play.silhouette.api.LoginInfo)(implicit tag: scala.reflect.ClassTag[T]): scala.concurrent.Future[Unit] = ???
def save[T <: com.mohiva.play.silhouette.api.AuthInfo](loginInfo: com.mohiva.play.silhouette.api.LoginInfo,authInfo: T): scala.concurrent.Future[T] = ???
def update[T <: com.mohiva.play.silhouette.api.AuthInfo](loginInfo: com.mohiva.play.silhouette.api.LoginInfo,authInfo: T): scala.concurrent.Future[T] = ???
但是,在同一个文件中,我实现了它们
class UsersRepository(session: Session)
extends CassandraRepository[UserKeys,User](session, "users", List("bucket","email")) with UserDao with AuthInfoRepository {
def find(loginInfo:LoginInfo):Future[Option[PasswordInfo]] = Future {
... }
def add(loginInfo:LoginInfo, authInfo:PasswordInfo):Future[PasswordInfo] = Future {
...
}
def update(loginInfo:LoginInfo, authInfo:PasswordInfo):Future[PasswordInfo] = {
add(..)//add returns a Future
...}
def save(loginInfo:LoginInfo, authInfo:PasswordInfo):Future[PasswordInfo] = {
add(..)//add returns a Future
}
def remove(loginInfo:LoginInfo):Future[Unit] = Future{
...
}
}
我做错了什么?
答案 0 :(得分:0)
嗯,你实际上并没有覆盖它们:
def add[T <: AuthInfo](
loginInfo: LoginInfo,
authInfo: T
): Future[T]
VS
def add(
loginInfo:LoginInfo,
authInfo: PasswordInfo
):Future[PasswordInfo]
前者采用任何可以是AuthInfo
的实例,后者是一个非常具体的案例,它正好是PasswordInfo
。
当您将OOP混入其中时,例如转发到父接口,专门化可能实际上不明显,编译器将不得不使用通用(未实现)方法。
在这种情况下,添加override
关键字更安全,并确保您实际上覆盖了???
实施。