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

ratpack.func.Actions Maven / Gradle / Ivy

There is a newer version: 2.0.0-rc-1
Show newest version
/*
 * Copyright 2014 the original author or authors.
 *
 * 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 ratpack.func;

import ratpack.api.Nullable;
import ratpack.util.ExceptionUtils;

/**
 * Factories for different {@link ratpack.func.Action} implementations.
 */
public abstract class Actions {

  private final static Action THROW_EXCEPTION = new Action() {
    @Override
    public void execute(Throwable throwable) throws Exception {
      throw ExceptionUtils.toException(throwable);
    }
  };

  private static final Action NOOP = new Action() {
    @Override
    public void execute(Object thing) throws Exception {
    }
  };

  private Actions() {

  }

  /**
   * Returns an action that does precisely nothing.
   *
   * @return an action that does precisely nothing
   */
  public static Action noop() {
    return NOOP;
  }

  /**
   * If the given action is {@code null}, returns {@link #noop()}, otherwise returns the given action.
   *
   * @param action an action, maybe {@code null}.
   * @param  the type of parameter received by the action
   * @return the given {@code action} param if it is not {@code null}, else a {@link #noop()}.
   */
  public static  Action noopIfNull(@Nullable Action action) {
    if (action == null) {
      return noop();
    } else {
      return action;
    }
  }

  /**
   * Returns a new action that executes the given actions in order.
   *
   * @param actions the actions to join into one action
   * @param  the type of object the action accepts
   * @return the newly created aggregate action
   */
  @SafeVarargs
  public static  Action join(final Action... actions) {
    return new Action() {
      @Override
      public void execute(T thing) throws Exception {
        for (Action action : actions) {
          action.execute(thing);
        }
      }
    };
  }

  /**
   * Returns an action that receives a throwable and immediately throws it.
   *
   * @return an action that receives a throwable and immediately throws it
   */
  public static Action throwException() {
    return THROW_EXCEPTION;
  }

  /**
   * Returns an action that acts on an action that acts on the given argument.
   * 

* The returned action is effectively a callback for executing a callback for the given argument. * * @param t the argument to give to actions given to the returned action * @param the type of the argument * @return an action that acts on an action that acts on the given argument */ public static Action> actionAction(final T t) { return new Action>() { @Override public void execute(Action action) throws Exception { action.execute(t); } }; } }