diff options
author | Lei Zhang <thestig@chromium.org> | 2015-08-11 14:08:47 -0700 |
---|---|---|
committer | Lei Zhang <thestig@chromium.org> | 2015-08-11 14:08:47 -0700 |
commit | 119dc646ff7c108cc7319dbc11e05958d98fadfe (patch) | |
tree | 287591b7caa87be7fc7def160bfb47d1a80a0f5f /core/src | |
parent | 335e11825fcb8520f68ac668f8dacd9b48f05804 (diff) | |
download | pdfium-119dc646ff7c108cc7319dbc11e05958d98fadfe.tar.xz |
Merge to XFA: Remove dead code from CPDF_Metadata. Add missing nullptr check.
BUG=pdfium:117
R=tsepez@chromium.org
Review URL: https://codereview.chromium.org/1282653002 .
(cherry picked from commit 1e2ece0cf98f8daecdea5b45ebd20cedbcef4bd9)
Review URL: https://codereview.chromium.org/1274803004 .
Diffstat (limited to 'core/src')
-rw-r--r-- | core/src/fpdfdoc/doc_metadata.cpp | 139 |
1 files changed, 13 insertions, 126 deletions
diff --git a/core/src/fpdfdoc/doc_metadata.cpp b/core/src/fpdfdoc/doc_metadata.cpp index e350ea6f41..c779f68354 100644 --- a/core/src/fpdfdoc/doc_metadata.cpp +++ b/core/src/fpdfdoc/doc_metadata.cpp @@ -6,136 +6,23 @@ #include "../../include/fpdfdoc/fpdf_doc.h" #include "../../include/fxcrt/fx_xml.h" -typedef struct _PDFDOC_METADATA { - CPDF_Document* m_pDoc; - CXML_Element* m_pXmlElmnt; - CXML_Element* m_pElmntRdf; - CFX_CMapByteStringToPtr* m_pStringMap; -} PDFDOC_METADATA, *PDFDOC_LPMETADATA; -typedef PDFDOC_METADATA const* PDFDOC_LPCMETADATA; -const FX_CHAR* const gs_FPDFDOC_Metadata_Titles[] = { - "Title", "title", "Subject", "description", "Author", - "creator", "Keywords", "Keywords", "Producer", "Producer", - "Creator", "CreatorTool", "CreationDate", "CreateDate", "ModDate", - "ModifyDate", "MetadataDate", "MetadataDate"}; -CPDF_Metadata::CPDF_Metadata() { - m_pData = FX_Alloc(PDFDOC_METADATA, 1); - CFX_CMapByteStringToPtr*& pStringMap = - ((PDFDOC_LPMETADATA)m_pData)->m_pStringMap; - pStringMap = new CFX_CMapByteStringToPtr; - if (pStringMap != NULL) { - CFX_ByteString bstr; - for (int i = 0; i < 18; i += 2) { - bstr = gs_FPDFDOC_Metadata_Titles[i]; - pStringMap->AddValue(bstr, (void*)gs_FPDFDOC_Metadata_Titles[i + 1]); - } - } -} -CPDF_Metadata::~CPDF_Metadata() { - FXSYS_assert(m_pData != NULL); - CXML_Element*& p = ((PDFDOC_LPMETADATA)m_pData)->m_pXmlElmnt; - delete p; - CFX_CMapByteStringToPtr* pStringMap = - ((PDFDOC_LPMETADATA)m_pData)->m_pStringMap; - if (pStringMap) { - pStringMap->RemoveAll(); - delete pStringMap; - } - FX_Free(m_pData); -} -void CPDF_Metadata::LoadDoc(CPDF_Document* pDoc) { - FXSYS_assert(pDoc != NULL); - ((PDFDOC_LPMETADATA)m_pData)->m_pDoc = pDoc; + +CPDF_Metadata::CPDF_Metadata(CPDF_Document* pDoc) : m_pDoc(pDoc) { CPDF_Dictionary* pRoot = pDoc->GetRoot(); + if (!pRoot) + return; + CPDF_Stream* pStream = pRoot->GetStream(FX_BSTRC("Metadata")); - if (!pStream) { + if (!pStream) return; - } + CPDF_StreamAcc acc; acc.LoadAllData(pStream, FALSE); - int size = acc.GetSize(); - const uint8_t* pBuf = acc.GetData(); - CXML_Element*& pXmlElmnt = ((PDFDOC_LPMETADATA)m_pData)->m_pXmlElmnt; - pXmlElmnt = CXML_Element::Parse(pBuf, size); - if (!pXmlElmnt) { - return; - } - CXML_Element*& pElmntRdf = ((PDFDOC_LPMETADATA)m_pData)->m_pElmntRdf; - if (pXmlElmnt->GetTagName() == FX_BSTRC("RDF")) { - pElmntRdf = pXmlElmnt; - } else { - pElmntRdf = pXmlElmnt->GetElement(NULL, FX_BSTRC("RDF")); - } -} -int32_t CPDF_Metadata::GetString(const CFX_ByteStringC& bsItem, - CFX_WideString& wsStr) { - if (!((PDFDOC_LPMETADATA)m_pData)->m_pXmlElmnt) { - return -1; - } - if (!((PDFDOC_LPMETADATA)m_pData)->m_pStringMap) { - return -1; - } - void* szTag; - if (!((PDFDOC_LPMETADATA)m_pData)->m_pStringMap->Lookup(bsItem, szTag)) { - return -1; - } - CFX_ByteString bsTag = (const FX_CHAR*)szTag; - wsStr = L""; - CXML_Element* pElmntRdf = ((PDFDOC_LPMETADATA)m_pData)->m_pElmntRdf; - if (!pElmntRdf) { - return -1; - } - int nChild = pElmntRdf->CountChildren(); - for (int i = 0; i < nChild; i++) { - CXML_Element* pTag = - pElmntRdf->GetElement(NULL, FX_BSTRC("Description"), i); - if (!pTag) { - continue; - } - if (bsItem == FX_BSTRC("Title") || bsItem == FX_BSTRC("Subject")) { - CXML_Element* pElmnt = pTag->GetElement(NULL, bsTag); - if (!pElmnt) { - continue; - } - pElmnt = pElmnt->GetElement(NULL, FX_BSTRC("Alt")); - if (!pElmnt) { - continue; - } - pElmnt = pElmnt->GetElement(NULL, FX_BSTRC("li")); - if (!pElmnt) { - continue; - } - wsStr = pElmnt->GetContent(0); - return wsStr.GetLength(); - } - if (bsItem == FX_BSTRC("Author")) { - CXML_Element* pElmnt = pTag->GetElement(NULL, bsTag); - if (!pElmnt) { - continue; - } - pElmnt = pElmnt->GetElement(NULL, FX_BSTRC("Seq")); - if (!pElmnt) { - continue; - } - pElmnt = pElmnt->GetElement(NULL, FX_BSTRC("li")); - if (!pElmnt) { - continue; - } - wsStr = pElmnt->GetContent(0); - return wsStr.GetLength(); - } - CXML_Element* pElmnt = pTag->GetElement(NULL, bsTag); - if (!pElmnt) { - continue; - } - wsStr = pElmnt->GetContent(0); - return wsStr.GetLength(); - } - return -1; -} -CXML_Element* CPDF_Metadata::GetRoot() const { - return ((PDFDOC_LPMETADATA)m_pData)->m_pXmlElmnt; + m_pXmlElement.reset(CXML_Element::Parse(acc.GetData(), acc.GetSize())); } -CXML_Element* CPDF_Metadata::GetRDF() const { - return ((PDFDOC_LPMETADATA)m_pData)->m_pElmntRdf; + +CPDF_Metadata::~CPDF_Metadata() {} + +const CXML_Element* CPDF_Metadata::GetRoot() const { + return m_pXmlElement.get(); } |