Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(41)

Side by Side Diff: core/fxcrt/fx_xml_composer.cpp

Issue 1972053003: Add CFX_ByteStringC::CharAt() to avoid c_str() and casts (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@master
Patch Set: Created 4 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « core/fxcrt/fx_extension.cpp ('k') | core/fxcrt/include/fx_string.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 #include "core/fxcrt/xml_int.h" 7 #include "core/fxcrt/xml_int.h"
8 8
9 #include "core/fxcrt/include/fx_xml.h" 9 #include "core/fxcrt/include/fx_xml.h"
10 10
11 void FX_XML_SplitQualifiedName(const CFX_ByteStringC& bsFullName, 11 void FX_XML_SplitQualifiedName(const CFX_ByteStringC& bsFullName,
12 CFX_ByteStringC& bsSpace, 12 CFX_ByteStringC& bsSpace,
13 CFX_ByteStringC& bsName) { 13 CFX_ByteStringC& bsName) {
14 if (bsFullName.IsEmpty()) { 14 if (bsFullName.IsEmpty())
15 return; 15 return;
16 } 16
17 int32_t iStart = 0; 17 FX_STRSIZE iStart = bsFullName.Find(':');
18 for (; iStart < bsFullName.GetLength(); iStart++) { 18 if (iStart == -1) {
19 if (bsFullName.GetAt(iStart) == ':') {
20 break;
21 }
22 }
23 if (iStart >= bsFullName.GetLength()) {
24 bsName = bsFullName; 19 bsName = bsFullName;
25 } else { 20 } else {
26 bsSpace = CFX_ByteStringC(bsFullName.c_str(), iStart); 21 bsSpace = bsFullName.Mid(0, iStart);
27 iStart++; 22 bsName = bsFullName.Mid(iStart + 1);
28 bsName = CFX_ByteStringC(bsFullName.c_str() + iStart,
29 bsFullName.GetLength() - iStart);
30 } 23 }
31 } 24 }
25
32 void CXML_Element::SetTag(const CFX_ByteStringC& qSpace, 26 void CXML_Element::SetTag(const CFX_ByteStringC& qSpace,
33 const CFX_ByteStringC& tagname) { 27 const CFX_ByteStringC& tagname) {
34 m_QSpaceName = qSpace; 28 m_QSpaceName = qSpace;
35 m_TagName = tagname; 29 m_TagName = tagname;
36 } 30 }
37 void CXML_Element::SetTag(const CFX_ByteStringC& qTagName) { 31 void CXML_Element::SetTag(const CFX_ByteStringC& qTagName) {
38 ASSERT(!qTagName.IsEmpty()); 32 ASSERT(!qTagName.IsEmpty());
39 CFX_ByteStringC bsSpace, bsName; 33 CFX_ByteStringC bsSpace, bsName;
40 FX_XML_SplitQualifiedName(qTagName, bsSpace, bsName); 34 FX_XML_SplitQualifiedName(qTagName, bsSpace, bsName);
41 m_QSpaceName = bsSpace; 35 m_QSpaceName = bsSpace;
42 m_TagName = bsName; 36 m_TagName = bsName;
43 } 37 }
OLDNEW
« no previous file with comments | « core/fxcrt/fx_extension.cpp ('k') | core/fxcrt/include/fx_string.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698