diff options
author | Dan Sinclair <dsinclair@chromium.org> | 2017-11-14 18:48:23 +0000 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2017-11-14 18:48:23 +0000 |
commit | c8619c8d1cebb6b64db248ec89db98ab4513ad3c (patch) | |
tree | 698720728c3acb98f98340b83af2a015f66aa0ad /xfa/fxfa/parser/cxfa_datadata.cpp | |
parent | 83cb4369f97a244fc34633b31b3b75abb993a392 (diff) | |
download | pdfium-c8619c8d1cebb6b64db248ec89db98ab4513ad3c.tar.xz |
Rename a few more data classes.
The CXFA_Data nd CXFA_ExData files are part of the data hierarchy. They
need to be renamed to not clash with XFA node names.
Change-Id: I1ad11dd92edf26912f845aec21c57a9d23e51fcf
Reviewed-on: https://pdfium-review.googlesource.com/18270
Commit-Queue: dsinclair <dsinclair@chromium.org>
Reviewed-by: Tom Sepez <tsepez@chromium.org>
Diffstat (limited to 'xfa/fxfa/parser/cxfa_datadata.cpp')
-rw-r--r-- | xfa/fxfa/parser/cxfa_datadata.cpp | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/xfa/fxfa/parser/cxfa_datadata.cpp b/xfa/fxfa/parser/cxfa_datadata.cpp new file mode 100644 index 0000000000..8f41c2f3dd --- /dev/null +++ b/xfa/fxfa/parser/cxfa_datadata.cpp @@ -0,0 +1,82 @@ +// Copyright 2016 PDFium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com + +#include "xfa/fxfa/parser/cxfa_datadata.h" + +#include "core/fxcrt/fx_extension.h" +#include "xfa/fxfa/parser/cxfa_measurement.h" +#include "xfa/fxfa/parser/cxfa_node.h" + +// Static. +FX_ARGB CXFA_DataData::ToColor(const WideStringView& wsValue) { + uint8_t r = 0, g = 0, b = 0; + if (wsValue.GetLength() == 0) + return 0xff000000; + + int cc = 0; + const wchar_t* str = wsValue.unterminated_c_str(); + int len = wsValue.GetLength(); + while (FXSYS_iswspace(str[cc]) && cc < len) + cc++; + + if (cc >= len) + return 0xff000000; + + while (cc < len) { + if (str[cc] == ',' || !FXSYS_isDecimalDigit(str[cc])) + break; + + r = r * 10 + str[cc] - '0'; + cc++; + } + if (cc < len && str[cc] == ',') { + cc++; + while (FXSYS_iswspace(str[cc]) && cc < len) + cc++; + + while (cc < len) { + if (str[cc] == ',' || !FXSYS_isDecimalDigit(str[cc])) + break; + + g = g * 10 + str[cc] - '0'; + cc++; + } + if (cc < len && str[cc] == ',') { + cc++; + while (FXSYS_iswspace(str[cc]) && cc < len) + cc++; + + while (cc < len) { + if (str[cc] == ',' || !FXSYS_isDecimalDigit(str[cc])) + break; + + b = b * 10 + str[cc] - '0'; + cc++; + } + } + } + return (0xff << 24) | (r << 16) | (g << 8) | b; +} + +XFA_Element CXFA_DataData::GetElementType() const { + return m_pNode ? m_pNode->GetElementType() : XFA_Element::Unknown; +} + +bool CXFA_DataData::TryMeasure(XFA_Attribute eAttr, + float& fValue, + bool bUseDefault) const { + CXFA_Measurement ms; + if (m_pNode->JSNode()->TryMeasure(eAttr, ms, bUseDefault)) { + fValue = ms.ToUnit(XFA_Unit::Pt); + return true; + } + return false; +} + +bool CXFA_DataData::SetMeasure(XFA_Attribute eAttr, float fValue) { + CXFA_Measurement ms(fValue, XFA_Unit::Pt); + return m_pNode->JSNode()->SetMeasure(eAttr, ms, false); +} |