
org.opencypher.v9_0.expressions.Parameter.scala Maven / Gradle / Ivy
The newest version!
/*
* Copyright (c) Neo4j Sweden AB (http://neo4j.com)
*
* 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 org.opencypher.v9_0.expressions
import org.opencypher.v9_0.util.InputPosition
import org.opencypher.v9_0.util.symbols.CypherType
import scala.util.hashing.MurmurHash3
sealed trait Parameter extends Expression {
def name: String
def parameterType: CypherType
override def asCanonicalStringVal: String = "$" + name
//NOTE: hashCode and equals must be same for different parameter types, since we
//we auto parameterize for efficent cache utilization
override def hashCode(): Int = MurmurHash3.arrayHash(Array(name, parameterType))
override def equals(obj: Any): Boolean = obj match {
case p: Parameter => name == p.name && parameterType == p.parameterType
case _ => false
}
}
object Parameter {
def unapply(p: Parameter): Option[(String, CypherType)] = Some((p.name, p.parameterType))
def apply(name: String,
parameterType: CypherType)(position: InputPosition): Parameter = ExplicitParameter(name, parameterType)(position)
}
case class ExplicitParameter(name: String,
parameterType: CypherType)(val position: InputPosition) extends Parameter {
override def canEqual(that: Any): Boolean = that.isInstanceOf[Parameter]
override def equals(obj: Any): Boolean = super.equals(obj)
}
case class ListOfLiteralWriter(literals: Seq[Literal]) extends LiteralWriter {
override def writeTo(literalExtractor: LiteralExtractor): Unit = {
literalExtractor.beginList(literals.size)
literals.foreach(_.writeTo(literalExtractor))
literalExtractor.endList()
}
}
case class AutoExtractedParameter(name: String,
parameterType: CypherType,
writer: LiteralWriter)(val position: InputPosition) extends Parameter {
def writeTo(literalExtractor: LiteralExtractor): Unit = writer.writeTo(literalExtractor)
override def canEqual(that: Any): Boolean = that.isInstanceOf[Parameter]
override def equals(obj: Any): Boolean = super.equals(obj)
}
trait SensitiveParameter {
val name: String
val position: InputPosition
}
trait SensitiveAutoParameter extends SensitiveParameter
case class ParameterWithOldSyntax(name: String,
parameterType: CypherType)(val position: InputPosition)
extends Parameter
© 2015 - 2025 Weber Informatics LLC | Privacy Policy