Commit 6b213042 authored by Jacek Caban's avatar Jacek Caban Committed by Alexandre Julliard

mshtml: AsyncOpen code clean up.

parent cd07f728
...@@ -629,67 +629,62 @@ static HRESULT create_mon_for_nschannel(nsChannel *channel, IMoniker **mon) ...@@ -629,67 +629,62 @@ static HRESULT create_mon_for_nschannel(nsChannel *channel, IMoniker **mon)
return hres; return hres;
} }
static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListener *aListener, static nsresult async_open_doc_uri(nsChannel *This, NSContainer *container,
nsISupports *aContext) nsIStreamListener *listener, nsISupports *context, BOOL *open)
{ {
nsChannel *This = NSCHANNEL_THIS(iface); IMoniker *mon;
BSCallback *bscallback;
IMoniker *mon = NULL;
PRBool is_doc_uri;
nsresult nsres;
task_t *task;
HRESULT hres; HRESULT hres;
TRACE("(%p)->(%p %p)\n", This, aListener, aContext); *open = FALSE;
nsIWineURI_GetIsDocumentURI(This->uri, &is_doc_uri); if(container->bscallback) {
nsIChannel_AddRef(NSCHANNEL(This));
container->bscallback->nschannel = This;
if(is_doc_uri && (This->load_flags & LOAD_INITIAL_DOCUMENT_URI)) { nsIStreamListener_AddRef(listener);
NSContainer *container; container->bscallback->nslistener = listener;
nsIWineURI_GetNSContainer(This->uri, &container); if(context) {
if(!container) { nsISupports_AddRef(context);
TRACE("container = NULL\n"); container->bscallback->nscontext = context;
return nsIChannel_AsyncOpen(This->channel, aListener, aContext);
} }
if(container->bscallback) { if(do_load_from_moniker_hack(This))
nsIChannel_AddRef(NSCHANNEL(This)); return WINE_NS_LOAD_FROM_MONIKER;
container->bscallback->nschannel = This; }else {
BOOL cont = before_async_open(This, container);
nsIStreamListener_AddRef(aListener);
container->bscallback->nslistener = aListener;
if(aContext) {
nsISupports_AddRef(aContext);
container->bscallback->nscontext = aContext;
}
nsIWebBrowserChrome_Release(NSWBCHROME(container));
if(do_load_from_moniker_hack(This))
return WINE_NS_LOAD_FROM_MONIKER;
}else {
BOOL cont = before_async_open(This, container);
nsIWebBrowserChrome_Release(NSWBCHROME(container));
if(!cont) { if(!cont) {
TRACE("canceled\n"); TRACE("canceled\n");
return NS_ERROR_UNEXPECTED; return NS_ERROR_UNEXPECTED;
} }
if(!container->doc) if(!container->doc) {
return This->channel return This->channel
? nsIChannel_AsyncOpen(This->channel, aListener, aContext) ? nsIChannel_AsyncOpen(This->channel, listener, context)
: NS_ERROR_UNEXPECTED; : NS_ERROR_UNEXPECTED;
}
hres = create_mon_for_nschannel(This, &mon); hres = create_mon_for_nschannel(This, &mon);
if(FAILED(hres)) if(FAILED(hres)) {
return NS_ERROR_UNEXPECTED; return NS_ERROR_UNEXPECTED;
set_current_mon(container->doc, mon);
} }
set_current_mon(container->doc, mon);
} }
*open = TRUE;
return NS_OK;
}
static nsresult async_open(nsChannel *This, NSContainer *container, nsIStreamListener *listener,
nsISupports *context)
{
BSCallback *bscallback;
IMoniker *mon = NULL;
nsresult nsres;
task_t *task;
HRESULT hres;
if(This->channel) { if(This->channel) {
if(This->post_data_stream) { if(This->post_data_stream) {
nsIUploadChannel *upload_channel; nsIUploadChannel *upload_channel;
...@@ -710,7 +705,7 @@ static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListen ...@@ -710,7 +705,7 @@ static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListen
} }
} }
nsres = nsIChannel_AsyncOpen(This->channel, aListener, aContext); nsres = nsIChannel_AsyncOpen(This->channel, listener, context);
if(mon) if(mon)
IMoniker_Release(mon); IMoniker_Release(mon);
...@@ -732,17 +727,17 @@ static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListen ...@@ -732,17 +727,17 @@ static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListen
nsIChannel_AddRef(NSCHANNEL(This)); nsIChannel_AddRef(NSCHANNEL(This));
bscallback->nschannel = This; bscallback->nschannel = This;
nsIStreamListener_AddRef(aListener); nsIStreamListener_AddRef(listener);
bscallback->nslistener = aListener; bscallback->nslistener = listener;
if(aContext) { if(context) {
nsISupports_AddRef(aContext); nsISupports_AddRef(context);
bscallback->nscontext = aContext; bscallback->nscontext = context;
} }
task = mshtml_alloc(sizeof(task_t)); task = mshtml_alloc(sizeof(task_t));
task->doc = bscallback->doc; task->doc = container->doc;
task->task_id = TASK_START_BINDING; task->task_id = TASK_START_BINDING;
task->next = NULL; task->next = NULL;
task->bscallback = bscallback; task->bscallback = bscallback;
...@@ -752,6 +747,35 @@ static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListen ...@@ -752,6 +747,35 @@ static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListen
return NS_OK; return NS_OK;
} }
static nsresult NSAPI nsChannel_AsyncOpen(nsIHttpChannel *iface, nsIStreamListener *aListener,
nsISupports *aContext)
{
nsChannel *This = NSCHANNEL_THIS(iface);
NSContainer *container;
PRBool is_doc_uri;
BOOL open = TRUE;
nsresult nsres = NS_OK;
TRACE("(%p)->(%p %p)\n", This, aListener, aContext);
nsIWineURI_GetNSContainer(This->uri, &container);
if(!container) {
TRACE("container = NULL\n");
return nsIChannel_AsyncOpen(This->channel, aListener, aContext);
}
nsIWineURI_GetIsDocumentURI(This->uri, &is_doc_uri);
if(is_doc_uri && (This->load_flags & LOAD_INITIAL_DOCUMENT_URI))
nsres = async_open_doc_uri(This, container, aListener, aContext, &open);
if(open)
nsres = async_open(This, container, aListener, aContext);
nsIWebBrowserChrome_Release(NSWBCHROME(container));
return nsres;
}
static nsresult NSAPI nsChannel_GetRequestMethod(nsIHttpChannel *iface, nsACString *aRequestMethod) static nsresult NSAPI nsChannel_GetRequestMethod(nsIHttpChannel *iface, nsACString *aRequestMethod)
{ {
nsChannel *This = NSCHANNEL_THIS(iface); nsChannel *This = NSCHANNEL_THIS(iface);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment