Chromium Code Reviews| Index: net/url_request/ftp_protocol_handler.cc |
| diff --git a/net/url_request/ftp_protocol_handler.cc b/net/url_request/ftp_protocol_handler.cc |
| index 4c10124ceed561394fb91791304affe231f7b684..aa350ae264b6b0d204802877bdf555dfce204638 100644 |
| --- a/net/url_request/ftp_protocol_handler.cc |
| +++ b/net/url_request/ftp_protocol_handler.cc |
| @@ -5,9 +5,11 @@ |
| #include "net/url_request/ftp_protocol_handler.h" |
| #include "base/logging.h" |
| +#include "base/memory/ptr_util.h" |
| #include "net/base/net_errors.h" |
| #include "net/base/port_util.h" |
| #include "net/ftp/ftp_auth_cache.h" |
| +#include "net/ftp/ftp_network_layer.h" |
| #include "net/url_request/url_request.h" |
| #include "net/url_request/url_request_error_job.h" |
| #include "net/url_request/url_request_ftp_job.h" |
| @@ -15,11 +17,16 @@ |
| namespace net { |
| -FtpProtocolHandler::FtpProtocolHandler( |
| - FtpTransactionFactory* ftp_transaction_factory) |
| - : ftp_transaction_factory_(ftp_transaction_factory), |
| - ftp_auth_cache_(new FtpAuthCache) { |
| - DCHECK(ftp_transaction_factory_); |
| +std::unique_ptr<FtpProtocolHandler> FtpProtocolHandler::Create( |
| + HostResolver* host_resolver) { |
|
eroman
2016/10/19 16:29:51
It would be good to have DCHECK that |host_resolve
mmenke
2016/10/19 17:09:35
SGTM, done. Added to FtpNetworkLayer (Wider cover
|
| + return base::WrapUnique( |
|
eroman
2016/10/19 16:29:51
style: this line uses both WrapUnique and MakeUniq
mmenke
2016/10/19 17:09:35
Switched to WrapUnique (Due to the private constru
|
| + new FtpProtocolHandler(base::MakeUnique<FtpNetworkLayer>(host_resolver))); |
| +} |
| + |
| +std::unique_ptr<FtpProtocolHandler> FtpProtocolHandler::CreateForTesting( |
| + std::unique_ptr<FtpTransactionFactory> ftp_transaction_factory) { |
| + return base::WrapUnique( |
| + new FtpProtocolHandler(std::move(ftp_transaction_factory))); |
| } |
| FtpProtocolHandler::~FtpProtocolHandler() { |
| @@ -34,10 +41,16 @@ URLRequestJob* FtpProtocolHandler::MaybeCreateJob( |
| return new URLRequestErrorJob(request, network_delegate, ERR_UNSAFE_PORT); |
| } |
| - return new URLRequestFtpJob(request, |
| - network_delegate, |
| - ftp_transaction_factory_, |
| + return new URLRequestFtpJob(request, network_delegate, |
| + ftp_transaction_factory_.get(), |
| ftp_auth_cache_.get()); |
| } |
| +FtpProtocolHandler::FtpProtocolHandler( |
| + std::unique_ptr<FtpTransactionFactory> ftp_transaction_factory) |
| + : ftp_transaction_factory_(std::move(ftp_transaction_factory)), |
| + ftp_auth_cache_(new FtpAuthCache) { |
| + DCHECK(ftp_transaction_factory_); |
| +} |
| + |
| } // namespace net |