Update contrib.
2 * Copyright (c) 2002-2004 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
14 * Description: This class is a utitlity class for conversion of Vodafone
28 #ifndef CNVPICTOGRAPHSHARED_H
29 #define CNVPICTOGRAPHSHARED_H
34 #include <convutils.h>
35 #include "PictographObserver.h"
39 // Count of Vodafone pictograph's pages
40 const TInt KCountOfPictoPages(6);
46 * This class is a utitlity class for conversion of Vodafone pictograph.
47 * The conversion data are in each CnvPctograph1 - 6 dll.
48 * CnvPictographShared only to be used by ISO2022Jp.cpl, SHIFTJIS_SHARED.dll or
49 * something. For example, when CCnvCharacterSetConverter::ConvertFromUnicode()
50 * is called, and ConvertFromUnicode() of ISO2022Jp.cpl is called. After that,
51 * ISO2022Jp.cpl sets some parameters for the conversion. At that time,
52 * CnvPictographShared::SetCharacterSetsForPictograph() is called.
53 * In a nut shell, CnvPictographShared is chaind from Japanese conversion
56 * @lib CnvPictograph1.dll
57 * @lib CnvPictograph2.dll
58 * @lib CnvPictograph3.dll
59 * @lib CnvPictograph4.dll
60 * @lib CnvPictograph5.dll
61 * @lib CnvPictograph6.dll
64 class CnvPictographShared
68 * It sets parameters to SCharacterSet array.
69 * It called in ConvertFromUnicode().
70 * It makes possible that pictograph conversion is called from other
71 * conversion plug-ins.
73 * @param aArrayOfCharacterSets The conversion table array
75 static void SetCharacterSetsForPictograph(
76 RArray<CnvUtilities::SCharacterSet>& aArrayOfCharacterSets);
78 * It sets parameters to SCharacterSet array.
79 * It called in ConvertFromUnicode().
80 * It makes possible that pictograph conversion is called from other
81 * conversion plug-ins.
83 * @param aArrayOfCharacterSets The conversion table array
84 * @param aOriginalCharset The character set
86 static void SetCharacterSetsForPictograph(
87 RArray<CnvUtilities::SCharacterSet>& aArrayOfCharacterSets,
88 TOriginalCharset aOriginalCharset);
90 * It sets parameters to SMethod array.
91 * It called in ConvertToUnicode().
92 * It makes possible that pictograph conversion is called from other
93 * conversion plug-ins.
95 * @param aArrayOfMethods The conversion table array
96 * @param aOriginalCharset The character set
98 static void SetMethodsForPictograph(
99 RArray<CnvUtilities::SMethod>& aArrayOfMethods,
100 TOriginalCharset aOriginalCharset);
102 * It sets parameters to SState array.
103 * It called in ConvertToUnicode().
104 * It makes possible that pictograph conversion is called from other
105 * conversion plug-ins.
107 * @param aArrayOfMethods The conversion table array
109 static void SetStatesForPictograph(
110 RArray<CnvUtilities::SState>& aArrayOfStates);
114 * It converts from an intermediate buffer to a pictograph code.
115 * After that, it adds shift-in code(0x0F).
117 * @param aStartPositionInDescriptor The start postion for checking
118 * @param aDescriptor The descripter has intermidiate buffer.
119 * @param aNumberOfCharactersThatDroppedOut The number of characters
120 * that it's dropped out
122 static void ConvertToPictograph1InPlace(
123 TInt aStartPositionInDescriptor,
124 TDes8& aDescriptor, TInt& aNumberOfCharactersThatDroppedOut);
126 * It converts from an intermediate buffer to a pictograph code.
127 * After that, it adds shift-in code(0x0F).
129 * @param aStartPositionInDescriptor The start postion for checking
130 * @param aDescriptor The descripter has intermidiate buffer.
131 * @param aNumberOfCharactersThatDroppedOut The number of characters
132 * that it's dropped out
134 static void ConvertToPictograph2InPlace(
135 TInt aStartPositionInDescriptor,
136 TDes8& aDescriptor, TInt& aNumberOfCharactersThatDroppedOut);
138 * It converts from an intermediate buffer to a pictograph code.
139 * After that, it adds shift-in code(0x0F).
141 * @param aStartPositionInDescriptor The start postion for checking
142 * @param aDescriptor The descripter has intermidiate buffer.
143 * @param aNumberOfCharactersThatDroppedOut The number of characters
144 * that it's dropped out
146 static void ConvertToPictograph3InPlace(
147 TInt aStartPositionInDescriptor,
148 TDes8& aDescriptor, TInt& aNumberOfCharactersThatDroppedOut);
150 * It converts from an intermediate buffer to a pictograph code.
151 * After that, it adds shift-in code(0x0F).
153 * @param aStartPositionInDescriptor The start postion for checking
154 * @param aDescriptor The descripter has intermidiate buffer.
155 * @param aNumberOfCharactersThatDroppedOut The number of characters
156 * that it's dropped out
158 static void ConvertToPictograph4InPlace(
159 TInt aStartPositionInDescriptor,
160 TDes8& aDescriptor, TInt& aNumberOfCharactersThatDroppedOut);
162 * It converts from an intermediate buffer to a pictograph code.
163 * After that, it adds shift-in code(0x0F).
165 * @param aStartPositionInDescriptor The start postion for checking
166 * @param aDescriptor The descripter has intermidiate buffer.
167 * @param aNumberOfCharactersThatDroppedOut The number of characters
168 * that it's dropped out
170 static void ConvertToPictograph5InPlace(
171 TInt aStartPositionInDescriptor,
172 TDes8& aDescriptor, TInt& aNumberOfCharactersThatDroppedOut);
174 * It converts from an intermediate buffer to a pictograph code.
175 * After that, it adds shift-in code(0x0F).
177 * @param aStartPositionInDescriptor The start postion for checking
178 * @param aDescriptor The descripter has intermidiate buffer.
179 * @param aNumberOfCharactersThatDroppedOut The number of characters
180 * that it's dropped out
182 static void ConvertToPictograph6InPlace(
183 TInt aStartPositionInDescriptor,
184 TDes8& aDescriptor, TInt& aNumberOfCharactersThatDroppedOut);
187 * It returns a number of bytes that the conversion to pictograph is
188 * possible in the descriptor.
190 * @param aDescriptor A descriptor has any character code.
191 * @return Number of bytes that the conversion is possible
193 static TInt NumberOfBytesAbleToConvertSJisDirectMap(const TDesC8& aDescriptor);
196 * It returns a number of bytes that the conversion to pictograph is
197 * possible in the descriptor.
199 * @param aDescriptor A descriptor has any character code.
200 * @return Number of bytes that the conversion is possible
202 static TInt NumberOfBytesAbleToConvertToEucJpDirectMap1(const TDesC8& aDescriptor);
205 * It returns a number of bytes that the conversion to pictograph is
206 * possible in the descriptor.
208 * @param aDescriptor A descriptor has any character code.
209 * @return Number of bytes that the conversion is possible
211 static TInt NumberOfBytesAbleToConvertToEucJpDirectMap2(const TDesC8& aDescriptor);
214 * It returns a number of bytes that the conversion to pictograph is
215 * possible in the descriptor.
217 * @param aDescriptor A descriptor has any character code.
218 * @return Number of bytes that the conversion is possible
220 static TInt NumberOfBytesAbleToConvertToPicto1(
221 const TDesC8& aDescriptor);
223 * It returns a number of bytes that the conversion to pictograph is
224 * possible in the descriptor.
226 * @param aDescriptor A descriptor has any character code.
227 * @return Number of bytes that the conversion is possible
229 static TInt NumberOfBytesAbleToConvertToPicto2(
230 const TDesC8& aDescriptor);
232 * It returns a number of bytes that the conversion to pictograph is
233 * possible in the descriptor.
235 * @param aDescriptor A descriptor has any character code.
236 * @return Number of bytes that the conversion is possible
238 static TInt NumberOfBytesAbleToConvertToPicto3(
239 const TDesC8& aDescriptor);
241 * It returns a number of bytes that the conversion to pictograph is
242 * possible in the descriptor.
244 * @param aDescriptor A descriptor has any character code.
245 * @return Number of bytes that the conversion is possible
247 static TInt NumberOfBytesAbleToConvertToPicto4(
248 const TDesC8& aDescriptor);
250 * It returns a number of bytes that the conversion to pictograph is
251 * possible in the descriptor.
253 * @param aDescriptor A descriptor has any character code.
254 * @return Number of bytes that the conversion is possible
256 static TInt NumberOfBytesAbleToConvertToPicto5(
257 const TDesC8& aDescriptor);
259 * It returns a number of bytes that the conversion to pictograph is
260 * possible in the descriptor.
262 * @param aDescriptor A descriptor has any character code.
263 * @return Number of bytes that the conversion is possible
265 static TInt NumberOfBytesAbleToConvertToPicto6(
266 const TDesC8& aDescriptor);
268 * It's a common function for checking the number of bytes that
269 * the conversion to pictograph
271 * @param aDescriptor A descriptor has any character code.
272 * @param aIntermidiateCode An intermidiate buffer
273 * @return Number of bytes that the conversion is possible
275 static TInt NumberOfBytesAbleToConvertToPictograph(
276 const TDesC8& aDescriptor, TInt aIntermidiateCode);
278 * It converts the string which includes a pictograph's escape sequence
281 * @param aDescriptor It includes a pictograph's escape sequence
283 static void ConvertToPictographFromUnicode(TDes8& aDescriptor);
286 * It converts the string which has Unicode with pictograph to EUC-jp
287 * with direct mapped pictograph
289 * @param aDescriptor It includes a pictograph's escape sequence
291 static void ConvertToPictographFromEucJpPackedInPlace(TDes8& aDescriptor);
293 * It appends a shift-in code to the descriptor.
295 * @param aDescriptor It's append a shift-in code.
296 * @param aNumberOfCharactersThatDroppedOut The number of characters
297 * that it's dropped out
299 static void AppendShiftIn(TDes8& aDescriptor,
300 TInt& aNumberOfCharactersThatDroppedOut);
303 #endif // CNVPICTOGRAPHSHARED_H