Closed
Bug 224240
Opened 21 years ago
Closed 21 years ago
nsURIChecker cleanup
Categories
(Core :: Networking, defect)
Core
Networking
Tracking
()
RESOLVED
FIXED
mozilla1.6beta
People
(Reporter: darin.moz, Assigned: darin.moz)
Details
Attachments
(1 file, 2 obsolete files)
36.54 KB,
patch
|
Biesinger
:
review+
bzbarsky
:
superreview+
|
Details | Diff | Splinter Review |
nsURIChecker does a lot of wierd stuff. not sure what i was smoking when i
reviewed it originally. patch coming up...
Assignee | ||
Updated•21 years ago
|
Severity: normal → minor
Status: NEW → ASSIGNED
Target Milestone: --- → mozilla1.6beta
Assignee | ||
Comment 1•21 years ago
|
||
this is an unfinished patch; i'm just posting it here for feedback in case
anyone has interest in further modifications to the interface. i've made the
following changes:
1) added an init method which takes only a nsIURI
2) replaced asyncCheckURI with asyncCheck, which only takes a
nsIRequestObserver and context parameter.
3) replaced baseRequest with baseChannel.
separating these gives consumers the ability to tweak the baseChannel before
calling asyncCheck. also, this init/asyncXXX pattern is more consistent with
other necko interfaces.
next patch will include changes to the consumers of nsIURIChecker.
Assignee | ||
Comment 2•21 years ago
|
||
i forgot to mention that this patch tries to fix some bugs (leaks and borkage)
that can occur when we hit the 404 w/ a NES 3.6 server problem.
Assignee | ||
Comment 3•21 years ago
|
||
Attachment #134518 -
Attachment is obsolete: true
Comment 4•21 years ago
|
||
+ // If we get here, then it's an http channel, not a 100, 200 or 404.
hmm, as I read the patch this will possibly be a 404 at this place (unless the
server is NES 3.x)
Assignee | ||
Comment 5•21 years ago
|
||
yeah, i just carried that comment over... it isn't accurate :(
Assignee | ||
Updated•21 years ago
|
Attachment #134556 -
Flags: superreview?(bz-vacation)
Attachment #134556 -
Flags: review?(cbiesinger)
Assignee | ||
Comment 6•21 years ago
|
||
i've fixed the incorrect comment in my tree.
Comment 7•21 years ago
|
||
Comment on attachment 134556 [details] [diff] [review]
v1 patch
+ rv = lastChannel->GetOriginalURI(getter_AddRefs(uri));
+ rv |= lastChannel->GetLoadFlags(&loadFlags);
I don't really like this, it makes it impossible to find out the real return
value... but it's your module.
+ rv |= mChannel->SetLoadFlags(loadFlags);
what if SetLoadFlags fails but AsyncCheck succeeds - you end up not returning
from this function, and will return NS_BINDING_FAILED later. is that what you
want? it will cause an OnStopRequest immediately, with a failure code, afaict.
+ rv = ios->NewChannelFromURI(aURI, getter_AddRefs(mChannel));
hm... why not NS_NewChannel?
in AsyncCheck
+ mStatus = NS_OK;
wasn't this done in the constructor already?
- // break cycle if we fail to open the channel.
- if (NS_FAILED(rv))
- mChannel = nsnull;
don't you still have to do this? or will all impls of AsyncOpen release their
reference to the notificationCallbacks if they failed?
doesn't the nsIRequest API require the request to add itself to the loadgroup
while pending? you don't seem to do that...
+ NS_ASSERTION(aRequest == mChannel, "unexpected request");
hm, this will be the case even for redirects? for OnStopRequest, this is a
simple if.
+ // break reference cycle between us and the channel (see comment in
don't you need to release the reference to mObserver and mObserverContext as
well?
Attachment #134556 -
Flags: review?(cbiesinger) → review-
Assignee | ||
Comment 8•21 years ago
|
||
>(From update of attachment 134556 [details] [diff] [review])
>+ rv = lastChannel->GetOriginalURI(getter_AddRefs(uri));
>+ rv |= lastChannel->GetLoadFlags(&loadFlags);
>
>I don't really like this, it makes it impossible to find out the real return
>value... but it's your module.
>
>+ rv |= mChannel->SetLoadFlags(loadFlags);
>
>what if SetLoadFlags fails but AsyncCheck succeeds - you end up not returning
>from this function, and will return NS_BINDING_FAILED later. is that what you
>want? it will cause an OnStopRequest immediately, with a failure code, afaict.
good catch. thx!
>+ rv = ios->NewChannelFromURI(aURI, getter_AddRefs(mChannel));
>hm... why not NS_NewChannel?
because that (maybe) adds bloat. the function is inline, and it does a lot
more than we need here. we only need a new channel, we don't need to set load
flags, etc. now, iirc MSVC actually won't inline NS_NewChannel. instead, it
will prefer to share the code amongst all the callers, and thereby only add the
code to necko.dll once. in that case it would be less code.
>in AsyncCheck
>+ mStatus = NS_OK;
>
>wasn't this done in the constructor already?
yup... fixed.
>- // break cycle if we fail to open the channel.
>- if (NS_FAILED(rv))
>- mChannel = nsnull;
>don't you still have to do this? or will all impls of AsyncOpen release their
>reference to the notificationCallbacks if they failed?
you are correct.
>doesn't the nsIRequest API require the request to add itself to the loadgroup
>while pending? you don't seem to do that...
well, not exactly. the only real requirement is that the request be canceled
when the load group is canceled. in this case, the request inserts another
request (the channel), which when canceled causes the nsURIChecker to also
be canceled. that is sufficient.
>
>+ NS_ASSERTION(aRequest == mChannel, "unexpected request");
>
>hm, this will be the case even for redirects? for OnStopRequest, this is a
>simple if.
OnStopRequest is not called by the redirected channel. that's why HTTP has a
OnRedirect, so consumers can intercept a redirect. (i once considered making
OnStopRequest fire for the redirected channel, but i quickly decided against it
once i realized how many OnStopRequest and OnStartRequest implementations
simply didn't care for the information.)
>
>+ // break reference cycle between us and the channel (see comment in
>don't you need to release the reference to mObserver and mObserverContext as
>well?
see SetStatusAndCallback, which is called from OnStartRequest once we have
enough information to notify the observer. since we must always notify the
observer, it seemed appropriate to discard our reference to the observer
immediately after notifying them.
Assignee | ||
Comment 9•21 years ago
|
||
>+ rv = lastChannel->GetOriginalURI(getter_AddRefs(uri));
>+ rv |= lastChannel->GetLoadFlags(&loadFlags);
>
>I don't really like this, it makes it impossible to find out the real return
>value... but it's your module.
i forgot to comment on this one... the idea is that the code only cares if it
can successfully create and open the new channel. if it cannot do so, then it
needs to return with NS_BINDING_FAILED. the value of |rv| itself is
inconsequential.
anyways, if you wanted to debug this code you could always single step to see
the value of returned from each function.
Assignee | ||
Updated•21 years ago
|
Attachment #134556 -
Flags: superreview?(bz-vacation)
Assignee | ||
Comment 10•21 years ago
|
||
revised per comments from biesi.
Assignee | ||
Updated•21 years ago
|
Attachment #134556 -
Attachment is obsolete: true
Assignee | ||
Updated•21 years ago
|
Attachment #134679 -
Flags: superreview?(bz-vacation)
Attachment #134679 -
Flags: review?(cbiesinger)
Updated•21 years ago
|
Attachment #134679 -
Flags: review?(cbiesinger) → review+
Assignee | ||
Updated•21 years ago
|
Whiteboard: [patch needs sr=]
Comment 11•21 years ago
|
||
Comment on attachment 134679 [details] [diff] [review]
v1.1 patch
>Index: netwerk/base/src/nsURIChecker.cpp
>+ServerIsNES3x(nsIHttpChannel *httpChannel)
>+ // case sensitive string comparision is OK here. the server string
"comparison"
>+nsURIChecker::CheckStatus()
>+ rv = Init(uri);
>+ rv |= mChannel->SetLoadFlags(loadFlags);
If the NS_NewChannel() in Init() fails, this will crash, no? Since
getter_AddRefs will null out the mChannel pointer...
sr=bzbarsky with those issues fixed.
Attachment #134679 -
Flags: superreview?(bz-vacation) → superreview+
Assignee | ||
Comment 12•21 years ago
|
||
patch checked in on trunk.
Status: ASSIGNED → RESOLVED
Closed: 21 years ago
Resolution: --- → FIXED
You need to log in
before you can comment on or make changes to this bug.
Description
•