Chromium Code Reviews| OLD | NEW | 
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 #ifndef CHROME_BROWSER_WEBSHARE_SHARE_SERVICE_IMPL_H_ | 5 #ifndef CHROME_BROWSER_WEBSHARE_SHARE_SERVICE_IMPL_H_ | 
| 6 #define CHROME_BROWSER_WEBSHARE_SHARE_SERVICE_IMPL_H_ | 6 #define CHROME_BROWSER_WEBSHARE_SHARE_SERVICE_IMPL_H_ | 
| 7 | 7 | 
| 8 #include <string> | 8 #include <string> | 
| 9 | 9 | 
| 10 #include "base/gtest_prod_util.h" | |
| 10 #include "mojo/public/cpp/bindings/interface_request.h" | 11 #include "mojo/public/cpp/bindings/interface_request.h" | 
| 11 #include "third_party/WebKit/public/platform/modules/webshare/webshare.mojom.h" | 12 #include "third_party/WebKit/public/platform/modules/webshare/webshare.mojom.h" | 
| 12 | 13 | 
| 13 class GURL; | 14 class GURL; | 
| 14 | 15 | 
| 15 // Desktop implementation of the ShareService Mojo service. | 16 // Desktop implementation of the ShareService Mojo service. | 
| 16 class ShareServiceImpl : public blink::mojom::ShareService { | 17 class ShareServiceImpl : public blink::mojom::ShareService { | 
| 17 public: | 18 public: | 
| 18 ShareServiceImpl() = default; | 19 ShareServiceImpl() = default; | 
| 19 ~ShareServiceImpl() override = default; | 20 ~ShareServiceImpl() override = default; | 
| 20 | 21 | 
| 21 static void Create(mojo::InterfaceRequest<ShareService> request); | 22 static void Create(mojo::InterfaceRequest<ShareService> request); | 
| 22 | 23 | 
| 24 // blink::mojom::ShareService overrides: | |
| 23 void Share(const std::string& title, | 25 void Share(const std::string& title, | 
| 24 const std::string& text, | 26 const std::string& text, | 
| 25 const GURL& url, | 27 const GURL& share_url, | 
| 26 const ShareCallback& callback) override; | 28 const ShareCallback& callback) override; | 
| 27 | 29 | 
| 28 private: | 30 private: | 
| 31 FRIEND_TEST_ALL_PREFIXES(ShareServiceImplUnittest, ReplacePlaceholders); | |
| 32 | |
| 33 // Opens a new tab and navigates to |target_url|. | |
| 34 // Virtual for testing purposes. | |
| 35 virtual void OpenTargetURL(const GURL& target_url); | |
| 36 | |
| 37 // Splits |url_template| on %{ and }, and stores in |split_template|. | |
| 38 // Ensures elements at even indices of |split_template| are the substrings | |
| 39 // between %{ and } in the |url_template|. Thus, if } was immediately followed | |
| 
 
Matt Giuca
2017/01/09 03:56:54
nit: Add quotes around the literal bits to make it
 
constantina
2017/01/09 23:51:05
Done.
 
 | |
| 40 // by %{, an empty string is stored. | |
| 
 
Matt Giuca
2017/01/09 03:56:54
Document the return conditions.
 
constantina
2017/01/09 23:51:05
Done.
 
 | |
| 41 static bool SplitTemplate(const std::string& url_template, | |
| 
 
Matt Giuca
2017/01/09 03:56:54
Maybe a quick example to clarify:
Input: "abc%{de
 
Matt Giuca
2017/01/09 03:56:54
This doesn't have to be a static method; it can ju
 
constantina
2017/01/09 23:51:05
Done.
 
constantina
2017/01/09 23:51:05
Done.
 
 | |
| 42 std::vector<base::StringPiece>& split_template); | |
| 43 | |
| 44 // Writes to |url_template_filled|, a copy of |url_template| with all | |
| 45 // instances of "%{title}", "%{text}", and "%{url}" replaced with | |
| 46 // |title|, |text|, and |url| respectively. | |
| 47 // Replaces instances of "%{X}" where "X" is any string besides "title", | |
| 48 // "text", and "url", with an empty string, for forwards compatibility. | |
| 49 // Returns true, if there are badly nested placeholders. | |
| 50 // This includes any case in which two "%{" occur before a "}", or a "}" | |
| 51 // occurs with no preceding "%{". | |
| 52 static bool ReplacePlaceholders(const std::string& url_template, | |
| 53 const std::string& title, | |
| 54 const std::string& text, | |
| 55 const GURL& share_url, | |
| 56 std::string* url_template_filled); | |
| 57 | |
| 29 DISALLOW_COPY_AND_ASSIGN(ShareServiceImpl); | 58 DISALLOW_COPY_AND_ASSIGN(ShareServiceImpl); | 
| 30 }; | 59 }; | 
| 31 | 60 | 
| 32 #endif // CHROME_BROWSER_WEBSHARE_SHARE_SERVICE_IMPL_H_ | 61 #endif // CHROME_BROWSER_WEBSHARE_SHARE_SERVICE_IMPL_H_ | 
| OLD | NEW |