
quasar.planner.scala Maven / Gradle / Ivy
/*
* Copyright 2014–2016 SlamData Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package quasar
import quasar.Predef._
import quasar.fp._
import quasar.fs.PathError
import matryoshka._
import scalaz._, Scalaz._
object Planner {
sealed trait PlannerError {
def message: String
}
final case class NonRepresentableData(data: Data) extends PlannerError {
def message = "The back-end has no representation for the constant: " + data
}
final case class UnsupportedFunction(name: String, hint: Option[String]) extends PlannerError {
def message = "The function '" + name + "' is recognized but not supported by this back-end." + hint.map(" (" + _ + ")").getOrElse("")
}
final case class PlanPathError(error: PathError) extends PlannerError {
def message = error.shows
}
final case class UnsupportedJoinCondition(cond: Fix[LogicalPlan]) extends PlannerError {
def message = "Joining with " + cond + " is not currently supported"
}
final case class UnsupportedPlan(plan: LogicalPlan[_], hint: Option[String]) extends PlannerError {
def message = "The back-end has no or no efficient means of implementing the plan" + hint.map(" (" + _ + ")").getOrElse("")+ ": " + plan
}
final case class FuncApply(name: String, expected: String, actual: String) extends PlannerError {
def message = "A parameter passed to function " + name + " is invalid: Expected " + expected + " but found: " + actual
}
final case class ObjectIdFormatError(str: String) extends PlannerError {
def message = "Invalid ObjectId string: " + str
}
final case class NonRepresentableInJS(value: String) extends PlannerError {
def message = "Operation/value could not be compiled to JavaScript: " + value
}
final case class UnsupportedJS(value: String) extends PlannerError {
def message = "Conversion of operation/value to JavaScript not implemented: " + value
}
final case class InternalError(message: String) extends PlannerError
implicit val PlannerErrorRenderTree: RenderTree[PlannerError] = new RenderTree[PlannerError] {
def render(v: PlannerError) = Terminal(List("Error"), Some(v.message))
}
implicit val plannerErrorShow: Show[PlannerError] =
Show.show(_.message)
sealed trait CompilationError {
def message: String
}
object CompilationError {
final case class CompilePathError(error: PathError)
extends CompilationError {
def message = error.shows
}
final case class CSemanticError(error: SemanticError)
extends CompilationError {
def message = error.message
}
final case class CPlannerError(error: PlannerError)
extends CompilationError {
def message = error.message
}
final case class ManyErrors(errors: NonEmptyList[SemanticError])
extends CompilationError {
def message = errors.map(_.message).list.toList.mkString("[", "\n", "]")
}
}
object CompilePathError {
def apply(error: PathError): CompilationError =
CompilationError.CompilePathError(error)
def unapply(obj: CompilationError): Option[PathError] = obj match {
case CompilationError.CompilePathError(error) => Some(error)
case _ => None
}
}
object CSemanticError {
def apply(error: SemanticError): CompilationError = CompilationError.CSemanticError(error)
def unapply(obj: CompilationError): Option[SemanticError] = obj match {
case CompilationError.CSemanticError(error) => Some(error)
case _ => None
}
}
object CPlannerError {
def apply(error: PlannerError): CompilationError = CompilationError.CPlannerError(error)
def unapply(obj: CompilationError): Option[PlannerError] = obj match {
case CompilationError.CPlannerError(error) => Some(error)
case _ => None
}
}
object ManyErrors {
def apply(error: NonEmptyList[SemanticError]): CompilationError = CompilationError.ManyErrors(error)
def unapply(obj: CompilationError): Option[NonEmptyList[SemanticError]] = obj match {
case CompilationError.ManyErrors(error) => Some(error)
case _ => None
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy