apoc.export.util.ProgressReporter Maven / Gradle / Ivy
package apoc.export.util;
import apoc.result.ProgressInfo;
import org.neo4j.graphdb.QueryStatistics;
import java.io.PrintWriter;
import java.util.function.Consumer;
import java.util.stream.Stream;
/**
* @author mh
* @since 22.05.16
*/
public class ProgressReporter implements Reporter {
private final SizeCounter sizeCounter;
private final PrintWriter out;
private final long batchSize;
long time;
int counter;
long totalEntities = 0;
long lastBatch = 0;
long start = System.currentTimeMillis();
private final ProgressInfo progressInfo;
private Consumer consumer;
public ProgressReporter(SizeCounter sizeCounter, PrintWriter out, ProgressInfo progressInfo) {
this.sizeCounter = sizeCounter;
this.out = out;
this.time = start;
this.progressInfo = progressInfo;
this.batchSize = progressInfo.batchSize;
}
public ProgressReporter withConsumer(Consumer consumer) {
this.consumer = consumer;
return this;
}
@Override
public void progress(String msg) {
long now = System.currentTimeMillis();
// todo report percentages back
println(String.format(msg + " %d. %d%%: %s time %d ms total %d ms", counter++, percent(), progressInfo, now - time, now - start));
time = now;
}
private void println(String message) {
if (out != null) out.println(message);
}
private long percent() {
return sizeCounter == null ? 100 : sizeCounter.getPercent();
}
public void update(long nodes, long relationships, long properties) {
time = System.currentTimeMillis();
progressInfo.update(nodes, relationships, properties);
totalEntities += nodes + relationships;
acceptBatch();
}
public void acceptBatch() {
if (batchSize != -1 && totalEntities / batchSize > lastBatch) {
updateRunningBatch(progressInfo);
if (consumer != null) {
consumer.accept(progressInfo);
}
}
}
public void updateRunningBatch(ProgressInfo progressInfo) {
lastBatch = Math.max(totalEntities / batchSize,lastBatch);
progressInfo.batches = lastBatch;
this.progressInfo.rows = totalEntities;
this.progressInfo.updateTime(start);
}
@Override
public void done() {
if (totalEntities / batchSize == lastBatch) lastBatch++;
updateRunningBatch(progressInfo);
progressInfo.done(start);
if (consumer != null) {
consumer.accept(progressInfo);
}
if (consumer != null) {
consumer.accept(ProgressInfo.EMPTY);
}
}
public static void update(QueryStatistics queryStatistics, Reporter reporter) {
if (queryStatistics.containsUpdates()) {
reporter.update(
queryStatistics.getNodesCreated() - queryStatistics.getNodesDeleted(),
queryStatistics.getRelationshipsCreated() - queryStatistics.getRelationshipsDeleted(),
queryStatistics.getPropertiesSet());
}
}
public ProgressInfo getTotal() {
progressInfo.done(start);
return progressInfo;
}
public Stream stream() {
return Stream.of(getTotal());
}
public void nextRow() {
this.progressInfo.nextRow();
this.totalEntities++;
acceptBatch();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy