/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */

#ifndef _ACTIVEMQ_COMMANDS_REPLAYCOMMAND_H_
#define _ACTIVEMQ_COMMANDS_REPLAYCOMMAND_H_

// Turn off warning message for ignored exception specification
#ifdef _MSC_VER
#pragma warning( disable : 4290 )
#endif

#include <activemq/commands/BaseCommand.h>
#include <activemq/util/Config.h>
#include <decaf/lang/Pointer.h>
#include <string>
#include <vector>

namespace activemq {
namespace commands {

    using decaf::lang::Pointer;

    /*
     *
     *  Command code for OpenWire format for ReplayCommand
     *
     *  NOTE!: This file is auto generated - do not modify!
     *         if you need to make a change, please see the Java Classes
     *         in the activemq-cpp-openwire-generator module
     *
     */
    class AMQCPP_API ReplayCommand : public BaseCommand {
    protected:

        int firstNakNumber;
        int lastNakNumber;

    public:

        const static unsigned char ID_REPLAYCOMMAND = 65;

    private:

        ReplayCommand(const ReplayCommand&);
        ReplayCommand& operator= (const ReplayCommand&);

    public:

        ReplayCommand();

        virtual ~ReplayCommand();

        virtual unsigned char getDataStructureType() const;

        virtual ReplayCommand* cloneDataStructure() const;

        virtual void copyDataStructure(const DataStructure* src);

        virtual std::string toString() const;

        virtual bool equals(const DataStructure* value) const;

        virtual int getFirstNakNumber() const;
        virtual void setFirstNakNumber(int firstNakNumber);

        virtual int getLastNakNumber() const;
        virtual void setLastNakNumber(int lastNakNumber);

        /**
         * @return an answer of true to the isReplayCommand() query.
         */
        virtual bool isReplayCommand() const {
            return true;
        }

        virtual Pointer<Command> visit(activemq::state::CommandVisitor* visitor);

    };

}}

#endif /*_ACTIVEMQ_COMMANDS_REPLAYCOMMAND_H_*/
