org.elasticsearch.cluster.AbstractDiffable Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elasticsearch Show documentation
Show all versions of elasticsearch Show documentation
Elasticsearch - Open Source, Distributed, RESTful Search Engine
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
package org.elasticsearch.cluster;
import org.elasticsearch.common.Nullable;
import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.StreamOutput;
import java.io.IOException;
/**
* Abstract diffable object with simple diffs implementation that sends the entire object if object has changed or
* nothing if object remained the same.
*/
public abstract class AbstractDiffable> implements Diffable {
private static final Diff> EMPTY = new CompleteDiff<>();
@SuppressWarnings("unchecked")
@Override
public Diff diff(T previousState) {
if (this.equals(previousState)) {
return (Diff) EMPTY;
} else {
return new CompleteDiff<>((T) this);
}
}
@SuppressWarnings("unchecked")
public static > Diff readDiffFrom(Reader reader, StreamInput in) throws IOException {
if (in.readBoolean()) {
return new CompleteDiff<>(reader.read(in));
}
return (Diff) EMPTY;
}
private static class CompleteDiff> implements Diff {
@Nullable
private final T part;
/**
* Creates simple diff with changes
*/
CompleteDiff(T part) {
this.part = part;
}
/**
* Creates simple diff without changes
*/
CompleteDiff() {
this.part = null;
}
@Override
public void writeTo(StreamOutput out) throws IOException {
if (part != null) {
out.writeBoolean(true);
part.writeTo(out);
} else {
out.writeBoolean(false);
}
}
@Override
public T apply(T part) {
if (this.part != null) {
return this.part;
} else {
return part;
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy