diff --git a/PowerEditor/src/WinControls/StatusBar/StatusBar.cpp b/PowerEditor/src/WinControls/StatusBar/StatusBar.cpp index 4f6c63b7b..904d1b410 100644 --- a/PowerEditor/src/WinControls/StatusBar/StatusBar.cpp +++ b/PowerEditor/src/WinControls/StatusBar/StatusBar.cpp @@ -46,11 +46,8 @@ enum StatusBar::~StatusBar() { - if (NULL != _hloc) - { - ::LocalUnlock(_hloc); - ::LocalFree(_hloc); - } + if (_lpParts != nullptr) + delete[] _lpParts; } @@ -62,7 +59,6 @@ void StatusBar::init(HINSTANCE /*hInst*/, HWND /*hPere*/) void StatusBar::init(HINSTANCE hInst, HWND hPere, int nbParts) { - assert(nbParts > 0); Window::init(hInst, hPere); InitCommonControls(); @@ -84,8 +80,8 @@ void StatusBar::init(HINSTANCE hInst, HWND hPere, int nbParts) _partWidthArray.resize(nbParts, (int) defaultPartWidth); // Allocate an array for holding the right edge coordinates. - _hloc = ::LocalAlloc(LHND, sizeof(int) * _partWidthArray.size()); - _lpParts = (LPINT)::LocalLock(_hloc); + if (_partWidthArray.size()) + _lpParts = new int[_partWidthArray.size()]; RECT rc; ::GetClientRect(_hParent, &rc); diff --git a/PowerEditor/src/WinControls/StatusBar/StatusBar.h b/PowerEditor/src/WinControls/StatusBar/StatusBar.h index 120bc493e..cadad0375 100644 --- a/PowerEditor/src/WinControls/StatusBar/StatusBar.h +++ b/PowerEditor/src/WinControls/StatusBar/StatusBar.h @@ -60,7 +60,6 @@ private: private: std::vector _partWidthArray; - HLOCAL _hloc = NULL; - LPINT _lpParts = NULL; + int *_lpParts = nullptr; generic_string _lastSetText; }; \ No newline at end of file