Merge XFA to PDFium master at 4dc95e7 on 10/28/2014
[pdfium.git] / xfa / src / fxbarcode / src / BC_Base256Encoder.cpp
1 // Copyright 2014 PDFium Authors. All rights reserved.\r
2 // Use of this source code is governed by a BSD-style license that can be\r
3 // found in the LICENSE file.\r
4 \r
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com\r
6 \r
7 #include "barcode.h"\r
8 #include "include/BC_Encoder.h"\r
9 #include "include/BC_Dimension.h"\r
10 #include "include/BC_SymbolShapeHint.h"\r
11 #include "include/BC_SymbolInfo.h"\r
12 #include "include/BC_EncoderContext.h"\r
13 #include "include/BC_HighLevelEncoder.h"\r
14 #include "include/BC_Base256Encoder.h"\r
15 CBC_Base256Encoder::CBC_Base256Encoder()\r
16 {\r
17 }\r
18 CBC_Base256Encoder::~CBC_Base256Encoder()\r
19 {\r
20 }\r
21 FX_INT32 CBC_Base256Encoder::getEncodingMode()\r
22 {\r
23     return BASE256_ENCODATION;\r
24 }\r
25 void CBC_Base256Encoder::Encode(CBC_EncoderContext &context, FX_INT32 &e)\r
26 {\r
27     CFX_WideString buffer;\r
28     buffer += (FX_WCHAR)'\0';\r
29     while (context.hasMoreCharacters()) {\r
30         FX_WCHAR c = context.getCurrentChar();\r
31         buffer += c;\r
32         context.m_pos++;\r
33         FX_INT32 newMode = CBC_HighLevelEncoder::lookAheadTest(context.m_msg, context.m_pos, getEncodingMode());\r
34         if (newMode != getEncodingMode()) {\r
35             context.signalEncoderChange(newMode);\r
36             break;\r
37         }\r
38     }\r
39     FX_INT32 dataCount = buffer.GetLength() - 1;\r
40     FX_CHAR buf[128];\r
41 #if defined(_FX_WINAPI_PARTITION_APP_)\r
42     memset(buf, 0, sizeof(FX_CHAR) * 128);\r
43     _itoa_s(dataCount, buf, 128, 10);\r
44 #else\r
45     FXSYS_itoa(dataCount, buf, 10);\r
46 #endif\r
47     buffer.SetAt(0, FX_WCHAR(*buf) - '0');\r
48     FX_INT32 lengthFieldSize = 1;\r
49     FX_INT32 currentSize = context.getCodewordCount() + dataCount + lengthFieldSize;\r
50     context.updateSymbolInfo(currentSize, e);\r
51     if (e != BCExceptionNO) {\r
52         return;\r
53     }\r
54     FX_BOOL mustPad = (context.m_symbolInfo->m_dataCapacity - currentSize) > 0;\r
55     if (context.hasMoreCharacters() || mustPad) {\r
56         if (dataCount <= 249) {\r
57             buffer.SetAt(0, (FX_WCHAR) dataCount);\r
58         } else if (dataCount > 249 && dataCount <= 1555) {\r
59             buffer.SetAt(0, (FX_WCHAR) ((dataCount / 250) + 249));\r
60             buffer.Insert(1, (FX_WCHAR) (dataCount % 250));\r
61         } else {\r
62             e = BCExceptionIllegalStateMessageLengthInvalid;\r
63             return;\r
64         }\r
65     }\r
66     for (FX_INT32 i = 0, c = buffer.GetLength(); i < c; i++) {\r
67         context.writeCodeword(randomize255State(buffer.GetAt(i), context.getCodewordCount() + 1));\r
68     }\r
69 }\r
70 FX_WCHAR CBC_Base256Encoder::randomize255State(FX_WCHAR ch, FX_INT32 codewordPosition)\r
71 {\r
72     FX_INT32 pseudoRandom = ((149 * codewordPosition) % 255) + 1;\r
73     FX_INT32 tempVariable = ch + pseudoRandom;\r
74     if (tempVariable <= 255) {\r
75         return (FX_WCHAR) tempVariable;\r
76     } else {\r
77         return (FX_WCHAR) (tempVariable - 256);\r
78     }\r
79 }\r