![JAR search and dependency download from the Maven repository](/logo.png)
oracle.kv.impl.topo.change.Add Maven / Gradle / Ivy
/*-
* Copyright (C) 2011, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This file was distributed by Oracle as part of a version of Oracle NoSQL
* Database made available at:
*
* http://www.oracle.com/technetwork/database/database-technologies/nosqldb/downloads/index.html
*
* Please see the LICENSE file included in the top-level directory of the
* appropriate version of Oracle NoSQL Database for a copy of the license and
* additional information.
*/
package oracle.kv.impl.topo.change;
import static oracle.kv.impl.util.ObjectUtil.checkNull;
import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
import oracle.kv.impl.topo.ResourceId;
import oracle.kv.impl.topo.ResourceId.ResourceType;
import oracle.kv.impl.topo.Topology.Component;
import com.sleepycat.persist.model.Persistent;
/**
* Represents the creation of a new component in the topology.
*
* @see #writeFastExternal FastExternalizable format
*/
@Persistent
public class Add extends TopologyChange {
private static final long serialVersionUID = 1L;
Component> component;
Add(int sequenceNumber, Component> component) {
super(sequenceNumber);
checkNull("component", component);
checkNull("component.resourceId", component.getResourceId());
this.component = component;
}
Add(DataInput in, short serialVersion)
throws IOException {
super(in, serialVersion);
component = Component.readFastExternal(null, in, serialVersion);
}
/**
* Writes this object to the output stream. Format:
*
* - ({@link TopologyChange}) {@code super}
*
- ({@link Component}) {@link #getComponent component}
*
*
* Note that the format of the component depends on the component type,
* which is identified by the component's {@link ResourceType}.
*/
@Override
public void writeFastExternal(DataOutput out, short serialVersion)
throws IOException {
super.writeFastExternal(out, serialVersion);
component.writeFastExternal(out, serialVersion);
}
@SuppressWarnings("unused")
private Add() { super();}
/* (non-Javadoc)
* @see oracle.kv.impl.topo.change.TopologyChange#getType()
*/
@Override
public Type getType() {
return Type.ADD;
}
@Override
public Component> getComponent() {
return component;
}
/* (non-Javadoc)
* @see oracle.kv.impl.topo.change.TopologyChange#getResourceId()
*/
@Override
public ResourceId getResourceId() {
return component.getResourceId();
}
@Override
public Add clone() {
Component> comp = component.clone();
comp.setTopology(null);
return new Add(sequenceNumber, comp);
}
@Override
public String toString() {
return "Add " + component.getResourceId() + " seq=" +
sequenceNumber;
}
}