webengine/osswebengine/WebKit/win/DefaultDownloadDelegate.cpp
changeset 0 dd21522fd290
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/webengine/osswebengine/WebKit/win/DefaultDownloadDelegate.cpp	Mon Mar 30 12:54:55 2009 +0300
@@ -0,0 +1,243 @@
+/*
+ * Copyright (C) 2007 Apple Inc.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE COMPUTER, INC. OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+ * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
+ * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
+ */
+#include "config.h"
+#include "WebKitDLL.h"
+#include "DefaultDownloadDelegate.h"
+
+#include "MarshallingHelpers.h"
+#include "WebKit.h"
+#include "WebKitLogging.h"
+#include "WebMutableURLRequest.h"
+
+#include <shlobj.h>
+#include <tchar.h>
+
+#pragma warning(push, 0)
+#include <WebCore/BString.h>
+#pragma warning(pop)
+
+using namespace WebCore;
+
+
+// DefaultDownloadDelegate ----------------------------------------------------------------
+
+DefaultDownloadDelegate::DefaultDownloadDelegate()
+    : m_refCount(0)
+{
+    gClassCount++;
+}
+
+DefaultDownloadDelegate::~DefaultDownloadDelegate()
+{
+    gClassCount--;
+    HashSet<IWebDownload*>::iterator i = m_downloads.begin();
+    for (;i != m_downloads.end(); ++i)
+        (*i)->Release();
+}
+
+DefaultDownloadDelegate* DefaultDownloadDelegate::sharedInstance()
+{
+    static COMPtr<DefaultDownloadDelegate> shared;
+    if (!shared)
+        shared.adoptRef(DefaultDownloadDelegate::createInstance());
+    return shared.get();
+}
+
+DefaultDownloadDelegate* DefaultDownloadDelegate::createInstance()
+{
+    DefaultDownloadDelegate* instance = new DefaultDownloadDelegate();
+    instance->AddRef();
+    return instance;
+}
+
+// IUnknown -------------------------------------------------------------------
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::QueryInterface(REFIID riid, void** ppvObject)
+{
+    *ppvObject = 0;
+    if (IsEqualGUID(riid, IID_IUnknown))
+        *ppvObject = static_cast<IUnknown*>(this);
+    else if (IsEqualGUID(riid, IID_IWebDownloadDelegate))
+        *ppvObject = static_cast<IWebDownloadDelegate*>(this);
+    else
+        return E_NOINTERFACE;
+
+    AddRef();
+    return S_OK;
+}
+
+ULONG STDMETHODCALLTYPE DefaultDownloadDelegate::AddRef()
+{
+    return ++m_refCount;
+}
+
+ULONG STDMETHODCALLTYPE DefaultDownloadDelegate::Release()
+{
+    ULONG newRef = --m_refCount;
+    if (!newRef)
+        delete(this);
+
+    return newRef;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::decideDestinationWithSuggestedFilename(IWebDownload *download, BSTR filename)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - decideDestinationWithSuggestedFilename %s", download, String(filename, SysStringLen(filename)).ascii().data());
+
+    TCHAR pathChars[MAX_PATH];
+    if (FAILED(SHGetFolderPath(0, CSIDL_DESKTOPDIRECTORY  | CSIDL_FLAG_CREATE, 0, 0, pathChars))) {
+        if (FAILED(download->setDestination(filename, true))) {
+            LOG_ERROR("Failed to set destination on file");
+            return E_FAIL;
+        }  
+        return S_OK;
+    }
+
+    size_t fullLength = _tcslen(pathChars) + SysStringLen(filename) + 2;
+    BSTR full = SysAllocStringLen(0, (UINT)fullLength);
+    if (!full)
+        return E_OUTOFMEMORY;
+
+    _tcscpy_s(full, fullLength, pathChars);
+    _tcscat_s(full, fullLength, _T("\\"));
+    _tcscat_s(full, fullLength, filename);
+    BString fullPath;
+    fullPath.adoptBSTR(full);
+
+#ifndef NDEBUG
+    String debug((BSTR)fullPath, SysStringLen(BSTR(fullPath)));
+    LOG(Download, "Setting path to %s", debug.ascii().data());
+#endif
+
+    if (FAILED(download->setDestination(fullPath, true))) {
+        LOG_ERROR("Failed to set destination on file");
+        return E_FAIL;
+    }
+    return S_OK;
+}
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didCancelAuthenticationChallenge(IWebDownload* download, IWebURLAuthenticationChallenge* challenge)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didCancelAuthenticationChallenge %p", download, challenge);
+    download = 0;
+    challenge = 0;
+    return S_OK;
+}
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didCreateDestination(IWebDownload* download, BSTR destination)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didCreateDestination %s", download, String(destination, SysStringLen(destination)).ascii().data());
+    download = 0;
+    destination = 0;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didReceiveAuthenticationChallenge(IWebDownload* download, IWebURLAuthenticationChallenge* challenge)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didReceiveAuthenticationChallenge %p", download, challenge);
+    download = 0;
+    challenge = 0;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didReceiveDataOfLength(IWebDownload* download, unsigned length)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didReceiveDataOfLength %i", download, length);
+    download = 0;
+    length = 0;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didReceiveResponse(IWebDownload* download, IWebURLResponse* response)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didReceiveResponse %p", download, response);
+    download = 0;
+    response = 0;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::shouldDecodeSourceDataOfMIMEType(IWebDownload* download, BSTR encodingType, BOOL* shouldDecode)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - shouldDecodeSourceDataOfMIMEType %s", download, String(encodingType, SysStringLen(encodingType)).ascii().data());
+    download = 0;
+    encodingType = 0;
+    *shouldDecode = false;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::willResumeWithResponse(IWebDownload* download, IWebURLResponse* response, long long fromByte)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - willResumeWithResponse %p, %q", download, response, fromByte);
+    download = 0;
+    response = 0;
+    fromByte = 0;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::willSendRequest(IWebDownload* download, IWebMutableURLRequest* request,  
+                                                                 IWebURLResponse* redirectResponse, IWebMutableURLRequest** finalRequest)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - willSendRequest %p %p", download, request, redirectResponse);
+    download = 0;
+    redirectResponse = 0;
+    *finalRequest = request;
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didBegin(IWebDownload* download)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didBegin", download);
+    registerDownload(download);
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didFinish(IWebDownload* download)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didFinish", download);
+    unregisterDownload(download);
+    return S_OK;
+}
+
+HRESULT STDMETHODCALLTYPE DefaultDownloadDelegate::didFailWithError(IWebDownload* download, IWebError* error)
+{
+    LOG(Download, "DefaultDownloadDelegate %p - didFailWithError %p", download, error);
+    unregisterDownload(download);
+    error = 0;
+    return S_OK;
+}
+
+void DefaultDownloadDelegate::registerDownload(IWebDownload* download)
+{
+    if (m_downloads.contains(download))
+        return;
+    download->AddRef();
+    m_downloads.add(download);
+}
+
+void DefaultDownloadDelegate::unregisterDownload(IWebDownload* download)
+{
+    if (m_downloads.contains(download)) {
+        download->Release();
+        m_downloads.remove(download);
+    }
+}