2 // Open Service Platform
3 // Copyright (c) 2012 Samsung Electronics Co., Ltd.
5 // Licensed under the Apache License, Version 2.0 (the License);
6 // you may not use this file except in compliance with the License.
7 // You may obtain a copy of the License at
9 // http://www.apache.org/licenses/LICENSE-2.0
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
19 * @file FIo_IpcClient.h
20 * @brief This is the header file for the _IpcClient class.
22 * This file contains the declarations of _IpcClient.
26 #ifndef _FIO_INTERNAL_IPC_CLIENT_H_
27 #define _FIO_INTERNAL_IPC_CLIENT_H_
33 #include <ipc/ipc_message_macros.h>
34 #include <ipc/ipc_message_utils.h>
36 #include <FBaseResult.h>
37 #include <FBaseObject.h>
38 #include <FBaseString.h>
39 #include <FOspConfig.h>
42 namespace Tizen { namespace Base { namespace Runtime
46 namespace Tizen { namespace Io
49 class _IIpcClientEventListener;
53 * @brief This class provides methods for sending a message to an IPC server.
57 class _OSP_EXPORT_ _IpcClient
62 * This is the default constructor for this class.
68 * This is the destructor for this class.
71 virtual ~_IpcClient(void);
74 * Constructs the instance of this class.
78 * @return An error code
79 * @param[in] serverName The name of the server
80 * @param[in] pListener Set if the client want to handle a message from the IPC server.
82 * @exception E_SUCCESS The method was successful.
83 * @exception E_OBJ_NOT_FOUND The IPC server was not found.
84 * @exception E_OUT_OF_MEMORY Insufficient memory.
85 * @exception E_SYSTEM A system error occurred.
87 result Construct(const Tizen::Base::String& serverName, const _IIpcClientEventListener* pListener = null);
90 * Sends a request message to an IPC server.
97 * CalculatorProxy::Add(int a , int b)
101 * My_sum mySum(a, b, &c);
103 * __pIpcClient->SendRequest(mySum);
109 * @return An error code
110 * @param[in] message The message to send
111 * @exception E_SUCCESS The method was successful.
112 * @exception E_INVALID_STATE The instance is in an invalid state.
113 * @exception E_OUT_OF_MEMORY Insufficient memory.
114 * @exception E_SYSTEM A system error occurred.
117 result SendRequest(const IPC::Message& message);
119 result SendRequest(IPC::Message* pMessage);
122 _IpcClient(const _IpcClient& value);
124 _IpcClient& operator =(const _IpcClient& value);
126 result Send(IPC::Message* pMessage);
128 result SendAsync(IPC::Message* pMessage);
130 result SendSync(IPC::Message* pMessage);
132 result MakeConnection(bool forReverse = false);
136 void ReleaseFd(int fd);
138 static gboolean OnReadMessage(GIOChannel* source, GIOCondition condition, gpointer data);
140 gboolean HandleReceivedMessage(GIOChannel* source, GIOCondition condition);
143 GSource* __pReverseSource;
145 std::vector <int> __fds;
147 Tizen::Base::Runtime::Mutex* __pFdLock;
148 Tizen::Base::String __name;
149 _IIpcClientEventListener* __pListener;
151 static const int __MAX_MESSAGE_BUFFER_SIZE = 1024;
152 char __messageBuffer[__MAX_MESSAGE_BUFFER_SIZE];
153 std::string __pending;
158 #endif // _FIO_INTERNAL_IPC_CLIENT_H_