All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.gemstone.gemfire.internal.cache.FunctionStreamingReplyMessage Maven / Gradle / Ivy

/*
 * Copyright (c) 2010-2015 Pivotal Software, Inc. All rights reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you
 * may not use this file except in compliance with the License. You
 * may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 * implied. See the License for the specific language governing
 * permissions and limitations under the License. See accompanying
 * LICENSE file.
 */
package com.gemstone.gemfire.internal.cache;

import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
import java.io.NotSerializableException;

import com.gemstone.gemfire.CancelException;
import com.gemstone.gemfire.DataSerializer;
import com.gemstone.gemfire.distributed.DistributedSystemDisconnectedException;
import com.gemstone.gemfire.distributed.internal.DM;
import com.gemstone.gemfire.distributed.internal.ReplyException;
import com.gemstone.gemfire.distributed.internal.ReplyMessage;
import com.gemstone.gemfire.distributed.internal.membership.InternalDistributedMember;

public class FunctionStreamingReplyMessage extends ReplyMessage {

  /** the number of this message */
  protected int msgNum;
  
  /** whether this message is the last one in this series */
  protected boolean lastMsg;

  protected Object result;

  protected transient AbstractOperationMessage txMsg;

  protected transient boolean sendTXChanges;

  protected static final byte IS_LAST = 0x1;
  protected static final byte HAS_TX_CHANGES = 0x2;

  public FunctionStreamingReplyMessage() {
    super();
  }

  public FunctionStreamingReplyMessage(AbstractOperationMessage txMsg,
      boolean sendTXChanges) {
    super(null, false, false);
    this.txMsg = txMsg;
    this.sendTXChanges = sendTXChanges;
  }

  /**
   * @param msgNum message number in this series (0-based)
   * @param lastMsg if this is the last message in this series
   */
  public static void send(InternalDistributedMember recipient, int processorId,
      ReplyException exception, DM dm, Object result, int msgNum,
      boolean lastMsg, AbstractOperationMessage txMsg, boolean sendTXChanges) {
    FunctionStreamingReplyMessage m = new FunctionStreamingReplyMessage(txMsg,
        sendTXChanges);
    m.processorId = processorId;
    if (exception != null) {
      m.setException(exception);
      dm.getLoggerI18n().fine("Replying with exception: " + m, exception);
    }
    m.setRecipient(recipient);
    m.msgNum = msgNum;
    m.lastMsg = lastMsg;
    m.result = result;
    dm.putOutgoing(m);
  } 

  public int getMessageNumber() {
    return this.msgNum;
  }
  
  public boolean isLastMessage() {
    return this.lastMsg;
  }
  
  public Object getResult() {
    return this.result;
  }
  
  @Override
  public int getDSFID() {
    return FUNCTION_STREAMING_REPLY_MESSAGE;
  }

  @Override
  public void fromData(DataInput in) throws IOException, ClassNotFoundException {
    super.fromData(in);
    this.msgNum = in.readInt();
    this.processorId = in.readInt();
    try {
      this.result = DataSerializer.readObject(in);
      byte flags = in.readByte();
      this.lastMsg = (flags & IS_LAST) != 0;
      if ((flags & HAS_TX_CHANGES) != 0) {
        this.txChanges = TXChanges.fromData(in);
      }
    }
    catch (Exception e) { // bug fix 40670
      // Seems odd to throw a NonSerializableEx when it has already been
      // serialized and we are failing because we can't deserialize.
      NotSerializableException ioEx = new NotSerializableException();
      ioEx.initCause(e);
      throw ioEx;
    }
  }

  @Override
  public void toData(DataOutput out) throws IOException {
    super.toData(out);
    byte flags = this.lastMsg ? IS_LAST : 0;
    out.writeInt(this.msgNum);
    out.writeInt(this.processorId);
    
    //soubhik. fix for ticket 40670
    try {
      DataSerializer.writeObject(this.result, out);
      if (this.lastMsg) {
        super.finishTX(this.txMsg, this.sendTXChanges, true);
      }
      if (this.txChanges != null) {
        flags |= HAS_TX_CHANGES;
      }
      out.writeByte(flags);
      if (this.txChanges != null) {
        this.txChanges.toData(out);
      }
    } 
    catch(Exception ex) {
      if (ex instanceof CancelException) {
        throw new DistributedSystemDisconnectedException(ex);
      }
      NotSerializableException ioEx = new NotSerializableException(this.result
          .getClass().getName());
      ioEx.initCause(ex);
      throw ioEx;
    }
  }

  @Override
  protected StringBuilder getStringBuilder() {
    final StringBuilder buff = super.getStringBuilder();
    if (this.getException() == null) {
      buff.append(" result=").append(this.result);
    }
    buff.append(" msgNum=").append(this.msgNum);
    buff.append(" lastMsg=").append(this.lastMsg);
    if (this.txChanges != null) {
      buff.append(' ');
      this.txChanges.toString(buff);
    }
    return buff;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy