| OLD | NEW |
| 1 // Copyright 2014 PDFium Authors. All rights reserved. | 1 // Copyright 2014 PDFium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com | 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| 6 | 6 |
| 7 #ifndef XFA_FXBARCODE_COMMON_REEDSOLOMON_BC_REEDSOLOMONGF256POLY_H_ | 7 #ifndef XFA_FXBARCODE_COMMON_REEDSOLOMON_BC_REEDSOLOMONGF256POLY_H_ |
| 8 #define XFA_FXBARCODE_COMMON_REEDSOLOMON_BC_REEDSOLOMONGF256POLY_H_ | 8 #define XFA_FXBARCODE_COMMON_REEDSOLOMON_BC_REEDSOLOMONGF256POLY_H_ |
| 9 | 9 |
| 10 #include "core/fxcrt/fx_basic.h" | 10 #include "core/fxcrt/fx_basic.h" |
| 11 | 11 |
| 12 class CBC_ReedSolomonGF256; | 12 class CBC_ReedSolomonGF256; |
| 13 | 13 |
| 14 class CBC_ReedSolomonGF256Poly final { | 14 class CBC_ReedSolomonGF256Poly final { |
| 15 public: | 15 public: |
| 16 CBC_ReedSolomonGF256Poly(CBC_ReedSolomonGF256* field, int32_t coefficients); | 16 CBC_ReedSolomonGF256Poly(CBC_ReedSolomonGF256* field, int32_t coefficients); |
| 17 CBC_ReedSolomonGF256Poly(); | 17 CBC_ReedSolomonGF256Poly(); |
| 18 ~CBC_ReedSolomonGF256Poly(); | 18 ~CBC_ReedSolomonGF256Poly(); |
| 19 void Init(CBC_ReedSolomonGF256* field, | 19 void Init(CBC_ReedSolomonGF256* field, |
| 20 CFX_Int32Array* coefficients, | 20 CFX_Int32Array* coefficients, |
| 21 int32_t& e); | 21 int32_t& e); |
| 22 | 22 |
| 23 int32_t GetCoefficients(int32_t degree); | 23 int32_t GetCoefficients(int32_t degree); |
| 24 CFX_Int32Array* GetCoefficients(); | 24 CFX_Int32Array* GetCoefficients(); |
| 25 int32_t GetDegree(); | 25 int32_t GetDegree(); |
| 26 FX_BOOL IsZero(); | 26 bool IsZero(); |
| 27 int32_t EvaluateAt(int32_t a); | 27 int32_t EvaluateAt(int32_t a); |
| 28 CBC_ReedSolomonGF256Poly* AddOrSubtract(CBC_ReedSolomonGF256Poly* other, | 28 CBC_ReedSolomonGF256Poly* AddOrSubtract(CBC_ReedSolomonGF256Poly* other, |
| 29 int32_t& e); | 29 int32_t& e); |
| 30 CBC_ReedSolomonGF256Poly* Multiply(CBC_ReedSolomonGF256Poly* other, | 30 CBC_ReedSolomonGF256Poly* Multiply(CBC_ReedSolomonGF256Poly* other, |
| 31 int32_t& e); | 31 int32_t& e); |
| 32 CBC_ReedSolomonGF256Poly* Multiply(int32_t scalar, int32_t& e); | 32 CBC_ReedSolomonGF256Poly* Multiply(int32_t scalar, int32_t& e); |
| 33 CBC_ReedSolomonGF256Poly* MultiplyByMonomial(int32_t degree, | 33 CBC_ReedSolomonGF256Poly* MultiplyByMonomial(int32_t degree, |
| 34 int32_t coefficient, | 34 int32_t coefficient, |
| 35 int32_t& e); | 35 int32_t& e); |
| 36 CFX_ArrayTemplate<CBC_ReedSolomonGF256Poly*>* Divide( | 36 CFX_ArrayTemplate<CBC_ReedSolomonGF256Poly*>* Divide( |
| 37 CBC_ReedSolomonGF256Poly* other, | 37 CBC_ReedSolomonGF256Poly* other, |
| 38 int32_t& e); | 38 int32_t& e); |
| 39 | 39 |
| 40 CBC_ReedSolomonGF256Poly* Clone(int32_t& e); | 40 CBC_ReedSolomonGF256Poly* Clone(int32_t& e); |
| 41 | 41 |
| 42 private: | 42 private: |
| 43 CBC_ReedSolomonGF256* m_field; | 43 CBC_ReedSolomonGF256* m_field; |
| 44 CFX_Int32Array m_coefficients; | 44 CFX_Int32Array m_coefficients; |
| 45 }; | 45 }; |
| 46 | 46 |
| 47 #endif // XFA_FXBARCODE_COMMON_REEDSOLOMON_BC_REEDSOLOMONGF256POLY_H_ | 47 #endif // XFA_FXBARCODE_COMMON_REEDSOLOMON_BC_REEDSOLOMONGF256POLY_H_ |
| OLD | NEW |