| Index: mojo/examples/wget/wget.cc | 
| diff --git a/mojo/examples/wget/wget.cc b/mojo/examples/wget/wget.cc | 
| index 9ec7e5cae126d9dfbaf0f338aa53f4cd3c160798..55a8cb85b0be5830a153b61e91000fa7338057e4 100644 | 
| --- a/mojo/examples/wget/wget.cc | 
| +++ b/mojo/examples/wget/wget.cc | 
| @@ -6,68 +6,29 @@ | 
|  | 
| #include "mojo/public/cpp/application/application_delegate.h" | 
| #include "mojo/public/cpp/application/application_impl.h" | 
| +#include "mojo/public/cpp/utility/run_loop.h" | 
| #include "mojo/services/public/interfaces/network/network_service.mojom.h" | 
| #include "mojo/services/public/interfaces/network/url_loader.mojom.h" | 
|  | 
| namespace mojo { | 
| namespace examples { | 
| +namespace { | 
|  | 
| -class WGetApp : public ApplicationDelegate, public URLLoaderClient { | 
| +class ResponsePrinter { | 
| public: | 
| -  virtual void Initialize(ApplicationImpl* app) MOJO_OVERRIDE { | 
| -    app->ConnectToService("mojo:mojo_network_service", &network_service_); | 
| -    Start(); | 
| -  } | 
| - | 
| - private: | 
| -  virtual void OnReceivedRedirect(URLResponsePtr response, | 
| -                                  const String& new_url, | 
| -                                  const String& new_method) MOJO_OVERRIDE { | 
| -    PrintResponse(response); | 
| -  } | 
| - | 
| -  virtual void OnReceivedResponse(URLResponsePtr response) MOJO_OVERRIDE { | 
| -    PrintResponse(response); | 
| -    PrintResponseBody(); | 
| -    Start(); | 
| -  } | 
| - | 
| -  virtual void OnReceivedError(NetworkErrorPtr error) MOJO_OVERRIDE { | 
| -    printf("Got error: %d (%s)\n", | 
| -        error->code, error->description.get().c_str()); | 
| -  } | 
| - | 
| -  virtual void OnReceivedEndOfResponseBody() MOJO_OVERRIDE { | 
| -    // Ignored. | 
| -  } | 
| - | 
| -  void Start() { | 
| -    std::string url = PromptForURL(); | 
| -    printf("Loading: %s\n", url.c_str()); | 
| - | 
| -    network_service_->CreateURLLoader(Get(&url_loader_)); | 
| -    url_loader_.set_client(this); | 
| - | 
| -    URLRequestPtr request(URLRequest::New()); | 
| -    request->url = url; | 
| -    request->method = "GET"; | 
| -    request->auto_follow_redirects = true; | 
| - | 
| -    DataPipe data_pipe; | 
| -    response_body_stream_ = data_pipe.consumer_handle.Pass(); | 
| +  void Run(URLResponsePtr response) const { | 
| +    if (response->error) { | 
| +      printf("Got error: %d (%s)\n", | 
| +          response->error->code, response->error->description.get().c_str()); | 
| +    } else { | 
| +      PrintResponse(response); | 
| +      PrintResponseBody(response->body.Pass()); | 
| +    } | 
|  | 
| -    url_loader_->Start(request.Pass(), data_pipe.producer_handle.Pass()); | 
| +    RunLoop::current()->Quit();  // All done! | 
| } | 
|  | 
| -  std::string PromptForURL() { | 
| -    printf("Enter URL> "); | 
| -    char buf[1024]; | 
| -    if (scanf("%1023s", buf) != 1) | 
| -      buf[0] = '\0'; | 
| -    return buf; | 
| -  } | 
| - | 
| -  void PrintResponse(const URLResponsePtr& response) { | 
| +  void PrintResponse(const URLResponsePtr& response) const { | 
| printf(">>> Headers <<< \n"); | 
| printf("  %s\n", response->status_line.get().c_str()); | 
| if (response->headers) { | 
| @@ -76,20 +37,17 @@ class WGetApp : public ApplicationDelegate, public URLLoaderClient { | 
| } | 
| } | 
|  | 
| -  void PrintResponseBody() { | 
| +  void PrintResponseBody(ScopedDataPipeConsumerHandle body) const { | 
| // Read response body in blocking fashion. | 
| printf(">>> Body <<<\n"); | 
|  | 
| for (;;) { | 
| char buf[512]; | 
| uint32_t num_bytes = sizeof(buf); | 
| -      MojoResult result = ReadDataRaw( | 
| -          response_body_stream_.get(), | 
| -          buf, | 
| -          &num_bytes, | 
| -          MOJO_READ_DATA_FLAG_NONE); | 
| +      MojoResult result = ReadDataRaw(body.get(), buf, &num_bytes, | 
| +                                      MOJO_READ_DATA_FLAG_NONE); | 
| if (result == MOJO_RESULT_SHOULD_WAIT) { | 
| -        Wait(response_body_stream_.get(), | 
| +        Wait(body.get(), | 
| MOJO_HANDLE_SIGNAL_READABLE, | 
| MOJO_DEADLINE_INDEFINITE); | 
| } else if (result == MOJO_RESULT_OK) { | 
| @@ -104,10 +62,42 @@ class WGetApp : public ApplicationDelegate, public URLLoaderClient { | 
|  | 
| printf("\n>>> EOF <<<\n"); | 
| } | 
| +}; | 
| + | 
| +}  // namespace | 
| + | 
| +class WGetApp : public ApplicationDelegate { | 
| + public: | 
| +  virtual void Initialize(ApplicationImpl* app) MOJO_OVERRIDE { | 
| +    app->ConnectToService("mojo:mojo_network_service", &network_service_); | 
| +    Start(); | 
| +  } | 
| + | 
| + private: | 
| +  void Start() { | 
| +    std::string url = PromptForURL(); | 
| +    printf("Loading: %s\n", url.c_str()); | 
| + | 
| +    network_service_->CreateURLLoader(Get(&url_loader_)); | 
| + | 
| +    URLRequestPtr request(URLRequest::New()); | 
| +    request->url = url; | 
| +    request->method = "GET"; | 
| +    request->auto_follow_redirects = true; | 
| + | 
| +    url_loader_->Start(request.Pass(), ResponsePrinter()); | 
| +  } | 
| + | 
| +  std::string PromptForURL() { | 
| +    printf("Enter URL> "); | 
| +    char buf[1024]; | 
| +    if (scanf("%1023s", buf) != 1) | 
| +      buf[0] = '\0'; | 
| +    return buf; | 
| +  } | 
|  | 
| NetworkServicePtr network_service_; | 
| URLLoaderPtr url_loader_; | 
| -  ScopedDataPipeConsumerHandle response_body_stream_; | 
| }; | 
|  | 
| }  // namespace examples | 
|  |