ValuesBackedNode.java
/*******************************************************************************
* Copyright (c) 2020 Eclipse RDF4J contributors.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*******************************************************************************/
package org.eclipse.rdf4j.sail.shacl.ast.planNodes;
import java.util.Iterator;
import java.util.List;
import java.util.Objects;
import java.util.SortedSet;
import java.util.stream.Collectors;
import org.apache.commons.text.StringEscapeUtils;
import org.eclipse.rdf4j.common.iteration.CloseableIteration;
import org.eclipse.rdf4j.model.Resource;
import org.eclipse.rdf4j.model.Value;
import org.eclipse.rdf4j.sail.shacl.ast.constraintcomponents.ConstraintComponent;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author H��vard Ottestad
*/
public class ValuesBackedNode implements PlanNode {
private static final Logger logger = LoggerFactory.getLogger(ValuesBackedNode.class);
private final SortedSet<Value> values;
private final List<ValidationTuple> tuples;
private final ConstraintComponent.Scope scope;
boolean printed = false;
private ValidationExecutionLogger validationExecutionLogger;
public ValuesBackedNode(SortedSet<Value> values, ConstraintComponent.Scope scope, Resource[] dataGraph) {
this.tuples = values.stream()
.map(c -> new ValidationTuple(c, scope, false, dataGraph))
.collect(Collectors.toList());
this.values = values;
this.scope = scope;
}
@Override
public CloseableIteration<? extends ValidationTuple> iterator() {
return new LoggingCloseableIteration(this, validationExecutionLogger) {
final Iterator<ValidationTuple> iterator = tuples.iterator();
@Override
protected void init() {
// no-op
}
@Override
public void localClose() {
}
@Override
public boolean localHasNext() {
return iterator.hasNext();
}
@Override
public ValidationTuple loggingNext() {
return iterator.next();
}
};
}
@Override
public int depth() {
return 0;
}
@Override
public void getPlanAsGraphvizDot(StringBuilder stringBuilder) {
if (printed) {
return;
}
printed = true;
stringBuilder.append(getId() + " [label=\"" + StringEscapeUtils.escapeJava(this.toString()) + "\"];")
.append("\n");
}
@Override
public String getId() {
return System.identityHashCode(this) + "";
}
@Override
public String toString() {
return "ValuesBackedNode{" + "values=" + Formatter.prefix(values) + '}';
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
ValuesBackedNode that = (ValuesBackedNode) o;
return values.equals(that.values) && scope == that.scope;
}
@Override
public int hashCode() {
return Objects.hash(values, scope);
}
@Override
public void receiveLogger(ValidationExecutionLogger validationExecutionLogger) {
this.validationExecutionLogger = validationExecutionLogger;
}
@Override
public boolean producesSorted() {
return true;
}
@Override
public boolean requiresSorted() {
return false;
}
}