Fix code-path leak by using nsCOMPtr.

This commit is contained in:
waterson%netscape.com 1999-12-01 07:04:00 +00:00
Родитель b0f8a35bbe
Коммит 73094f0bbd
2 изменённых файлов: 10 добавлений и 22 удалений

Просмотреть файл

@ -135,22 +135,17 @@ nsChromeProtocolHandler::NewChannel(const char* verb, nsIURI* uri,
NS_WITH_SERVICE(nsIChromeRegistry, reg, kChromeRegistryCID, &rv);
if (NS_FAILED(rv)) return rv;
nsIURI* chromeURI;
rv = uri->Clone(&chromeURI); // don't mangle the original
nsCOMPtr<nsIURI> chromeURI;
rv = uri->Clone(getter_AddRefs(chromeURI)); // don't mangle the original
if (NS_FAILED(rv)) return rv;
rv = reg->ConvertChromeURL(chromeURI);
if (NS_FAILED(rv)) {
NS_RELEASE(chromeURI);
return rv;
}
if (NS_FAILED(rv)) return rv;
// now fetch the converted URI
NS_WITH_SERVICE(nsIIOService, serv, kIOServiceCID, &rv);
if (NS_FAILED(rv)) {
NS_RELEASE(chromeURI);
return rv;
}
if (NS_FAILED(rv)) return rv;
rv = serv->NewChannelFromURI(verb, chromeURI,
aLoadGroup,
@ -175,7 +170,6 @@ nsChromeProtocolHandler::NewChannel(const char* verb, nsIURI* uri,
(*result)->SetOwner(owner);
}
NS_RELEASE(chromeURI);
return rv;
}

Просмотреть файл

@ -135,22 +135,17 @@ nsChromeProtocolHandler::NewChannel(const char* verb, nsIURI* uri,
NS_WITH_SERVICE(nsIChromeRegistry, reg, kChromeRegistryCID, &rv);
if (NS_FAILED(rv)) return rv;
nsIURI* chromeURI;
rv = uri->Clone(&chromeURI); // don't mangle the original
nsCOMPtr<nsIURI> chromeURI;
rv = uri->Clone(getter_AddRefs(chromeURI)); // don't mangle the original
if (NS_FAILED(rv)) return rv;
rv = reg->ConvertChromeURL(chromeURI);
if (NS_FAILED(rv)) {
NS_RELEASE(chromeURI);
return rv;
}
if (NS_FAILED(rv)) return rv;
// now fetch the converted URI
NS_WITH_SERVICE(nsIIOService, serv, kIOServiceCID, &rv);
if (NS_FAILED(rv)) {
NS_RELEASE(chromeURI);
return rv;
}
if (NS_FAILED(rv)) return rv;
rv = serv->NewChannelFromURI(verb, chromeURI,
aLoadGroup,
@ -175,7 +170,6 @@ nsChromeProtocolHandler::NewChannel(const char* verb, nsIURI* uri,
(*result)->SetOwner(owner);
}
NS_RELEASE(chromeURI);
return rv;
}