Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

Call.hpp

Go to the documentation of this file.
00001 /* -*- C++ -*- */
00002 
00003 /*
00004  * The Apache Software License, Version 1.1
00005  *
00006  *
00007  * Copyright (c) 2002 The Apache Software Foundation.  All rights
00008  * reserved.
00009  *
00010  * Redistribution and use in source and binary forms, with or without
00011  * modification, are permitted provided that the following conditions
00012  * are met:
00013  *
00014  * 1. Redistributions of source code must retain the above copyright
00015  *    notice, this list of conditions and the following disclaimer.
00016  *
00017  * 2. Redistributions in binary form must reproduce the above copyright
00018  *    notice, this list of conditions and the following disclaimer in
00019  *    the documentation and/or other materials provided with the
00020  *    distribution.
00021  *
00022  * 3. The end-user documentation included with the redistribution,
00023  *    if any, must include the following acknowledgment:
00024  *       "This product includes software developed by the
00025  *        Apache Software Foundation (http://www.apache.org/)."
00026  *    Alternately, this acknowledgment may appear in the software itself,
00027  *    if and wherever such third-party acknowledgments normally appear.
00028  *
00029  * 4. The names "SOAP" and "Apache Software Foundation" must
00030  *    not be used to endorse or promote products derived from this
00031  *    software without prior written permission. For written
00032  *    permission, please contact apache@apache.org.
00033  *
00034  * 5. Products derived from this software may not be called "Apache",
00035  *    nor may "Apache" appear in their name, without prior written
00036  *    permission of the Apache Software Foundation.
00037  *
00038  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
00039  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00040  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00041  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
00042  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00043  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00044  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
00045  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00046  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00047  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
00048  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00049  * SUCH DAMAGE.
00050  * ====================================================================
00051  *
00052  * This software consists of voluntary contributions made by many
00053  * individuals on behalf of the Apache Software Foundation.  For more
00054  * information on the Apache Software Foundation, please see
00055  * <http://www.apache.org/>.
00056  */
00057 
00058 /*
00059  *
00060  * @authors     Lilantha Darshana    (lilantha@erunway.com)
00061  *              Satheesh Thurairajah (satheesh@erunway.com)
00062  *          
00063  *
00064  */
00065 
00066 #if !defined(_AXIS_CALL_HPP)
00067 #define _AXIS_CALL_HPP
00068 
00069 
00070 #include <vector>
00071 #include <string>
00072 #include "Param.hpp"
00073 #include "XMLType.hpp"
00074 
00075 class SerializerFactory;
00076 class SOAPMsgContext;
00077 
00097 
00098 class Call  
00099 {
00100 public:
00101 
00103     enum Mode {IN_PARAM, OUT_PARAM, IN_OUT_PARAM};
00104 
00105 public:
00106     Call();
00107     virtual ~Call();
00108     
00127 
00128     template<typename T>
00129     void AddParameter(const char* p_pchName, T& p_Value, Mode p_Mode)
00130     {
00131         Param *newParam = new Param;
00132 
00133         newParam->m_pValue = (void*)&p_Value;
00134         newParam->m_pType  = ax::XMLType<T>::GetType();
00135         newParam->m_Name   = p_pchName;
00136 
00137         m_vArgs.push_back(newParam);
00138     }
00139 
00157 
00158     template<typename T>
00159     void AddParameter(T& value, Mode mode)
00160     {
00161         Param *newParam = new Param;
00162 
00163         char buf[10];
00164         sprintf(buf, "%d", m_vArgs.size());
00165 
00166         newParam->m_pValue = (void*)&value;
00167         newParam->m_pType  = ax::XMLType<T>::GetType();
00168         newParam->m_pType  += buf; // create names like arg0, arg1 etc.
00169 
00170         m_vArgs.push_back(newParam);
00171     }
00172 
00174     void * Invoke(const std::string& p_sNs, const std::string& p_sMethod);
00175 
00177     void * Invoke();
00178 
00180     void SetTargetEndpointAddress(const char* p_pchUrl);
00181 
00183     void SetMethodNamespaceURI(const char *p_pchOpNsURI);
00184 
00186     void SetOperationName(const char *p_pchOpName);
00187 
00189     void AddSerializerFactory(const std::string& p_sTypName, SerializerFactory * p_pSer);
00190 
00192     void SetEncodingStyle(const std::string& p_sNsURI);
00193 
00199     void ClearAllParams(){m_vArgs.clear();}
00200 
00201 
00202 private:
00203 
00205     void Cleanup();
00206 
00207 
00208 private:
00209     std::vector<Param*> m_vArgs;            
00210     std::string         m_strOpName;        
00211     std::string         m_strMethodNsURI;   
00212     std::string         m_ServerURL;        
00213     std::string         m_EncStyle;         
00214 
00215     SOAPMsgContext *m_pClientCtx;           
00216 
00217 };
00218 
00219     
00220 
00221 #endif // _AXIS_CALL_HPP
00222 
00223 
Axis C++ Client Lib - User's Guide

Copyright © 2001 SL_OpenSource XML Project. All Rights Reserved