First public contribution.
1 // Copyright (c) 1996-2010 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
14 // Common client side class
19 #include "../SERVER/w32cmd.h"
23 MWsClientClass::MWsClientClass() : iWsHandle(0), iBuffer(NULL)
27 MWsClientClass::MWsClientClass(RWsBuffer *aBuffer) : iWsHandle(0), iBuffer(aBuffer)
32 Writes data sent in aData1 of length aLength1 for the specifed aOpcode
33 into wserv buffer. It also takes aLength2 paratmeter, which is the length of second data
34 that will be added using AppendData. This Function checks if current command and aLength2
35 can fit in the remaining buffer, if not then it does flush of previous command so that
36 the current command can be set along with data of aLength2.
38 @param aData1 Data to be added to the buffer
39 @param aLength1 Length of the data to be added to buffer
40 @param aLength2 Length of second data that will(and must) be added using AppendData()
41 @param aOpcode Opcode for the current command
43 void MWsClientClass::Write(const TAny *aData1,TInt aLength1,TInt aLength2,TUint aOpcode) const
45 Write(aData1,aLength1,NULL,aLength2,aOpcode);
49 Writes data sent in aData1 and aData2 of lengths aLength1 and aLength2
50 for the specifed aOpcode into wserv buffer. It also takes an TIpcArgs by which
51 you can send additional data. But one thing needs to be noted that if aIpcArgs
52 has some content then this function flushes the wserv buffer
54 @param aData1 Data to be added to the buffer
55 @param aLength1 Length of the data to be added to buffer
56 @param aData2 second Data to be added to the buffer
57 @param aLength2 second Length of second data then can be added using AppendData()
58 @param aOpcode Opcode for the current command
59 @param aIpcArgs Additional data sent from client to server. It has default argument NULL.
60 And if some data is sent in aIpcArgs, it flushes wserv buffer.
62 Note:Only second, third and fourth slot of IPC agrs can be used to send data
63 as first slot is used up for normal wserv buffer
65 void MWsClientClass::Write(const TAny *aData1, TInt aLength1,const TAny *aData2, TInt aLength2,TUint aOpcode,const TIpcArgs* aIpcArgs/*=NULL*/) const
67 iBuffer->Write(iWsHandle,aOpcode,aData1,aLength1,aData2,aLength2,aIpcArgs);
71 Writes data sent in aData1 of length aLength1 for the specifed aOpcode
72 into wserv buffer. It also takes an TIpcArgs by which you can send additional data.
73 But one thing needs to be noted that if aIpcArgs has some content then this
74 function flushes the wserv buffer
76 @param aData1 Data to be added to the buffer
77 @param aLength1 Length of the data to be added to buffer
78 @param aOpcode Opcode for the current command
79 @param aIpcArgs Additional data sent from client to server. It has default argument NULL.
80 And if some data is sent in aIpcArgs, it flushes wserv buffer
82 Note:Only second, third and fourth slot of IPC agrs can be used to send data
83 as first slot is used up for normal wserv buffer
85 void MWsClientClass::Write(const TAny *aData, TInt aLength, TUint aOpcode, const TIpcArgs* aIpcArgs/*=NULL*/) const
87 iBuffer->Write(iWsHandle,aOpcode,aData,aLength,aIpcArgs);
90 void MWsClientClass::Write(TUint aOpcode) const
92 iBuffer->Write(iWsHandle,aOpcode);
95 void MWsClientClass::WriteInt(TInt aInt, TUint aOpcode) const
97 iBuffer->Write(iWsHandle,aOpcode,&aInt,sizeof(TInt));
100 void MWsClientClass::WriteRect(const TRect &aRect, TUint aOpcode) const
102 Write(&aRect,sizeof(aRect),aOpcode);
105 void MWsClientClass::WritePoint(const TPoint &aPoint, TUint aOpcode) const
107 Write(&aPoint,sizeof(aPoint),aOpcode);
110 void MWsClientClass::WriteSize(const TSize &aSize, TUint aOpcode) const
112 Write(&aSize,sizeof(aSize),aOpcode);
116 Appends data directly to wserv buffer for the current command. So this function
117 should be used after adding the current command.
118 Typically this function is used in conjunction with
119 MWsClientClass::Write(const TAny *aData1,TInt aLength1,TInt aLength2,TUint aOpcode)
120 Please see its description for more details.
122 @param aData Data to be added to the buffer
123 @param aLength Length of the data to be added to buffer. Make sure that its length
124 is less than availabe buffer.
125 @param aFinished EFalse, adds data to buffer and disables flushing(notfies that more data is pending to be added)
126 ETrue, adds data to buffer and enables flushing(Signals that this is the last bit of data to be added)
129 1. The total length of all data added by using this API(by one or more calls) must be less then(See note 3)or
130 same as aLength2 passed in earlier call to MWsClientClass::Write(const TAny *aData1,TInt aLength1,TInt aLength2,TUint aOpcode)
131 2. When data is added using this API, it pads out buffer to multiple of 4 bytes so that
132 all strings added to the buffer will begin on a 4 byte boundary.
133 3. If data added is less then the length passed to above Write API it works, but wastes buffer spaces.
135 void MWsClientClass::AppendData(const TAny *aData,TInt aLength,TBool aFinished)
137 iBuffer->AppendData(aData,aLength,aFinished);
140 TInt MWsClientClass::WriteReply(TUint aOpcode,const TIpcArgs* aIpcArgs) const
142 return(iBuffer->WriteReply(iWsHandle,aOpcode,aIpcArgs));
145 TInt MWsClientClass::WriteReplyInt(TInt aInt, TUint aOpcode,const TIpcArgs* aIpcArgs) const
147 return(iBuffer->WriteReply(iWsHandle,aOpcode,&aInt,sizeof(TInt),aIpcArgs));
150 TInt MWsClientClass::WriteReply(const TAny *aData1, TInt aLength1,TUint aOpcode,const TIpcArgs* aIpcArgs) const
152 return(iBuffer->WriteReply(iWsHandle,aOpcode,aData1,aLength1,aIpcArgs));
155 TInt MWsClientClass::WriteReply(const TAny *aData1, TInt aLength1,const TAny *aData2, TInt aLength2,TUint aOpcode,const TIpcArgs* aIpcArgs) const
157 return(iBuffer->WriteReply(iWsHandle,aOpcode,aData1,aLength1,aData2,aLength2,aIpcArgs));
160 TInt MWsClientClass::WriteReplyP(const TWriteDescriptorType& aReplyPackage,TUint aOpcode) const
162 return(iBuffer->WriteReplyP(iWsHandle,aOpcode,aReplyPackage));
165 TInt MWsClientClass::WriteReplyIntP(TInt aInt, const TWriteDescriptorType& aReplyPackage,TUint aOpcode) const
167 return(iBuffer->WriteReplyP(iWsHandle,aOpcode,&aInt,sizeof(aInt),aReplyPackage));
170 TInt MWsClientClass::WriteReplyP(const TAny *aData1, TInt aLength1, const TWriteDescriptorType& aReplyPackage,TUint aOpcode) const
172 return(iBuffer->WriteReplyP(iWsHandle,aOpcode,aData1,aLength1,aReplyPackage));
175 TInt MWsClientClass::WriteReplyP(const TAny *aData1, TInt aLength1,const TAny *aData2, TInt aLength2, const TWriteDescriptorType& aReplyPackage,TUint aOpcode) const
177 return(iBuffer->WriteReplyP(iWsHandle,aOpcode,aData1,aLength1,aData2,aLength2,aReplyPackage));
180 TInt MWsClientClass::WriteReplyByProvidingRemoteReadAccess(const TAny* aBuf, TInt aBufLen,const TReadDescriptorType& aRemoteReadBuffer, TUint aOpcode) const
182 return(iBuffer->WriteReplyByProvidingRemoteReadAccess(iWsHandle,aOpcode,aBuf,aBufLen,aRemoteReadBuffer));
185 void MWsClientClass::AddToBitmapArray(const TInt aBitmapHandle)const
187 iBuffer->AddToBitmapArray(aBitmapHandle);
190 void MWsClientClass::AsyncRequest(TRequestStatus& aStatus, TUint aOpcode) const
192 iBuffer->AsyncRequest(iWsHandle, aOpcode, aStatus);
195 TBool MWsClientClass::WindowSizeCacheEnabled() const
197 return iBuffer->WindowSizeCacheEnabled();
200 void MWsClientClass::MarkWindowSizeCacheDirty()
202 iBuffer->MarkWindowSizeCacheDirty(iWsHandle);
205 void MWsClientClass::RefreshWindowSizeCache(const TSize& aNewSize) const
207 iBuffer->RefreshWindowSizeCache(iWsHandle,aNewSize);
210 TInt MWsClientClass::CachedWindowSize(TSize& aSize) const
212 return iBuffer->CachedWindowSize(iWsHandle, aSize);
215 void MWsClientClass::DestroyWindowSizeCacheEntry()
217 iBuffer->DestroyWindowSizeCacheEntry(iWsHandle);