io.shiftleft.codepropertygraph.generated.nodes.Finding.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of codepropertygraph-domain-classes_3 Show documentation
Show all versions of codepropertygraph-domain-classes_3 Show documentation
codepropertygraph-domain-classes
The newest version!
package io.shiftleft.codepropertygraph.generated.nodes
import io.shiftleft.codepropertygraph.generated.language.*
import scala.collection.immutable.{IndexedSeq, ArraySeq}
import scala.collection.mutable
/** Node base type for compiletime-only checks to improve type safety. EMT stands for: "erased marker trait", i.e. it is
* erased at runtime
*/
trait FindingEMT extends AnyRef
trait FindingBase extends AbstractNode with StaticType[FindingEMT] {
def evidence: IndexedSeq[AbstractNode]
def keyValuePairs: IndexedSeq[KeyValuePairBase]
override def propertiesMap: java.util.Map[String, Any] = {
import io.shiftleft.codepropertygraph.generated.accessors.languagebootstrap.*
val res = new java.util.HashMap[String, Any]()
val tmpevidence = this.evidence; if (tmpevidence.nonEmpty) res.put("evidence", tmpevidence)
val tmpkeyValuePairs = this.keyValuePairs; if (tmpkeyValuePairs.nonEmpty) res.put("keyValuePairs", tmpkeyValuePairs)
res
}
}
object Finding {
val Label = "FINDING"
object PropertyNames {
val Evidence = "evidence"
val Keyvaluepairs = "keyValuePairs"
}
object Properties {}
object PropertyDefaults {}
}
class Finding(graph_4762: flatgraph.Graph, seq_4762: Int)
extends StoredNode(graph_4762, 15.toShort, seq_4762)
with FindingBase
with StaticType[FindingEMT] {
def evidence: IndexedSeq[StoredNode] = flatgraph.Accessors.getNodePropertyMulti[StoredNode](graph, nodeKind, 55, seq)
def keyValuePairs: IndexedSeq[KeyValuePair] =
flatgraph.Accessors.getNodePropertyMulti[KeyValuePair](graph, nodeKind, 56, seq)
override def productElementName(n: Int): String =
n match {
case 0 => "evidence"
case 1 => "keyValuePairs"
case _ => ""
}
override def productElement(n: Int): Any =
n match {
case 0 => this.evidence
case 1 => this.keyValuePairs
case _ => null
}
override def productPrefix = "Finding"
override def productArity = 2
override def canEqual(that: Any): Boolean = that != null && that.isInstanceOf[Finding]
}
object NewFinding {
def apply(): NewFinding = new NewFinding
private val outNeighbors: Map[String, Set[String]] = Map()
private val inNeighbors: Map[String, Set[String]] = Map()
object InsertionHelpers {
object NewNodeInserter_Finding_evidence extends flatgraph.NewNodePropertyInsertionHelper {
override def insertNewNodeProperties(
newNodes: mutable.ArrayBuffer[flatgraph.DNode],
dst: AnyRef,
offsets: Array[Int]
): Unit = {
if (newNodes.isEmpty) return
val dstCast = dst.asInstanceOf[Array[flatgraph.GNode]]
val seq = newNodes.head.storedRef.get.seq()
var offset = offsets(seq)
var idx = 0
while (idx < newNodes.length) {
val nn = newNodes(idx)
nn match {
case generated: NewFinding =>
for (item <- generated.evidence) {
dstCast(offset) = item match {
case newV: flatgraph.DNode => newV.storedRef.get; case oldV: flatgraph.GNode => oldV;
case null => null
}
offset += 1
}
case _ =>
}
assert(seq + idx == nn.storedRef.get.seq(), "internal consistency check")
idx += 1
offsets(idx + seq) = offset
}
}
}
object NewNodeInserter_Finding_keyValuePairs extends flatgraph.NewNodePropertyInsertionHelper {
override def insertNewNodeProperties(
newNodes: mutable.ArrayBuffer[flatgraph.DNode],
dst: AnyRef,
offsets: Array[Int]
): Unit = {
if (newNodes.isEmpty) return
val dstCast = dst.asInstanceOf[Array[flatgraph.GNode]]
val seq = newNodes.head.storedRef.get.seq()
var offset = offsets(seq)
var idx = 0
while (idx < newNodes.length) {
val nn = newNodes(idx)
nn match {
case generated: NewFinding =>
for (item <- generated.keyValuePairs) {
dstCast(offset) = item match {
case newV: flatgraph.DNode => newV.storedRef.get; case oldV: flatgraph.GNode => oldV;
case null => null
}
offset += 1
}
case _ =>
}
assert(seq + idx == nn.storedRef.get.seq(), "internal consistency check")
idx += 1
offsets(idx + seq) = offset
}
}
}
}
}
class NewFinding extends NewNode(15.toShort) with FindingBase {
override type StoredNodeType = Finding
override def label: String = "FINDING"
override def isValidOutNeighbor(edgeLabel: String, n: NewNode): Boolean = {
NewFinding.outNeighbors.getOrElse(edgeLabel, Set.empty).contains(n.label)
}
override def isValidInNeighbor(edgeLabel: String, n: NewNode): Boolean = {
NewFinding.inNeighbors.getOrElse(edgeLabel, Set.empty).contains(n.label)
}
var evidence: IndexedSeq[AbstractNode] = ArraySeq.empty
var keyValuePairs: IndexedSeq[KeyValuePairBase] = ArraySeq.empty
def evidence(value: IterableOnce[AbstractNode]): this.type = { this.evidence = value.iterator.to(ArraySeq); this }
def keyValuePairs(value: IterableOnce[KeyValuePairBase]): this.type = {
this.keyValuePairs = value.iterator.to(ArraySeq); this
}
override def countAndVisitProperties(interface: flatgraph.BatchedUpdateInterface): Unit = {
interface.countProperty(this, 55, evidence.size)
evidence.foreach(interface.visitContainedNode)
interface.countProperty(this, 56, keyValuePairs.size)
keyValuePairs.foreach(interface.visitContainedNode)
}
override def copy: this.type = {
val newInstance = new NewFinding
newInstance.evidence = this.evidence
newInstance.keyValuePairs = this.keyValuePairs
newInstance.asInstanceOf[this.type]
}
override def productElementName(n: Int): String =
n match {
case 0 => "evidence"
case 1 => "keyValuePairs"
case _ => ""
}
override def productElement(n: Int): Any =
n match {
case 0 => this.evidence
case 1 => this.keyValuePairs
case _ => null
}
override def productPrefix = "NewFinding"
override def productArity = 2
override def canEqual(that: Any): Boolean = that != null && that.isInstanceOf[NewFinding]
}