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

org.jsr107.ri.processor.RIEntryProcessorResult Maven / Gradle / Ivy

There is a newer version: 62
Show newest version
/**
 *  Copyright 2011-2013 Terracotta, Inc.
 *  Copyright 2011-2013 Oracle America Incorporated
 *
 *  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.
 */

package org.jsr107.ri.processor;

import javax.cache.CacheException;
import javax.cache.processor.EntryProcessorException;
import javax.cache.processor.EntryProcessorResult;

/**
 * An implementation of the {@link EntryProcessorResult}.
 *
 * @param  the type of {@link javax.cache.processor.EntryProcessor} result
 *
 * @author Brian Oliver
 */
public class RIEntryProcessorResult implements EntryProcessorResult {
  /**
   * The result of processing the entry.
   */
  private final T result;

  /**
   * The {@link CacheException} that may have occurred executing an {@link javax.cache.processor.EntryProcessor}.
   */
  private final CacheException exception;

  /**
   * Constructs an {@link RIEntryProcessorResult} for a resulting value
   *
   * @param result  the result
   */
  public RIEntryProcessorResult(T result) {
    this.result = result;
    this.exception = null;
  }

  /**
   * Constructs an {@link RIEntryProcessorResult} for an {@link Exception},
   * that of which will be returned wrapped as an {@link EntryProcessorException}.
   *
   * @param exception  the {@link Exception}
   */
  public RIEntryProcessorResult(Exception exception) {
    this.result = null;
    this.exception = new EntryProcessorException(exception);
  }

  @Override
  public T get() throws EntryProcessorException {
    if (exception == null) {
      return result;
    } else {
      throw exception;
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy