org.neo4j.cypher.internal.ir.CreatesPropertyKeys.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-cypher-ir Show documentation
Show all versions of neo4j-cypher-ir Show documentation
The intermediate representations, such as the query graph
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [https://neo4j.com]
*
* This file is part of Neo4j.
*
* Neo4j is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package org.neo4j.cypher.internal.ir
import org.neo4j.cypher.internal.expressions.Expression
import org.neo4j.cypher.internal.expressions.MapExpression
import org.neo4j.cypher.internal.expressions.PropertyKeyName
/*
* Used to simplify finding overlap between writing and reading properties
*/
sealed trait CreatesPropertyKeys {
def overlaps(propertyKeyName: PropertyKeyName): Boolean
def overlapsWithDynamicPropertyRead: Boolean = true
def overlapsWithFunctionPropertyRead: Boolean = true
def +(createsPropertyKeys: CreatesPropertyKeys): CreatesPropertyKeys
}
object CreatesPropertyKeys {
def apply(properties: Expression*): CreatesPropertyKeys = {
// CREATE ()
if (properties.isEmpty) CreatesNoPropertyKeys
else {
val knownProp: Seq[Seq[(PropertyKeyName, Expression)]] = properties.collect {
case MapExpression(props) => props
}
// all prop keys are known, CREATE ({prop1:1, prop2:2})
if (knownProp.size == properties.size) CreatesKnownPropertyKeys(knownProp.flatMap(_.map(s => s._1)).toSet)
// props created are not known, e.g. CREATE ({props})
else CreatesUnknownPropertyKeys
}
}
}
/*
* CREATE (a:L)
*/
case object CreatesNoPropertyKeys extends CreatesPropertyKeys {
override def overlaps(propertyKeyName: PropertyKeyName) = false
override def overlapsWithDynamicPropertyRead: Boolean = false
override def overlapsWithFunctionPropertyRead: Boolean = false
override def +(createsPropertyKeys: CreatesPropertyKeys) = createsPropertyKeys
}
/*
* CREATE ({prop1: 42, prop2: 42})
*/
case class CreatesKnownPropertyKeys(keys: Set[PropertyKeyName]) extends CreatesPropertyKeys {
override def overlaps(propertyKeyName: PropertyKeyName): Boolean = keys(propertyKeyName)
override def +(createsPropertyKeys: CreatesPropertyKeys) = createsPropertyKeys match {
case CreatesNoPropertyKeys => this
case CreatesKnownPropertyKeys(otherKeys) => CreatesKnownPropertyKeys(keys ++ otherKeys)
case CreatesUnknownPropertyKeys => CreatesUnknownPropertyKeys
}
}
object CreatesKnownPropertyKeys {
def apply(propertyKeyNames: PropertyKeyName*): CreatesKnownPropertyKeys =
CreatesKnownPropertyKeys(propertyKeyNames.toSet)
}
/*
* CREATE ({props})
*/
case object CreatesUnknownPropertyKeys extends CreatesPropertyKeys {
override def overlaps(propertyKeyName: PropertyKeyName) = true
override def +(createsPropertyKeys: CreatesPropertyKeys) = CreatesUnknownPropertyKeys
}