--- /dev/null
+///////////////////////////////////////////////////////////////////////////////
+// Name: wx/msw/wrapshl.h
+// Purpose: wrapper class for stuff from shell32.dll
+// Author: Vadim Zeitlin
+// Modified by:
+// Created: 2004-10-19
+// RCS-ID: $Id$
+// Copyright: (c) 2004 Vadim Zeitlin <vadim@wxwindows.org>
+// Licence: wxWindows licence
+///////////////////////////////////////////////////////////////////////////////
+
+#ifndef _WX_MSW_WRAPSHL_H_
+#define _WX_MSW_WRAPSHL_H_
+
+#ifdef __WXWINCE__
+ #include <winreg.h>
+ #include <objbase.h>
+ #include <shlguid.h>
+#endif
+
+#include <shlobj.h>
+
+// ----------------------------------------------------------------------------
+// wxItemIdList implements RAII on top of ITEMIDLIST
+// ----------------------------------------------------------------------------
+
+class wxItemIdList
+{
+public:
+ // ctor takes ownership of the item and will free it
+ wxItemIdList(LPITEMIDLIST pidl)
+ {
+ m_pidl = pidl;
+ }
+
+ static void Free(LPITEMIDLIST pidl)
+ {
+ if ( pidl )
+ {
+ LPMALLOC pMalloc;
+ SHGetMalloc(&pMalloc);
+ if ( pMalloc )
+ {
+ pMalloc->Free(pidl);
+ pMalloc->Release();
+ }
+ else
+ {
+ wxLogLastError(wxT("SHGetMalloc"));
+ }
+ }
+ }
+
+ ~wxItemIdList()
+ {
+ Free(m_pidl);
+ }
+
+ // implicit conversion to LPITEMIDLIST
+ operator LPITEMIDLIST() const { return m_pidl; }
+
+ // get the corresponding path, returns empty string on error
+ wxString GetPath() const
+ {
+ wxString path;
+ if ( !SHGetPathFromIDList(m_pidl, wxStringBuffer(path, MAX_PATH)) )
+ {
+ wxLogLastError(_T("SHGetPathFromIDList"));
+ }
+
+ return path;
+ }
+
+private:
+ LPITEMIDLIST m_pidl;
+
+ DECLARE_NO_COPY_CLASS(wxItemIdList)
+};
+
+#endif // _WX_MSW_WRAPSHL_H_
+
#endif
#include "wx/msw/private.h"
-
-#ifdef __WXWINCE__
-#include <winreg.h>
-#include <objbase.h>
-#include <shlguid.h>
-#endif
-#include <shlobj.h> // Win95 shell
+#include "wx/msw/wrapshl.h"
// ----------------------------------------------------------------------------
// constants
// ----------------------------------------------------------------------------
-#ifndef MAX_PATH
- #define MAX_PATH 4096 // be generous
-#endif
-
#ifndef BIF_NEWDIALOGSTYLE
#define BIF_NEWDIALOGSTYLE 0x0040
#endif
// private functions prototypes
// ----------------------------------------------------------------------------
-// free the parameter
-static void ItemListFree(LPITEMIDLIST pidl);
-
// the callback proc for the dir dlg
static int CALLBACK BrowseCallbackProc(HWND hwnd, UINT uMsg, LPARAM lp,
LPARAM pData);
}
// do show the dialog
- LPITEMIDLIST pidl = SHBrowseForFolder(&bi);
+ wxItemIdList pidl(SHBrowseForFolder(&bi));
- if ( bi.pidlRoot )
- {
- ItemListFree((LPITEMIDLIST)bi.pidlRoot);
- }
+ wxItemIdList::Free((LPITEMIDLIST)bi.pidlRoot);
if ( !pidl )
{
return wxID_CANCEL;
}
- BOOL ok = SHGetPathFromIDList(pidl, wxStringBuffer(m_path, MAX_PATH));
-
- ItemListFree(pidl);
-
- if ( !ok )
- {
- wxLogLastError(wxT("SHGetPathFromIDList"));
-
- return wxID_CANCEL;
- }
+ m_path = pidl.GetPath();
- return wxID_OK;
+ return m_path.empty() ? wxID_CANCEL : wxID_OK;
}
// ----------------------------------------------------------------------------
{
switch(uMsg)
{
+#ifdef BFFM_SETSELECTION
case BFFM_INITIALIZED:
// sent immediately after initialisation and so we may set the
// initial selection here
//
// wParam = TRUE => lParam is a string and not a PIDL
-#ifndef __WXWINCE__
::SendMessage(hwnd, BFFM_SETSELECTION, TRUE, pData);
-#endif
break;
+#endif // BFFM_SETSELECTION
+
case BFFM_SELCHANGED:
// note that this doesn't work with the new style UI (MSDN doesn't
}
-static void ItemListFree(LPITEMIDLIST pidl)
-{
- if ( pidl )
- {
- LPMALLOC pMalloc;
- SHGetMalloc(&pMalloc);
- if ( pMalloc )
- {
- pMalloc->Free(pidl);
- pMalloc->Release();
- }
- else
- {
- wxLogLastError(wxT("SHGetMalloc"));
- }
- }
-}
-
#else
#include "../generic/dirdlgg.cpp"
#endif // compiler/platform on which the code here compiles