/*
 * 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_EXCEPTIONRESPONSE_H_
#define _ACTIVEMQ_COMMANDS_EXCEPTIONRESPONSE_H_

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

#include <activemq/commands/BrokerError.h>
#include <activemq/commands/Response.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 ExceptionResponse
     *
     *  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 ExceptionResponse : public Response {
    protected:

        Pointer<BrokerError> exception;

    public:

        const static unsigned char ID_EXCEPTIONRESPONSE = 31;

    private:

        ExceptionResponse(const ExceptionResponse&);
        ExceptionResponse& operator= (const ExceptionResponse&);

    public:

        ExceptionResponse();

        virtual ~ExceptionResponse();

        virtual unsigned char getDataStructureType() const;

        virtual ExceptionResponse* cloneDataStructure() const;

        virtual void copyDataStructure(const DataStructure* src);

        virtual std::string toString() const;

        virtual bool equals(const DataStructure* value) const;

        virtual const Pointer<BrokerError>& getException() const;
        virtual Pointer<BrokerError>& getException();
        virtual void setException(const Pointer<BrokerError>& exception);

    };

}}

#endif /*_ACTIVEMQ_COMMANDS_EXCEPTIONRESPONSE_H_*/
