Index: fpdfsdk/src/fpdfdoc.cpp |
diff --git a/fpdfsdk/src/fpdfdoc.cpp b/fpdfsdk/src/fpdfdoc.cpp |
index 19ca06ca276416e0df34c3f7e432b423ca910cc1..ab2351f9d8102912ffce7709bcc7c97f7238ca2f 100644 |
--- a/fpdfsdk/src/fpdfdoc.cpp |
+++ b/fpdfsdk/src/fpdfdoc.cpp |
@@ -7,118 +7,122 @@ |
#include "../include/fsdk_define.h" |
#include "../include/fpdfdoc.h" |
-static int this_module = 0; |
+static int THISMODULE = 0; |
-static CPDF_Bookmark FindBookmark(CPDF_BookmarkTree& tree, CPDF_Bookmark This, const CFX_WideString& title) |
+static CPDF_Bookmark FindBookmark(const CPDF_BookmarkTree& tree, CPDF_Bookmark bookmark, const CFX_WideString& title) |
{ |
- if (This != NULL) { |
+ if (bookmark && bookmark.GetTitle().CompareNoCase(title) == 0) { |
// First check this item |
- CFX_WideString this_title = This.GetTitle(); |
- if (this_title.CompareNoCase(title) == 0) |
- return This; |
+ return bookmark; |
} |
// go into children items |
- CPDF_Bookmark Child = tree.GetFirstChild(This); |
- while (Child != NULL) { |
+ CPDF_Bookmark child = tree.GetFirstChild(bookmark); |
+ while (child) { |
// check if this item |
- CPDF_Bookmark Found = FindBookmark(tree, Child, title); |
- if (Found) return Found; |
- Child = tree.GetNextSibling(Child); |
+ CPDF_Bookmark found = FindBookmark(tree, child, title); |
+ if (found) |
+ return found; |
+ child = tree.GetNextSibling(child); |
} |
- return NULL; |
+ return CPDF_Bookmark(); |
} |
DLLEXPORT FPDF_BOOKMARK STDCALL FPDFBookmark_Find(FPDF_DOCUMENT document, FPDF_WIDESTRING title) |
{ |
- if (document == NULL) return NULL; |
- if (title == NULL || title[0] == 0) return NULL; |
- |
+ if (!document) |
+ return NULL; |
+ if (!title || title[0] == 0) |
+ return NULL; |
CPDF_Document* pDoc = (CPDF_Document*)document; |
CPDF_BookmarkTree tree(pDoc); |
- |
FX_STRSIZE len = CFX_WideString::WStringLength(title); |
- CFX_WideString wstr = CFX_WideString::FromUTF16LE(title, len); |
- return FindBookmark(tree, NULL, wstr); |
+ CFX_WideString encodedTitle = CFX_WideString::FromUTF16LE(title, len); |
+ return FindBookmark(tree, CPDF_Bookmark(), encodedTitle).GetDict(); |
} |
-DLLEXPORT FPDF_DEST STDCALL FPDFBookmark_GetDest(FPDF_DOCUMENT document, FPDF_BOOKMARK bookmark) |
+DLLEXPORT FPDF_DEST STDCALL FPDFBookmark_GetDest(FPDF_DOCUMENT document, FPDF_BOOKMARK pDict) |
{ |
- if (document == NULL) return NULL; |
- if (bookmark == NULL) return NULL; |
- |
- CPDF_Bookmark Bookmark = (CPDF_Dictionary*)bookmark; |
+ if (!document) |
+ return NULL; |
+ if (!pDict) |
+ return NULL; |
+ CPDF_Bookmark bookmark((CPDF_Dictionary*)pDict); |
CPDF_Document* pDoc = (CPDF_Document*)document; |
- CPDF_Dest dest = Bookmark.GetDest(pDoc); |
- if (dest != NULL) return dest; |
- |
+ CPDF_Dest dest = bookmark.GetDest(pDoc); |
+ if (dest) |
+ return dest; |
// If this bookmark is not directly associated with a dest, we try to get action |
- CPDF_Action Action = Bookmark.GetAction(); |
- if (Action == NULL) return NULL; |
- return Action.GetDest(pDoc); |
+ CPDF_Action action = bookmark.GetAction(); |
+ if (!action) |
+ return NULL; |
+ return action.GetDest(pDoc); |
} |
-DLLEXPORT FPDF_ACTION STDCALL FPDFBookmark_GetAction(FPDF_BOOKMARK bookmark) |
+DLLEXPORT FPDF_ACTION STDCALL FPDFBookmark_GetAction(FPDF_BOOKMARK pDict) |
{ |
- if (bookmark == NULL) return NULL; |
- |
- CPDF_Bookmark Bookmark = (CPDF_Dictionary*)bookmark; |
- return Bookmark.GetAction(); |
+ if (!pDict) |
+ return NULL; |
+ CPDF_Bookmark bookmark((CPDF_Dictionary*)pDict); |
+ return bookmark.GetAction(); |
} |
-DLLEXPORT unsigned long STDCALL FPDFAction_GetType(FPDF_ACTION action) |
+DLLEXPORT unsigned long STDCALL FPDFAction_GetType(FPDF_ACTION pDict) |
{ |
- if (action == NULL) return 0; |
- |
- CPDF_Action Action = (CPDF_Dictionary*)action; |
- CPDF_Action::ActionType type = Action.GetType(); |
+ if (!pDict) |
+ return 0; |
+ CPDF_Action action = (CPDF_Dictionary*)pDict; |
+ CPDF_Action::ActionType type = action.GetType(); |
switch (type) { |
- case CPDF_Action::GoTo: |
- return PDFACTION_GOTO; |
- case CPDF_Action::GoToR: |
- return PDFACTION_REMOTEGOTO; |
- case CPDF_Action::URI: |
- return PDFACTION_URI; |
- case CPDF_Action::Launch: |
- return PDFACTION_LAUNCH; |
- default: |
- return PDFACTION_UNSUPPORTED; |
+ case CPDF_Action::GoTo: |
+ return PDFACTION_GOTO; |
+ case CPDF_Action::GoToR: |
+ return PDFACTION_REMOTEGOTO; |
+ case CPDF_Action::URI: |
+ return PDFACTION_URI; |
+ case CPDF_Action::Launch: |
+ return PDFACTION_LAUNCH; |
+ default: |
+ return PDFACTION_UNSUPPORTED; |
} |
return PDFACTION_UNSUPPORTED; |
} |
-DLLEXPORT FPDF_DEST STDCALL FPDFAction_GetDest(FPDF_DOCUMENT document, FPDF_ACTION action) |
+DLLEXPORT FPDF_DEST STDCALL FPDFAction_GetDest(FPDF_DOCUMENT document, FPDF_ACTION pDict) |
{ |
- if (document == NULL) return NULL; |
- if (action == NULL) return NULL; |
+ if (!document) |
+ return NULL; |
+ if (!pDict) |
+ return NULL; |
CPDF_Document* pDoc = (CPDF_Document*)document; |
- CPDF_Action Action = (CPDF_Dictionary*)action; |
- |
- return Action.GetDest(pDoc); |
+ CPDF_Action action = (CPDF_Dictionary*)pDict; |
+ return action.GetDest(pDoc); |
} |
-DLLEXPORT unsigned long STDCALL FPDFAction_GetURIPath(FPDF_DOCUMENT document, FPDF_ACTION action, |
+DLLEXPORT unsigned long STDCALL FPDFAction_GetURIPath(FPDF_DOCUMENT document, FPDF_ACTION pDict, |
void* buffer, unsigned long buflen) |
{ |
- if (document == NULL) return 0; |
- if (action == NULL) return 0; |
+ if (!document) |
+ return 0; |
+ if (!pDict) |
+ return 0; |
CPDF_Document* pDoc = (CPDF_Document*)document; |
- CPDF_Action Action = (CPDF_Dictionary*)action; |
- |
- CFX_ByteString path = Action.GetURI(pDoc); |
+ CPDF_Action action = (CPDF_Dictionary*)pDict; |
+ CFX_ByteString path = action.GetURI(pDoc); |
unsigned long len = path.GetLength() + 1; |
if (buffer != NULL && buflen >= len) |
FXSYS_memcpy(buffer, path.c_str(), len); |
return len; |
} |
-DLLEXPORT unsigned long STDCALL FPDFDest_GetPageIndex(FPDF_DOCUMENT document, FPDF_DEST dest) |
+DLLEXPORT unsigned long STDCALL FPDFDest_GetPageIndex(FPDF_DOCUMENT document, FPDF_DEST pDict) |
{ |
- if (document == NULL) return 0; |
- if (dest == NULL) return 0; |
+ if (!document) |
+ return 0; |
+ if (!pDict) |
+ return 0; |
CPDF_Document* pDoc = (CPDF_Document*)document; |
- CPDF_Dest Dest = (CPDF_Array*)dest; |
- |
- return Dest.GetPageIndex(pDoc); |
+ CPDF_Dest dest = (CPDF_Array*)pDict; |
+ return dest.GetPageIndex(pDoc); |
} |
static void ReleaseLinkList(FX_LPVOID data) |
@@ -128,42 +132,44 @@ static void ReleaseLinkList(FX_LPVOID data) |
DLLEXPORT FPDF_LINK STDCALL FPDFLink_GetLinkAtPoint(FPDF_PAGE page, double x, double y) |
{ |
- if (page == NULL) return NULL; |
+ if (!page) |
+ return NULL; |
CPDF_Page* pPage = (CPDF_Page*)page; |
- |
// Link list is stored with the document |
CPDF_Document* pDoc = pPage->m_pDocument; |
- CPDF_LinkList* pLinkList = (CPDF_LinkList*)pDoc->GetPrivateData(&this_module); |
- if (pLinkList == NULL) { |
+ CPDF_LinkList* pLinkList = (CPDF_LinkList*)pDoc->GetPrivateData(&THISMODULE); |
+ if (!pLinkList) { |
pLinkList = FX_NEW CPDF_LinkList(pDoc); |
- pDoc->SetPrivateData(&this_module, pLinkList, ReleaseLinkList); |
+ pDoc->SetPrivateData(&THISMODULE, pLinkList, ReleaseLinkList); |
} |
- |
return pLinkList->GetLinkAtPoint(pPage, (FX_FLOAT)x, (FX_FLOAT)y); |
} |
-DLLEXPORT FPDF_DEST STDCALL FPDFLink_GetDest(FPDF_DOCUMENT document, FPDF_LINK link) |
+DLLEXPORT FPDF_DEST STDCALL FPDFLink_GetDest(FPDF_DOCUMENT document, FPDF_LINK pDict) |
{ |
- if (document == NULL) return NULL; |
+ if (!document) |
+ return NULL; |
CPDF_Document* pDoc = (CPDF_Document*)document; |
- if (link == NULL) return NULL; |
- CPDF_Link Link = (CPDF_Dictionary*)link; |
- |
- FPDF_DEST dest = Link.GetDest(pDoc); |
- if (dest) return dest; |
+ if (!pDict) |
+ return NULL; |
+ CPDF_Link link = (CPDF_Dictionary*)pDict; |
+ FPDF_DEST dest = link.GetDest(pDoc); |
+ if (dest) |
+ return dest; |
// If this link is not directly associated with a dest, we try to get action |
- CPDF_Action Action = Link.GetAction(); |
- if (Action == NULL) return NULL; |
- return Action.GetDest(pDoc); |
+ CPDF_Action action = link.GetAction(); |
+ if (!action) |
+ return NULL; |
+ return action.GetDest(pDoc); |
} |
-DLLEXPORT FPDF_ACTION STDCALL FPDFLink_GetAction(FPDF_LINK link) |
+DLLEXPORT FPDF_ACTION STDCALL FPDFLink_GetAction(FPDF_LINK pDict) |
{ |
- if (link == NULL) return NULL; |
- CPDF_Link Link = (CPDF_Dictionary*)link; |
- |
- return Link.GetAction(); |
+ if (!pDict) |
+ return NULL; |
+ CPDF_Link link = (CPDF_Dictionary*)pDict; |
+ return link.GetAction(); |
} |
DLLEXPORT FPDF_BOOL STDCALL FPDFLink_Enumerate(FPDF_PAGE page, int* startPos, FPDF_LINK* linkAnnot) |
@@ -171,15 +177,17 @@ DLLEXPORT FPDF_BOOL STDCALL FPDFLink_Enumerate(FPDF_PAGE page, int* startPos, FP |
if(!page || !startPos || !linkAnnot) |
return FALSE; |
CPDF_Page* pPage = (CPDF_Page*)page; |
- if(!pPage->m_pFormDict) return FALSE; |
+ if(!pPage->m_pFormDict) |
+ return FALSE; |
CPDF_Array* pAnnots = pPage->m_pFormDict->GetArray("Annots"); |
- if(!pAnnots) return FALSE; |
- for (int i = *startPos; i < (int)pAnnots->GetCount(); i ++) { |
+ if(!pAnnots) |
+ return FALSE; |
+ for (int i = *startPos; i < (int)pAnnots->GetCount(); i++) { |
CPDF_Dictionary* pDict = (CPDF_Dictionary*)pAnnots->GetElementValue(i); |
- if (pDict == NULL || pDict->GetType() != PDFOBJ_DICTIONARY) continue; |
- if(pDict->GetString(FX_BSTRC("Subtype")).Equal(FX_BSTRC("Link"))) |
- { |
- *startPos = i+1; |
+ if (!pDict || pDict->GetType() != PDFOBJ_DICTIONARY) |
+ continue; |
+ if(pDict->GetString(FX_BSTRC("Subtype")).Equal(FX_BSTRC("Link"))) { |
+ *startPos = i + 1; |
*linkAnnot = (FPDF_LINK)pDict; |
return TRUE; |
} |
@@ -206,7 +214,7 @@ DLLEXPORT int STDCALL FPDFLink_CountQuadPoints(FPDF_LINK linkAnnot) |
return 0; |
CPDF_Dictionary* pAnnotDict = (CPDF_Dictionary*)linkAnnot; |
CPDF_Array* pArray = pAnnotDict->GetArray(FX_BSTRC("QuadPoints")); |
- if (pArray == NULL) |
+ if (!pArray) |
return 0; |
else |
return pArray->GetCount() / 8; |
@@ -219,8 +227,8 @@ DLLEXPORT FPDF_BOOL STDCALL FPDFLink_GetQuadPoints(FPDF_LINK linkAnnot, int quad |
CPDF_Dictionary* pAnnotDict = (CPDF_Dictionary*)linkAnnot; |
CPDF_Array* pArray = pAnnotDict->GetArray(FX_BSTRC("QuadPoints")); |
if (pArray) { |
- if (0 > quadIndex || quadIndex >= (int)pArray->GetCount()/8 || |
- ((quadIndex*8+7) >= (int)pArray->GetCount())) return FALSE; |
+ if (quadIndex < 0 || quadIndex >= (int)pArray->GetCount()/8 || ((quadIndex*8+7) >= (int)pArray->GetCount())) |
+ return FALSE; |
quadPoints->x1 = pArray->GetNumber(quadIndex*8); |
quadPoints->y1 = pArray->GetNumber(quadIndex*8+1); |
quadPoints->x2 = pArray->GetNumber(quadIndex*8+2); |
@@ -234,27 +242,25 @@ DLLEXPORT FPDF_BOOL STDCALL FPDFLink_GetQuadPoints(FPDF_LINK linkAnnot, int quad |
return FALSE; |
} |
- |
DLLEXPORT unsigned long STDCALL FPDF_GetMetaText(FPDF_DOCUMENT doc, FPDF_BYTESTRING tag, |
void* buffer, unsigned long buflen) |
{ |
- if (doc == NULL || tag == NULL) return 0; |
- |
+ if (!doc || !tag) |
+ return 0; |
CPDF_Document* pDoc = (CPDF_Document*)doc; |
// Get info dictionary |
CPDF_Dictionary* pInfo = pDoc->GetInfo(); |
- if (pInfo == NULL) return 0; |
- |
+ if (!pInfo) |
+ return 0; |
CFX_WideString text = pInfo->GetUnicodeText(tag); |
- |
// Use UTF-16LE encoding |
- CFX_ByteString bstr = text.UTF16LE_Encode(); |
- unsigned long len = bstr.GetLength(); |
- if (buffer != NULL && buflen >= len+2) { |
- FXSYS_memcpy(buffer, bstr.c_str(), len); |
+ CFX_ByteString encodedText = text.UTF16LE_Encode(); |
+ unsigned long len = encodedText.GetLength(); |
+ if (buffer && buflen >= len + 2) { |
+ FXSYS_memcpy(buffer, encodedText.c_str(), len); |
// use double zero as trailer |
- ((FX_BYTE*)buffer)[len] = ((FX_BYTE*)buffer)[len+1] = 0; |
+ ((FX_BYTE*)buffer)[len] = 0; |
+ ((FX_BYTE*)buffer)[len + 1] = 0; |
} |
return len+2; |
} |
- |