Chromium Code Reviews| Index: xfa/fxfa/parser/xfa_document_serialize.cpp |
| diff --git a/xfa/fxfa/parser/xfa_document_serialize.cpp b/xfa/fxfa/parser/xfa_document_serialize.cpp |
| index ef85d0e2660b843331df77cfdcff443b2161fa2c..116ff12a178c236bfea1ec66e499948b57aa4e3d 100644 |
| --- a/xfa/fxfa/parser/xfa_document_serialize.cpp |
| +++ b/xfa/fxfa/parser/xfa_document_serialize.cpp |
| @@ -6,6 +6,8 @@ |
| #include "xfa/fxfa/parser/xfa_document_serialize.h" |
| +#include <memory> |
| + |
| #include "xfa/fde/xml/fde_xml_imp.h" |
| #include "xfa/fgas/crt/fgas_codepage.h" |
| #include "xfa/fxfa/fm2js/xfa_fm2jsapi.h" |
| @@ -22,31 +24,29 @@ CXFA_DataImporter::CXFA_DataImporter(CXFA_Document* pDocument) |
| : m_pDocument(pDocument) { |
| ASSERT(m_pDocument); |
| } |
| + |
| FX_BOOL CXFA_DataImporter::ImportData(IFX_FileRead* pDataDocument) { |
| - IXFA_Parser* pDataDocumentParser = IXFA_Parser::Create(m_pDocument); |
| - if (!pDataDocumentParser) { |
| + std::unique_ptr<IXFA_Parser> pDataDocumentParser( |
| + IXFA_Parser::Create(m_pDocument)); |
| + if (!pDataDocumentParser) |
|
Lei Zhang
2016/05/16 20:38:09
Always evals to false?
Tom Sepez
2016/05/16 21:29:06
Done.
|
| return FALSE; |
| - } |
| + |
| if (pDataDocumentParser->StartParse(pDataDocument, XFA_XDPPACKET_Datasets) != |
| XFA_PARSESTATUS_Ready) { |
| - pDataDocumentParser->Release(); |
| return FALSE; |
| } |
| - if (pDataDocumentParser->DoParse(NULL) < XFA_PARSESTATUS_Done) { |
| - pDataDocumentParser->Release(); |
| + if (pDataDocumentParser->DoParse(nullptr) < XFA_PARSESTATUS_Done) |
| return FALSE; |
| - } |
| + |
| CXFA_Node* pImportDataRoot = pDataDocumentParser->GetRootNode(); |
| - if (!pImportDataRoot) { |
| - pDataDocumentParser->Release(); |
| + if (!pImportDataRoot) |
| return FALSE; |
| - } |
| + |
| CXFA_Node* pDataModel = |
| ToNode(m_pDocument->GetXFAObject(XFA_HASHCODE_Datasets)); |
| - if (!pDataModel) { |
| - pDataDocumentParser->Release(); |
| + if (!pDataModel) |
| return FALSE; |
| - } |
| + |
| CXFA_Node* pDataNode = ToNode(m_pDocument->GetXFAObject(XFA_HASHCODE_Data)); |
| if (pDataNode) { |
| pDataModel->RemoveChild(pDataNode); |
| @@ -66,9 +66,9 @@ FX_BOOL CXFA_DataImporter::ImportData(IFX_FileRead* pDataDocument) { |
| pDataModel->InsertChild(pImportDataRoot); |
| } |
| m_pDocument->DoDataRemerge(FALSE); |
| - pDataDocumentParser->Release(); |
| return TRUE; |
| } |
| + |
| CFX_WideString XFA_ExportEncodeAttribute(const CFX_WideString& str) { |
| CFX_WideTextBuf textBuf; |
| int32_t iLen = str.GetLength(); |