макрос не был расширен - Circe макрос - решение уже найдено - PullRequest
0 голосов
/ 27 января 2019

В этой строке я получаю ошибку компилятора:

macro has not been expanded.

Вот фрагмент кода:

package app.client.rest.commands.generalCRUD

import app.shared.data.model.Entity.{Data, Entity}
import app.shared.data.model.{DataType, LineText, User}
import app.shared.data.ref.{Ref, RefDyn, RefVal, RefValDyn}
import app.shared.rest.routes.crudRequests.GetEntityRequest
//import app.shared.rest.routes.crudRequests.GetEntityRequest.GetEntityReqResult
import app.shared.{SomeError_Trait, TypeError}
import io.circe
import io.circe.Decoder
import io.circe.generic.auto._
import io.circe.parser.decode
import org.scalajs.dom.ext.Ajax

import scala.concurrent.Future
import scala.reflect.ClassTag
import scalaz.\/

object GetEntityAJAX {


  import scala.scalajs.concurrent.JSExecutionContext.Implicits.queue

  def getEntity[E <: Entity : ClassTag ](ref: Ref[E])(implicit d:Decoder[RefVal[E]]):
  Future[RefVal[E]] = {
    import scala.scalajs.concurrent.JSExecutionContext.Implicits.queue
    val route: String =GetEntityRequest.queryURL(ref)

//    val route: String = ???

    val res: Future[RefVal[E]] = Ajax
                                 .get( route )
                                 .map( _.responseText )
                                 .map( decode ) <======= COMPILER ERROR - MACRO NOT EXPANDED 
                                 .map((x: Either[circe.Error, RefVal[E]]) => x.right.get) //backlog
//    .map( x:RefVal[E] => GetEntityReqResult[E] )
    ??? //todo
    res
  }

}

1 Ответ

0 голосов
/ 28 января 2019

Для записи я нашел решение:

  import scala.scalajs.concurrent.JSExecutionContext.Implicits.queue

  def getEntity[E <: Entity : ClassTag ](ref: Ref[E])(implicit d:Decoder[RefVal[E]]):
  Future[RefVal[E]] = {
    import scala.scalajs.concurrent.JSExecutionContext.Implicits.queue
    val route: String =GetEntityRequest.queryURL(ref)

//    val route: String = ???

    def dd(s:String) : Either[circe.Error, RefVal[E]]= decode(s)

    val res: Future[RefVal[E]] = Ajax
                                 .get( route )
                                 .map( _.responseText )
                                 .map( x=>dd(x) )
                                 .map((x: Either[circe.Error, RefVal[E]]) => x.right.get) //backlog
//    .map( x:RefVal[E] => GetEntityReqResult[E] )
    ??? //todo
    res
  }
...