2 * Copyright (c) 2017 Inocybe Technologies and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.controller.cluster.raft.base.messages;
10 import com.google.common.base.Preconditions;
11 import java.io.Externalizable;
12 import java.io.ObjectInput;
13 import java.io.ObjectOutput;
16 * Abstract base that implements Externalizable with no-op methods that is intended for classes that use the
17 * externalizable proxy pattern but have no data to serialize and read-resolve to a static instance.
19 * @author Thomas Pantelis
21 public abstract class EmptyExternalizableProxy implements Externalizable {
22 private static final long serialVersionUID = 1L;
24 private final Object readResolveTo;
26 protected EmptyExternalizableProxy(Object readResolveTo) {
27 this.readResolveTo = Preconditions.checkNotNull(readResolveTo);
31 public void writeExternal(ObjectOutput out) {
35 public void readExternal(ObjectInput in) {
38 protected Object readResolve() {