summaryrefslogtreecommitdiff
path: root/xfa/fxfa/parser/cxfa_datadata.cpp
diff options
context:
space:
mode:
authorDan Sinclair <dsinclair@chromium.org>2017-11-14 18:48:23 +0000
committerChromium commit bot <commit-bot@chromium.org>2017-11-14 18:48:23 +0000
commitc8619c8d1cebb6b64db248ec89db98ab4513ad3c (patch)
tree698720728c3acb98f98340b83af2a015f66aa0ad /xfa/fxfa/parser/cxfa_datadata.cpp
parent83cb4369f97a244fc34633b31b3b75abb993a392 (diff)
downloadpdfium-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.cpp82
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);
+}