/*
 * $Header: /home/cvs/struts/xdocs/struts1.1/documentation/ja/src/share/org/apache/struts/action/ActionForward.java,v 1.4 2003/12/16 16:46:16 skirnir Exp $
 * $Revision: 1.4 $
 * $Date: 2003/12/16 16:46:16 $
 *
 * ====================================================================
 *
 * The Apache Software License, Version 1.1
 *
 * Copyright (c) 1999-2003 The Apache Software Foundation.  All rights
 * reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *
 * 3. The end-user documentation included with the redistribution, if
 *    any, must include the following acknowlegement:
 *       "This product includes software developed by the
 *        Apache Software Foundation (http://www.apache.org/)."
 *    Alternately, this acknowlegement may appear in the software itself,
 *    if and wherever such third-party acknowlegements normally appear.
 *
 * 4. The names "The Jakarta Project", "Struts", and "Apache Software
 *    Foundation" must not be used to endorse or promote products derived
 *    from this software without prior written permission. For written
 *    permission, please contact apache@apache.org.
 *
 * 5. Products derived from this software may not be called "Apache"
 *    nor may "Apache" appear in their names without prior written
 *    permission of the Apache Group.
 *
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 * ====================================================================
 *
 * This software consists of voluntary contributions made by many
 * individuals on behalf of the Apache Software Foundation.  For more
 * information on the Apache Software Foundation, please see
 * <http://www.apache.org/>.
 *
 */


package org.apache.struts.action;


import org.apache.struts.config.ForwardConfig;


/**
 * <strong>ActionForward</strong>は<code>Action</code>クラスの処理の結果、
 * コントローラServlet(<code>ActionServlet</code>)によって実行される、
 * <code>RequestDispatcher.forward()</code>または<code>HttpServletResponse.sendRedirect()</code>の遷移先を表わします。
 * このクラスのインスタンスは必要に応じて動的に生成される場合と、
 * あるマッピングインスタンスに対して複数存在しうる遷移先の中から名前による検索を行うために、
 * <code>ActionMapping</code>の中に設定されている場合があります。
 * {@primary An <strong>ActionForward</strong> represents a destination to which the
 * controller servlet, <code>ActionServlet</code>, might be directed to
 * perform a <code>RequestDispatcher.forward()</code> or
 * <code>HttpServletResponse.sendRedirect()</code> to, as a result of
 * processing activities of an <code>Action</code> class.  Instances of this
 * class may be created dynamically as necessary, or configured in association
 * with an <code>ActionMapping</code> instance for named lookup of potentially
 * multiple destinations for a particular mapping instance.}
 * <p>
 * <code>ActionForward</code>は少なくとも以下のプロパティを持ちます。
 * 追加プロパティは必要に応じてサブクラスによって提供されます。
 * {@primary <p>
 * An <code>ActionForward</code> has the following minimal set of properties.
 * Additional properties can be provided as needed by subclassses.}
 * <ul>
 * <li><strong>contextRelative</strong> - <code>path</code>の値が
 * '/'文字で始まっている場合に<code>path</code>
 * の値を（モジュール相対の代わりに）
 * コンテキスト相対で解釈するべきかどうかです。[false]</li>
 * <li><strong>name</strong> - 特定の<code>ActionMapping</code>との関係の中からこのインスタンスを探し出すときに用いる論理名です。</li>
 * <li><strong>path</strong> - 制御がフォワードされるべきモジュール相対もしくはコンテキスト相対URI、または、リダイレクトされるべき相対または絶対URIです。
 * <li><strong>redirect</strong> - もしコントローラサーブレットがその関連付けられているパスに制御を移す際に<code>HttpServletResponse.sendRedirect()</code>を呼び出すなら<code>true</code>、
 *     そうでなければ<code>false</code>です。[false]</li>
 * </ul>
 * {@primary <ul>
 * <li><strong>contextRelative</strong> - Should the <code>path</code>
 *     value be interpreted as context-relative (instead of
 *     module-relative, if it starts with a '/' character? [false]</li>
 * <li><strong>name</strong> - Logical name by which this instance may be
 *     looked up in relationship to a particular <code>ActionMapping</code>.
 *     </li>
 * <li><strong>path</strong> - Module-relative or context-relative URI to
 *     which control should be forwarded, or an absolute or relative URI to
 *     which control should be redirected.</li>
 * <li><strong>redirect</strong> - Set to <code>true</code> if the controller
 *     servlet should call <code>HttpServletResponse.sendRedirect()</code>
 *     on the associated path; otherwise <code>false</code>.  [false]</li>
 * </ul>}
 *
 * <p>Struts1.1からはこのクラスは<code>ForwardConfig</code>
 * を拡張して<code>contextRelative</code>プロパティを継承しています。
 * {@primary <p>Since Struts 1.1 this class extends <code>ForwardConfig</code>
 * and inherits the <code>contextRelative</code> property.}
 *
 * <p><strong>注意</strong> - このクラスが既存のアプリケーションが使用している公開されたAPIの一部であるという事実がなければ、
 * このクラスの使用は推奨されずに
 * <code>org.apache.struts.config.ForwardConfig</code>
 * に置き換えられていたでしょう。</p>
 * {@primary <p><strong>NOTE</strong> - This class would have been deprecated and
 * replaced by <code>org.apache.struts.config.ForwardConfig</code> except
 * for the fact that it is part of the public API that existing applications
 * are using.</p>}
 *
 * @author Craig R. McClanahan
 * @version $Revision: 1.4 $ $Date: 2003/12/16 16:46:16 $
 * @translator おかだひでひさ
 * @translator 横田 健彦
 * @status firstdraft
 * @update 2003/12/15
 * @memo ブロックA
 */

