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

Side by Side Diff: core/src/fxcrt/fx_basic_plex.cpp

Issue 1143663004: Add safe FX_Alloc2D() macro (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@master
Patch Set: Created 5 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
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 "../../include/fxcrt/fx_basic.h" 7 #include "../../include/fxcrt/fx_basic.h"
8 #include "plex.h" 8 #include "plex.h"
9 CFX_Plex* CFX_Plex::Create(CFX_Plex*& pHead, FX_DWORD nMax, FX_DWORD cbElement) 9 CFX_Plex* CFX_Plex::Create(CFX_Plex*& pHead, FX_DWORD nMax, FX_DWORD cbElement)
10 { 10 {
11 CFX_Plex* p = (CFX_Plex*)FX_Alloc(FX_BYTE, sizeof(CFX_Plex) + nMax * cbEleme nt); 11 CFX_Plex* p = (CFX_Plex*)FX_Alloc(FX_BYTE, sizeof(CFX_Plex) + nMax * cbEleme nt);
Lei Zhang 2015/05/15 23:44:17 Not going to check for overflows / convert to Allo
Tom Sepez 2015/05/18 16:04:30 Ah, this one didn't fit the model and should be cl
12 if (!p) {
13 return NULL;
14 }
15 p->pNext = pHead; 12 p->pNext = pHead;
16 pHead = p; 13 pHead = p;
17 return p; 14 return p;
18 } 15 }
19 void CFX_Plex::FreeDataChain() 16 void CFX_Plex::FreeDataChain()
20 { 17 {
21 CFX_Plex* p = this; 18 CFX_Plex* p = this;
22 while (p != NULL) { 19 while (p != NULL) {
23 FX_BYTE* bytes = (FX_BYTE*)p; 20 FX_BYTE* bytes = (FX_BYTE*)p;
24 CFX_Plex* pNext = p->pNext; 21 CFX_Plex* pNext = p->pNext;
25 FX_Free(bytes); 22 FX_Free(bytes);
26 p = pNext; 23 p = pNext;
27 } 24 }
28 } 25 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698