Author: gadamopoulos
Date: Mon Feb  9 22:29:23 2015
New Revision: 66212
URL: 
http://svn.reactos.org/svn/reactos?rev=66212&view=rev
Log:
[BROWSEUI]
- Implement CProgressDialog based on wine
- Patch by Huw Campbell, improved by me
CORE-4476
Added:
    trunk/reactos/dll/win32/browseui/CProgressDialog.cpp   (with props)
    trunk/reactos/dll/win32/browseui/CProgressDialog.h   (with props)
    trunk/reactos/dll/win32/browseui/res/progressdialog.rgs   (with props)
Modified:
    trunk/reactos/dll/win32/browseui/CMakeLists.txt
    trunk/reactos/dll/win32/browseui/browseui.cpp
    trunk/reactos/dll/win32/browseui/browseui.rc
    trunk/reactos/dll/win32/browseui/lang/en-US.rc
    trunk/reactos/dll/win32/browseui/precomp.h
    trunk/reactos/dll/win32/browseui/resource.h
Modified: trunk/reactos/dll/win32/browseui/CMakeLists.txt
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/CMakeLi…
==============================================================================
--- trunk/reactos/dll/win32/browseui/CMakeLists.txt     [iso-8859-1] (original)
+++ trunk/reactos/dll/win32/browseui/CMakeLists.txt     [iso-8859-1] Mon Feb  9 22:29:23
2015
@@ -28,6 +28,7 @@
     toolsband.cpp
     travellog.cpp
     utility.cpp