public class ActionForward extends ForwardConfig {


    /**
	 * デフォルトの値を用いて新しいインスタンスを構築します。
     * {@primary Construct a new instance with default values.]
     */
    public ActionForward() {

        this(null, false);

    }


    /**
	 * 指定されたパスを用いて新しいインスタンスを構築します。
     * {@primary Construct a new instance with the specified path.}
     *
	 * @param path このインスタンスに設定するパス
     * {@primary Path for this instance}
     */
    public ActionForward(String path) {

        this(path, false);

    }


    /**
	 * 指定されたパスとりダイレクトフラグを用いて新しいインスタンスを構築します。
     * {@primary Construct a new instance with the specified path and redirect flag.}
     *
	 * @param path このインスタンスに設定するパス
     * {@primary Path for this instance}
     * @param redirect このインスタンスに設定するリダイレクトフラグ
     * {@primary Redirect flag for this instance}
     */
    public ActionForward(String path, boolean redirect) {

        super();
        setName(null);
        setPath(path);
        setRedirect(redirect);

    }


    /**
	 * 指定されたパスとりダイレクトフラグを用いて新しいインスタンスを構築します。
     * {@primary Construct a new instance with the specified path and redirect flag.
     *
     * @param name このインスタンスの名前
     * {@primary Name of this instance}
	 * @param path このインスタンスに設定するパス
     * {@primary Path for this instance}
     * @param redirect このインスタンスに設定するリダイレクトフラグ
     * {@primary Redirect flag for this instance}
     */
    public ActionForward(String name, String path, boolean redirect) {

        super();
        setName(name);
        setPath(path);
        setRedirect(redirect);

    }


    /**
	 * 指定された値を用いて新しいインスタンスを構築します。
     * {@primary Construct a new instance with the specified values.}
     *
     * @param name このインスタンスの名前
     * {@primary Name of this instance}
	 * @param path このインスタンスに設定するパス
     * {@primary Path for this instance}
     * @param redirect このインスタンスに設定するリダイレクトフラグ
     * {@primary Redirect flag for this instance}
     * @param contextRelative このインスタンスに設定するコンテキスト相対フラグ
     * {@primary Context relative flag for this instance}
     */
    public ActionForward(String name, String path, boolean redirect,
                         boolean contextRelative) {

        super();
        setName(name);
        setPath(path);
        setRedirect(redirect);
        setContextRelative(contextRelative);

    }


}
