| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "base/json/json_reader.h" | 5 #include "base/json/json_reader.h" |
| 6 #include "base/values.h" | 6 #include "base/values.h" |
| 7 #include "examples/recipes/recipe_handler/recipe_factory.h" | 7 #include "examples/recipes/recipe_handler/recipe_factory.h" |
| 8 #include "examples/recipes/recipe_handler/recipe_impl.h" | 8 #include "examples/recipes/recipe_handler/recipe_impl.h" |
| 9 #include "mojo/application/application_runner_chromium.h" | 9 #include "mojo/application/application_runner_chromium.h" |
| 10 #include "mojo/application/content_handler_factory.h" | 10 #include "mojo/application/content_handler_factory.h" |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 private: | 30 private: |
| 31 // Overridden from ApplicationDelegate: | 31 // Overridden from ApplicationDelegate: |
| 32 bool ConfigureIncomingConnection( | 32 bool ConfigureIncomingConnection( |
| 33 mojo::ApplicationConnection* connection) override { | 33 mojo::ApplicationConnection* connection) override { |
| 34 connection->AddService(&content_handler_factory_); | 34 connection->AddService(&content_handler_factory_); |
| 35 return true; | 35 return true; |
| 36 } | 36 } |
| 37 | 37 |
| 38 // Overridden from ContentHandlerFactory::ManagedDelegate: | 38 // Overridden from ContentHandlerFactory::ManagedDelegate: |
| 39 scoped_ptr<mojo::ContentHandlerFactory::HandledApplicationHolder> | 39 scoped_ptr<mojo::ContentHandlerFactory::HandledApplicationHolder> |
| 40 CreateApplication(mojo::ShellPtr shell, | 40 CreateApplication( |
| 41 mojo::URLResponsePtr response) override { | 41 mojo::InterfaceRequest<mojo::Application> application_request, |
| 42 mojo::URLResponsePtr response) override { |
| 42 std::string recipe_string; | 43 std::string recipe_string; |
| 43 if (!mojo::common::BlockingCopyToString(response->body.Pass(), | 44 if (!mojo::common::BlockingCopyToString(response->body.Pass(), |
| 44 &recipe_string)) { | 45 &recipe_string)) { |
| 45 LOG(WARNING) << "failed reading recipe"; | 46 LOG(WARNING) << "failed reading recipe"; |
| 46 return nullptr; | 47 return nullptr; |
| 47 } | 48 } |
| 48 | 49 |
| 49 base::JSONReader reader(base::JSON_ALLOW_TRAILING_COMMAS); | 50 base::JSONReader reader(base::JSON_ALLOW_TRAILING_COMMAS); |
| 50 scoped_ptr<base::Value> recipe_value(reader.ReadToValue(recipe_string)); | 51 scoped_ptr<base::Value> recipe_value(reader.ReadToValue(recipe_string)); |
| 51 if (!recipe_value.get()) { | 52 if (!recipe_value.get()) { |
| 52 LOG(WARNING) << "failed parsing recipe: " << reader.GetErrorMessage(); | 53 LOG(WARNING) << "failed parsing recipe: " << reader.GetErrorMessage(); |
| 53 return nullptr; | 54 return nullptr; |
| 54 } | 55 } |
| 55 | 56 |
| 56 if (!recipe_value->IsType(base::Value::TYPE_DICTIONARY)) { | 57 if (!recipe_value->IsType(base::Value::TYPE_DICTIONARY)) { |
| 57 LOG(WARNING) << "recipe is not a dictionary"; | 58 LOG(WARNING) << "recipe is not a dictionary"; |
| 58 return nullptr; | 59 return nullptr; |
| 59 } | 60 } |
| 60 | 61 |
| 61 RecipeImpl* recipe = | 62 RecipeImpl* recipe = |
| 62 CreateRecipe(*static_cast<base::DictionaryValue*>(recipe_value.get())); | 63 CreateRecipe(*static_cast<base::DictionaryValue*>(recipe_value.get())); |
| 63 if (!recipe) | 64 if (!recipe) |
| 64 return nullptr; | 65 return nullptr; |
| 65 | 66 |
| 66 return make_handled_factory_holder( | 67 return make_handled_factory_holder( |
| 67 new mojo::ApplicationImpl(recipe, shell.Pass())); | 68 new mojo::ApplicationImpl(recipe, application_request.Pass())); |
| 68 } | 69 } |
| 69 | 70 |
| 70 mojo::ContentHandlerFactory content_handler_factory_; | 71 mojo::ContentHandlerFactory content_handler_factory_; |
| 71 | 72 |
| 72 DISALLOW_COPY_AND_ASSIGN(RecipeHandlerApp); | 73 DISALLOW_COPY_AND_ASSIGN(RecipeHandlerApp); |
| 73 }; | 74 }; |
| 74 | 75 |
| 75 } // namespace recipe_handler | 76 } // namespace recipe_handler |
| 76 } // namespace recipes | 77 } // namespace recipes |
| 77 | 78 |
| 78 MojoResult MojoMain(MojoHandle shell_handle) { | 79 MojoResult MojoMain(MojoHandle shell_handle) { |
| 79 mojo::ApplicationRunnerChromium runner( | 80 mojo::ApplicationRunnerChromium runner( |
| 80 new recipes::recipe_handler::RecipeHandlerApp()); | 81 new recipes::recipe_handler::RecipeHandlerApp()); |
| 81 return runner.Run(shell_handle); | 82 return runner.Run(shell_handle); |
| 82 } | 83 } |
| OLD | NEW |