+    CProgressDialog.cpp
     precomp.h)
 add_library(browseui SHARED
Added: trunk/reactos/dll/win32/browseui/CProgressDialog.cpp
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/CProgre…
==============================================================================
--- trunk/reactos/dll/win32/browseui/CProgressDialog.cpp        (added)
+++ trunk/reactos/dll/win32/browseui/CProgressDialog.cpp        [iso-8859-1] Mon Feb  9
22:29:23 2015
@@ -0,0 +1,453 @@
+/*
+ *     Progress dialog
+ *
+ *  Copyright 2007  Mikolaj Zalewski
+ *     Copyright 2014  Huw Campbell
+ *
+ * this library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * this library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include <precomp.h>
+
+#define COBJMACROS
+
+#define CANCEL_MSG_LINE 2
+
+/* Note: to avoid a deadlock we don't want to send messages to the dialog
+ * with the critical section held. Instead we only mark what fields should be
+ * updated and the dialog proc does the update */
+#define UPDATE_PROGRESS         0x1
+#define UPDATE_TITLE            0x2
+#define UPDATE_LINE1            0x4
+#define UPDATE_LINE2            (UPDATE_LINE1<<1)
+#define UPDATE_LINE3            (UPDATE_LINE1<<2)
+
+
+#define WM_DLG_UPDATE   (WM_APP+1)  /* set to the dialog when it should update */
+#define WM_DLG_DESTROY  (WM_APP+2)  /* DestroyWindow must be called from the owning
thread */
+
+#define ID_3SECONDS 101
+
+CProgressDialog::CProgressDialog()
+{
+    ULONG  cb = 32 *sizeof(WCHAR);
+    this->lines[0]  = (LPWSTR) heap_alloc_zero(cb);
+    this->lines[1]  = (LPWSTR) heap_alloc_zero(cb);
+    this->lines[2]  = (LPWSTR) heap_alloc_zero(cb);
+    this->cancelMsg = (LPWSTR) heap_alloc_zero(cb);
+    this->title     = (LPWSTR) heap_alloc_zero(cb);
+
+    this->clockHand = -1;
+    this->progressClock[29].ullMark = 0ull;
+    this->dwStartTime = GetTickCount();
+
+    InitializeCriticalSection(&this->cs);
+    this->cs.DebugInfo->Spare[0] = (DWORD_PTR)(__FILE__ ":
ProgressDialog.cs");
+}
+
+CProgressDialog::~CProgressDialog()
+{
+    if (this->hwnd)
+        this->end_dialog();
+    heap_free(this->lines[0]);
+    heap_free(this->lines[1]);
+    heap_free(this->lines[2]);
+    heap_free(this->cancelMsg);
+    heap_free(this->title);
+    this->cs.DebugInfo->Spare[0] = 0;
+    DeleteCriticalSection(&this->cs);
+}
+
+static void set_buffer(LPWSTR *buffer, LPCWSTR string)
+{
+    static const WCHAR empty_string[] = {0};
+    ULONG len;
+
+    if (string == NULL)
+        string = empty_string;
+    len = (wcslen(string) + 1)*sizeof(WCHAR);
+
+    LPWSTR tmp = (LPWSTR) heap_realloc(*buffer, len);
+    if (tmp)
+        *buffer = tmp;
+    else
+        len = wcslen(*buffer) + 1;
+
+    StringCchCopyW(*buffer, len, string);
+}
+
+struct create_params
+{
+    CProgressDialog *This;
+    HANDLE hEvent;
+    HWND hwndParent;
+};
+
+static LPWSTR load_string(HINSTANCE hInstance, UINT uiResourceId)
+{
+    WCHAR string[256];
+    LPWSTR ret;
+
+    LoadStringW(hInstance, uiResourceId, string, sizeof(string)/sizeof(string[0]));
+    ret = (LPWSTR) HeapAlloc(GetProcessHeap(), 0, (wcslen(string) + 1) * sizeof(WCHAR));
+    StrCpyW(ret, string);
+    return ret;
+}
+
+void CProgressDialog::set_progress_marquee()
+{
+    HWND hProgress = GetDlgItem(this->hwnd, IDC_PROGRESS_BAR);
+    SetWindowLongW(hProgress, GWL_STYLE,
+        GetWindowLongW(hProgress, GWL_STYLE)|PBS_MARQUEE);
+}
+
+void CProgressDialog::update_dialog(DWORD dwUpdate)
+{
+    WCHAR empty[] = {0};
+
+    if (dwUpdate & UPDATE_TITLE)
+        SetWindowTextW(this->hwnd, this->title);
+
+    if (dwUpdate & UPDATE_LINE1)
+        SetDlgItemTextW(this->hwnd, IDC_TEXT_LINE, (this->isCancelled ? empty :
this->lines[0]));
+    if (dwUpdate & UPDATE_LINE2)
+        SetDlgItemTextW(this->hwnd, IDC_TEXT_LINE+1, (this->isCancelled ? empty :
this->lines[1]));
+    if (dwUpdate & UPDATE_LINE3)
+        SetDlgItemTextW(this->hwnd, IDC_TEXT_LINE+2, (this->isCancelled ?
this->cancelMsg : this->lines[2]));
+
+    if (dwUpdate & UPDATE_PROGRESS)
+    {
+        ULONGLONG ullTotal = this->ullTotal;
+        ULONGLONG ullCompleted = this->ullCompleted;
+
+        /* progress bar requires 32-bit coordinates */
+        while (ullTotal >> 32)
+        {
+            ullTotal >>= 1;
+            ullCompleted >>= 1;
+        }
+
+        SendDlgItemMessageW(this->hwnd, IDC_PROGRESS_BAR, PBM_SETRANGE32, 0,
(DWORD)ullTotal);
+        SendDlgItemMessageW(this->hwnd, IDC_PROGRESS_BAR, PBM_SETPOS,
(DWORD)ullCompleted, 0);
+    }
+}
+
+void CProgressDialog::end_dialog()
+{
+    SendMessageW(this->hwnd, WM_DLG_DESTROY, 0, 0);
+    /* native doesn't re-enable the window? */
+    if (this->hwndDisabledParent)
+        EnableWindow(this->hwndDisabledParent, TRUE);
+    this->hwnd = NULL;
+}
+
+static INT_PTR CALLBACK dialog_proc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
+{
+    CProgressDialog *This = (CProgressDialog *)GetWindowLongPtrW(hwnd, DWLP_USER);
+
+    switch (msg)
+    {
+        case WM_INITDIALOG:
+        {
+            struct create_params *params = (struct create_params *)lParam;
+
+            /* Note: until we set the hEvent, the object is protected by
+             * the critical section held by StartProgress */
+            SetWindowLongPtrW(hwnd, DWLP_USER, (LONG_PTR)params->This);
+            This = params->This;
+            This->hwnd = hwnd;
+
+            if (This->dwFlags & PROGDLG_NOPROGRESSBAR)
+                ShowWindow(GetDlgItem(hwnd, IDC_PROGRESS_BAR), SW_HIDE);
+            if (This->dwFlags & PROGDLG_NOCANCEL)
+                ShowWindow(GetDlgItem(hwnd, IDCANCEL), SW_HIDE);
+            if (This->dwFlags & PROGDLG_MARQUEEPROGRESS)
+                This->set_progress_marquee();
+            if (This->dwFlags & PROGDLG_NOMINIMIZE)
+                SetWindowLongW(hwnd, GWL_STYLE, GetWindowLongW(hwnd, GWL_STYLE) &
(~WS_MINIMIZEBOX));
+
+            This->update_dialog(0xffffffff);
+            This->dwUpdate = 0;
+            This->isCancelled = FALSE;
+
+            SetTimer(hwnd, ID_3SECONDS, 3 * 1000, NULL);
+
+            SetEvent(params->hEvent);
+            return TRUE;
+        }
+
+        case WM_DLG_UPDATE:
+            EnterCriticalSection(&This->cs);
+            This->update_dialog(This->dwUpdate);
+            This->dwUpdate = 0;
+            LeaveCriticalSection(&This->cs);
+            return TRUE;
+
+        case WM_DLG_DESTROY:
+            DestroyWindow(hwnd);
+            PostThreadMessageW(GetCurrentThreadId(), WM_NULL, 0, 0); /* wake up the
GetMessage */
+            KillTimer(hwnd, ID_3SECONDS);
+
+            return TRUE;
+
+        case WM_CLOSE:
+        case WM_COMMAND:
+            if (msg == WM_CLOSE || wParam == IDCANCEL)
+            {
+                EnterCriticalSection(&This->cs);
+                This->isCancelled = TRUE;
+
+                if (!This->cancelMsg[0]) {
+                    heap_free(This->cancelMsg);
+                    This->cancelMsg =
load_string(_AtlBaseModule.GetResourceInstance(), IDS_CANCELLING);
+                }
+
+                This->set_progress_marquee();
+                EnableWindow(GetDlgItem(This->hwnd, IDCANCEL), FALSE);
+                This->update_dialog(UPDATE_LINE1|UPDATE_LINE2|UPDATE_LINE3);
+                LeaveCriticalSection(&This->cs);
+            }
+            return TRUE;
+
+        case WM_TIMER:
+            EnterCriticalSection(&This->cs);
+            if (This->progressClock[29].ullMark != 0ull) {
+                // We have enough info to take a guess
+                ULONGLONG sizeDiff = This->progressClock[This->clockHand].ullMark -
+                                     This->progressClock[(This->clockHand + 29) %
30].ullMark;
+                DWORD     timeDiff = This->progressClock[This->clockHand].dwTime -
+                                     This->progressClock[(This->clockHand + 29) %
30].dwTime;
+                DWORD      runDiff = This->progressClock[This->clockHand].dwTime -
+                                     This->dwStartTime;
+                ULONGLONG sizeLeft = This->ullTotal -
This->progressClock[This->clockHand].ullMark;
+
+                // A guess for time remaining based on the recent slope.
+                DWORD timeLeftD = (DWORD) timeDiff * ((double) sizeLeft) / ((double)
sizeDiff);
+                // A guess for time remaining based on the start time and current
position
+                DWORD timeLeftI = (DWORD) runDiff * ((double) sizeLeft) / ((double)
This->progressClock[This->clockHand].ullMark);
+
+                heap_realloc(&This->lines[2], 128);
+                StrFromTimeIntervalW(This->lines[2], 128, timeLeftD * 0.3 + timeLeftI
* 0.7 , 2);
+                This->update_dialog( UPDATE_LINE1 << 2 );
+            }
+            LeaveCriticalSection(&This->cs);
+
+            return TRUE;
+    }
+    return FALSE;
+}
+
+static DWORD WINAPI dialog_thread(LPVOID lpParameter)
+{
+    /* Note: until we set the hEvent in WM_INITDIALOG, the ProgressDialog object
+     * is protected by the critical section held by StartProgress */
+    struct create_params *params = (struct create_params *) lpParameter;
+    HWND hwnd;
+    MSG msg;
+
+    hwnd = CreateDialogParamW(_AtlBaseModule.GetResourceInstance(),
+                              MAKEINTRESOURCEW(IDD_PROGRESS_DLG),
+                              params->hwndParent,
+                              dialog_proc,
+                             (LPARAM)params);
+
+    while (GetMessageW(&msg, NULL, 0, 0) > 0)
+    {
+        if (!IsWindow(hwnd))
+            break;
+        if(!IsDialogMessageW(hwnd, &msg))
+        {
+            TranslateMessage(&msg);
+            DispatchMessageW(&msg);
+        }
+    }
+
+    return 0;
+}
+
+HRESULT WINAPI CProgressDialog::StartProgressDialog(HWND hwndParent, IUnknown
*punkEnableModeless, DWORD dwFlags, LPCVOID reserved)
+{
+    static const INITCOMMONCONTROLSEX init = { sizeof(init), ICC_ANIMATE_CLASS };
+
+    struct create_params params;
+    HANDLE hThread;
+
+    // TRACE("(%p, %p, %x, %p)\n", this, punkEnableModeless, dwFlags,
reserved);
+    if (punkEnableModeless || reserved)
+        FIXME("Reserved parameters not null (%p, %p)\n", punkEnableModeless,
reserved);
+    if (dwFlags & PROGDLG_AUTOTIME)
+        FIXME("Flags PROGDLG_AUTOTIME not supported\n");
+    if (dwFlags & PROGDLG_NOTIME)
+        FIXME("Flags PROGDLG_NOTIME not supported\n");
+
+    InitCommonControlsEx( &init );
+
+    EnterCriticalSection(&this->cs);
+
+    if (this->hwnd)
+    {
+        LeaveCriticalSection(&this->cs);
+        return S_OK;  /* as on XP */
+    }
+    this->dwFlags = dwFlags;
+    params.This = this;
+    params.hwndParent = hwndParent;
+    params.hEvent = CreateEventW(NULL, TRUE, FALSE, NULL);
+
+    hThread = CreateThread(NULL, 0, dialog_thread, ¶ms, 0, NULL);
+    WaitForSingleObject(params.hEvent, INFINITE);
+    CloseHandle(params.hEvent);
+    CloseHandle(hThread);
+
+    this->hwndDisabledParent = NULL;
+    if (hwndParent && (dwFlags & PROGDLG_MODAL))
+    {
+        HWND hwndDisable = GetAncestor(hwndParent, GA_ROOT);
+        if (EnableWindow(hwndDisable, FALSE))
+            this->hwndDisabledParent = hwndDisable;
+    }
+
+    LeaveCriticalSection(&this->cs);
+
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::StopProgressDialog()
+{
+    EnterCriticalSection(&this->cs);
+    if (this->hwnd)
+        this->end_dialog();
+    LeaveCriticalSection(&this->cs);
+
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::SetTitle(LPCWSTR pwzTitle)
+{
+    HWND hwnd;
+
+    EnterCriticalSection(&this->cs);
+    set_buffer(&this->title, pwzTitle);
+    this->dwUpdate |= UPDATE_TITLE;
+    hwnd = this->hwnd;
+    LeaveCriticalSection(&this->cs);
+
+    if (hwnd)
+        SendMessageW(hwnd, WM_DLG_UPDATE, 0, 0);
+
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::SetAnimation(HINSTANCE hInstance, UINT uiResourceId)
+{
+    return S_OK;
+}
+
+BOOL WINAPI CProgressDialog::HasUserCancelled()
+{
+    return this->isCancelled;
+}
+
+HRESULT WINAPI CProgressDialog::SetProgress64(ULONGLONG ullCompleted, ULONGLONG ullTotal)
+{
+    HWND hwnd;
+
+    EnterCriticalSection(&this->cs);
+    this->ullTotal = ullTotal;
+    this->ullCompleted = ullCompleted;
+
+    if (GetTickCount() - this->progressClock[(this->clockHand + 29) % 30].dwTime
> 20) {
+        this->clockHand = (this->clockHand + 1) % 30;
+        this->progressClock[this->clockHand].ullMark = ullCompleted;
+        this->progressClock[this->clockHand].dwTime = GetTickCount();
+    }
+
+    this->dwUpdate |= UPDATE_PROGRESS;
+    hwnd = this->hwnd;
+    LeaveCriticalSection(&this->cs);
+
+    if (hwnd)
+        SendMessageW(hwnd, WM_DLG_UPDATE, 0, 0);
+
+    return S_OK;  /* Windows sometimes returns S_FALSE */
+}
+
+HRESULT WINAPI CProgressDialog::SetProgress(DWORD dwCompleted, DWORD dwTotal)
+{
+    return this->SetProgress64(dwCompleted, dwTotal);
+}
+
+HRESULT WINAPI CProgressDialog::SetLine(DWORD dwLineNum, LPCWSTR pwzLine, BOOL bPath,
LPCVOID reserved)
+{
+    HWND hwnd;
+
+    if (reserved)
+        FIXME("reserved pointer not null (%p)\n", reserved);
+
+    dwLineNum--;
+    if (dwLineNum >= 3)  /* Windows seems to do something like that */
+        dwLineNum = 0;
+
+    EnterCriticalSection(&this->cs);
+    set_buffer(&this->lines[dwLineNum], pwzLine);
+    this->dwUpdate |= UPDATE_LINE1 << dwLineNum;
+    hwnd = (this->isCancelled ? NULL : this->hwnd); /* no sense to send the message
if window cancelled */
+    LeaveCriticalSection(&this->cs);
+
+    if (hwnd)
+        SendMessageW(hwnd, WM_DLG_UPDATE, 0, 0);
+
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::SetCancelMsg(LPCWSTR pwzMsg, LPCVOID reserved)
+{
+    HWND hwnd;
+
+    if (reserved)
+        FIXME("reserved pointer not null (%p)\n", reserved);
+
+    EnterCriticalSection(&this->cs);
+    set_buffer(&this->cancelMsg, pwzMsg);
+    this->dwUpdate |= UPDATE_LINE1 << CANCEL_MSG_LINE;
+    hwnd = (this->isCancelled ? this->hwnd : NULL); /* no sense to send the message
if window not cancelled */
+    LeaveCriticalSection(&this->cs);
+
+    if (hwnd)
+        SendMessageW(hwnd, WM_DLG_UPDATE, 0, 0);
+
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::Timer(DWORD dwTimerAction, LPCVOID reserved)
+{
+     if (reserved)
+         FIXME("Reserved field not NULL but %p\n", reserved);
+
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::GetWindow(HWND* phwnd)
+{
+    EnterCriticalSection(&this->cs);
+    *phwnd = this->hwnd;
+    LeaveCriticalSection(&this->cs);
+    return S_OK;
+}
+
+HRESULT WINAPI CProgressDialog::ContextSensitiveHelp(BOOL fEnterMode)
+{
+    return E_NOTIMPL;
+}
Propchange: trunk/reactos/dll/win32/browseui/CProgressDialog.cpp
------------------------------------------------------------------------------
    svn:eol-style = native
Added: trunk/reactos/dll/win32/browseui/CProgressDialog.h
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/CProgre…
==============================================================================
--- trunk/reactos/dll/win32/browseui/CProgressDialog.h  (added)
+++ trunk/reactos/dll/win32/browseui/CProgressDialog.h  [iso-8859-1] Mon Feb  9 22:29:23
2015
@@ -0,0 +1,101 @@
+/*
+ * Progress dialog
+ *
+ * Copyright 2014              Huw Campbell
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#ifndef _PROGRESSDIALOG_H_
+#define _PROGRESSDIALOG_H_
+
+class CProgressDialog :
+    public CComCoClass<CProgressDialog, &CLSID_ProgressDialog>,
+    public CComObjectRootEx<CComMultiThreadModelNoCS>,
+    public IProgressDialog,
+    public IOleWindow
+{
+public:
+    CRITICAL_SECTION cs;
+    HWND hwnd;
+    DWORD dwFlags;
+    DWORD dwUpdate;
+    LPWSTR lines[3];
+    LPWSTR cancelMsg;
+    LPWSTR title;
+    BOOL isCancelled;
+    ULONGLONG ullCompleted;
+    ULONGLONG ullTotal;
+    HWND hwndDisabledParent;
+    void set_progress_marquee();
+    void update_dialog(DWORD dwUpdate);
+    void end_dialog();
+
+    UINT clockHand;
+    struct progressMark {
+        ULONGLONG ullMark;
+        DWORD     dwTime;
+    };
+    progressMark progressClock[30];
+    DWORD dwStartTime;
+
+    CProgressDialog();
+    ~CProgressDialog();
+
+    // IProgressDialog
+    virtual HRESULT WINAPI StartProgressDialog(HWND hwndParent, IUnknown
*punkEnableModeless, DWORD dwFlags, LPCVOID reserved);
+    virtual HRESULT WINAPI StopProgressDialog();
+    virtual HRESULT WINAPI SetTitle(LPCWSTR pwzTitle);
+    virtual HRESULT WINAPI SetAnimation(HINSTANCE hInstance, UINT uiResourceId);
+    virtual BOOL    WINAPI HasUserCancelled();
+    virtual HRESULT WINAPI SetProgress64(ULONGLONG ullCompleted, ULONGLONG ullTotal);
+    virtual HRESULT WINAPI SetProgress(DWORD dwCompleted, DWORD dwTotal);
+    virtual HRESULT WINAPI SetLine(DWORD dwLineNum, LPCWSTR pwzLine, BOOL bPath, LPCVOID
reserved);
+    virtual HRESULT WINAPI SetCancelMsg(LPCWSTR pwzMsg, LPCVOID reserved);
+    virtual HRESULT WINAPI Timer(DWORD dwTimerAction, LPCVOID reserved);
+
+    //////// IOleWindow
+    virtual HRESULT WINAPI GetWindow(HWND* phwnd);
+    virtual HRESULT WINAPI ContextSensitiveHelp(BOOL fEnterMode);
+
+DECLARE_REGISTRY_RESOURCEID(IDR_PROGRESSDIALOG)
+DECLARE_NOT_AGGREGATABLE(CProgressDialog)
+
+DECLARE_PROTECT_FINAL_CONSTRUCT()
+
+BEGIN_COM_MAP(CProgressDialog)
+    COM_INTERFACE_ENTRY_IID(IID_IProgressDialog, IProgressDialog)
+    COM_INTERFACE_ENTRY_IID(IID_IOleWindow, IOleWindow)
+END_COM_MAP()
+};
+
+static inline void *heap_alloc(size_t size)
+{
+    return HeapAlloc(GetProcessHeap(), 0, size);
+}
+static inline void *heap_alloc_zero(size_t size)
+{
+    return HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, size);
+}
+static inline void *heap_realloc(void *mem, size_t size)
+{
+    return mem ? HeapReAlloc(GetProcessHeap(), 0, mem, size) : heap_alloc(size);
+}
+static inline BOOL heap_free(void *mem)
+{
+    return HeapFree(GetProcessHeap(), 0, mem);
+}
+
+#endif /* _PROGRESSDIALOG_H_ */
Propchange: trunk/reactos/dll/win32/browseui/CProgressDialog.h
------------------------------------------------------------------------------
    svn:eol-style = native
Modified: trunk/reactos/dll/win32/browseui/browseui.cpp
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/browseu…
==============================================================================
--- trunk/reactos/dll/win32/browseui/browseui.cpp       [iso-8859-1] (original)
+++ trunk/reactos/dll/win32/browseui/browseui.cpp       [iso-8859-1] Mon Feb  9 22:29:23
2015
@@ -39,6 +39,7 @@
 OBJECT_ENTRY(CLSID_InternetToolbar, CInternetToolbar)
 OBJECT_ENTRY(CLSID_CRegTreeOptions, CRegTreeOptions)
 OBJECT_ENTRY(CLSID_ExplorerBand, CExplorerBand)
+OBJECT_ENTRY(CLSID_ProgressDialog, CProgressDialog)
 END_OBJECT_MAP()
 CBrowseUIModule                             gModule;
Modified: trunk/reactos/dll/win32/browseui/browseui.rc
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/browseu…
==============================================================================
--- trunk/reactos/dll/win32/browseui/browseui.rc        [iso-8859-1] (original)
+++ trunk/reactos/dll/win32/browseui/browseui.rc        [iso-8859-1] Mon Feb  9 22:29:23
2015
@@ -42,6 +42,7 @@
 IDR_INTERNETTOOLBAR REGISTRY "res/internettoolbar.rgs"
 IDR_REGTREEOPTIONS REGISTRY "res/regtreeoptions.rgs"
 IDR_EXPLORERBAND REGISTRY "res/explorerband.rgs"
+IDR_PROGRESSDIALOG REGISTRY "res/progressdialog.rgs"
 /*
  * Everything specific to any language goes
Modified: trunk/reactos/dll/win32/browseui/lang/en-US.rc
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/lang/en…
==============================================================================
--- trunk/reactos/dll/win32/browseui/lang/en-US.rc      [iso-8859-1] (original)
+++ trunk/reactos/dll/win32/browseui/lang/en-US.rc      [iso-8859-1] Mon Feb  9 22:29:23
2015
@@ -108,6 +108,19 @@
 /* Dialogs */
+IDD_PROGRESS_DLG DIALOG 0, 0, 260, 85
+STYLE DS_MODALFRAME | DS_CENTER | WS_POPUP | WS_VISIBLE | WS_CLIPCHILDREN | WS_CAPTION |
WS_SYSMENU
+CAPTION ""
+FONT 8, "MS Shell Dlg"
+{
+    CONTROL "", IDC_ANIMATION, ANIMATE_CLASSA, 0, 12, 10, 236, 25 /* TODO:
style */
+    LTEXT "", IDC_TEXT_LINE,     7, 45, 250, 10, SS_LEFT|SS_NOPREFIX
+    LTEXT "", IDC_TEXT_LINE + 1, 7, 55, 250, 10, SS_LEFT|SS_NOPREFIX
+    LTEXT "", IDC_TEXT_LINE + 2, 7, 75, 190, 10, SS_LEFT|SS_NOPREFIX
+    CONTROL "", IDC_PROGRESS_BAR, PROGRESS_CLASSA, WS_BORDER, 7, 65, 190, 8
+    PUSHBUTTON "Cancel", IDCANCEL, 205, 65, 50, 15, WS_GROUP | WS_TABSTOP |
WS_VISIBLE
+}
+
 IDD_CUSTOMIZETOOLBAREX DIALOGEX 0, 0, 357, 33
 STYLE DS_SETFONT | DS_3DLOOK | DS_FIXEDSYS | DS_CONTROL | WS_CHILD | WS_VISIBLE |
WS_CAPTION
 FONT 8, "MS Shell Dlg", 0, 0, 0x1
@@ -141,6 +154,12 @@
 STRINGTABLE
 BEGIN
+    IDS_CANCELLING "Canceling..."
+    IDS_REMAINING  "Remaining"
+END
+
+STRINGTABLE
+BEGIN
     800 "Contains commands for manipulating the selected items."
 END
Modified: trunk/reactos/dll/win32/browseui/precomp.h
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/precomp…
==============================================================================
--- trunk/reactos/dll/win32/browseui/precomp.h  [iso-8859-1] (original)
+++ trunk/reactos/dll/win32/browseui/precomp.h  [iso-8859-1] Mon Feb  9 22:29:23 2015
@@ -22,6 +22,7 @@
 #include <atlwin.h>
 #include <perhist.h>
 #include <exdispid.h>
+#include <Strsafe.h>
 #include <shlwapi.h>
 #include <shlwapi_undoc.h>
 #include <undocshell.h>
@@ -43,6 +44,7 @@
 #include "globalfoldersettings.h"
 #include "regtreeoptions.h"
 #include "explorerband.h"
+#include "CProgressDialog.h"
 #include <stdio.h>
 WINE_DEFAULT_DEBUG_CHANNEL(browseui);
Added: trunk/reactos/dll/win32/browseui/res/progressdialog.rgs
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/res/pro…
==============================================================================
--- trunk/reactos/dll/win32/browseui/res/progressdialog.rgs     (added)
+++ trunk/reactos/dll/win32/browseui/res/progressdialog.rgs     [iso-8859-1] Mon Feb  9
22:29:23 2015
@@ -0,0 +1,13 @@
+HKCR
+{
+       NoRemove CLSID
+       {
+               ForceRemove {F8383852-FCD3-11D1-A6B9-006097DF5BD4} = s 'Progress
Dialog'
+               {
+                       InprocServer32 = s '%MODULE%'
+                       {
+                               val ThreadingModel = s 'Apartment'
+                       }
+               }
+       }
+}
Propchange: trunk/reactos/dll/win32/browseui/res/progressdialog.rgs
------------------------------------------------------------------------------
    svn:eol-style = native
Modified: trunk/reactos/dll/win32/browseui/resource.h
URL:
http://svn.reactos.org/svn/reactos/trunk/reactos/dll/win32/browseui/resourc…
==============================================================================
--- trunk/reactos/dll/win32/browseui/resource.h [iso-8859-1] (original)
+++ trunk/reactos/dll/win32/browseui/resource.h [iso-8859-1] Mon Feb  9 22:29:23 2015
@@ -83,6 +83,7 @@
 #define IDR_GLOBALFOLDERSETTINGS 137
 #define IDR_REGTREEOPTIONS       138
 #define IDR_EXPLORERBAND         139
+#define IDR_PROGRESSDIALOG       140
 #define IDS_SMALLICONS           12301
 #define IDS_LARGEICONS           12302
@@ -100,6 +101,13 @@
 #define IDS_BACK                 58689
 #define IDS_FORWARD              58690
+#define IDS_CANCELLING           16
+#define IDS_REMAINING            17
+#define IDC_ANIMATION            100
+#define IDC_PROGRESS_BAR         102
+#define IDC_TEXT_LINE            103
+#define IDD_PROGRESS_DLG         100
+
 #define IDR_ACCELERATORS 256
 #define IDI_CABINET 103