diff options
author | Dan Sinclair <dsinclair@chromium.org> | 2017-04-04 15:07:31 -0400 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2017-04-04 19:41:25 +0000 |
commit | ee62ba2df7297147cccda472f229a8c82bfc22bc (patch) | |
tree | a45f899363c19589937a0edc92d77b25cc1bbd67 /core/fxcrt/cfx_blockbuffer.h | |
parent | 03d58937248fa244cbf02a3d38d430a513500311 (diff) | |
download | pdfium-ee62ba2df7297147cccda472f229a8c82bfc22bc.tar.xz |
Cleanup CFX_BlockBuffer
This CL cleans up default parameters, return values and bits of code
formatting in the CFX_BlockBuffer code.
Change-Id: Ie7fd7d86046f716d0786213735ad464eefc58dbb
Reviewed-on: https://pdfium-review.googlesource.com/3670
Commit-Queue: dsinclair <dsinclair@chromium.org>
Reviewed-by: Nicolás Peña <npm@chromium.org>
Reviewed-by: Tom Sepez <tsepez@chromium.org>
Diffstat (limited to 'core/fxcrt/cfx_blockbuffer.h')
-rw-r--r-- | core/fxcrt/cfx_blockbuffer.h | 31 |
1 files changed, 15 insertions, 16 deletions
diff --git a/core/fxcrt/cfx_blockbuffer.h b/core/fxcrt/cfx_blockbuffer.h index dbf01a938a..e7e493ca86 100644 --- a/core/fxcrt/cfx_blockbuffer.h +++ b/core/fxcrt/cfx_blockbuffer.h @@ -10,44 +10,43 @@ #include <stdint.h> #include <memory> +#include <utility> #include <vector> #include "core/fxcrt/fx_string.h" class CFX_BlockBuffer { public: - explicit CFX_BlockBuffer(int32_t iAllocStep = 1024 * 1024); + CFX_BlockBuffer(); ~CFX_BlockBuffer(); - bool InitBuffer(int32_t iBufferSize = 1024 * 1024); - bool IsInitialized() { return m_iBufferSize / m_iAllocStep >= 1; } + bool InitBuffer(); + bool IsInitialized() { return m_iBufferSize / GetAllocStep() >= 1; } - wchar_t* GetAvailableBlock(int32_t& iIndexInBlock); - inline int32_t GetAllocStep() const { return m_iAllocStep; } - inline int32_t& GetDataLengthRef() { return m_iDataLength; } + std::pair<wchar_t*, int32_t> GetAvailableBlock(); + int32_t GetAllocStep() const; - inline void Reset(bool bReserveData = true) { + // This is ... scary. This returns a ref, which the XMLSyntaxParser stores + // and modifies. + int32_t& GetDataLengthRef() { return m_iDataLength; } + + void Reset(bool bReserveData) { if (!bReserveData) m_iStartPosition = 0; m_iDataLength = 0; } void SetTextChar(int32_t iIndex, wchar_t ch); - int32_t DeleteTextChars(int32_t iCount, bool bDirection = true); - void GetTextData(CFX_WideString& wsTextData, - int32_t iStart = 0, - int32_t iLength = -1) const; + int32_t DeleteTextChars(int32_t iCount); + CFX_WideString GetTextData(int32_t iStart, int32_t iLength) const; private: - inline void TextDataIndex2BufIndex(const int32_t iIndex, - int32_t& iBlockIndex, - int32_t& iInnerIndex) const; - void ClearBuffer(); + std::pair<int32_t, int32_t> TextDataIndex2BufIndex( + const int32_t iIndex) const; std::vector<std::unique_ptr<wchar_t, FxFreeDeleter>> m_BlockArray; int32_t m_iDataLength; int32_t m_iBufferSize; - int32_t m_iAllocStep; int32_t m_iStartPosition; }; |