| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_COMMON_NET_URL_FIXER_UPPER_H_ | 5 #ifndef COMPONENTS_URL_FIXER_URL_FIXER_H_ |
| 6 #define CHROME_COMMON_NET_URL_FIXER_UPPER_H_ | 6 #define COMPONENTS_URL_FIXER_URL_FIXER_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/strings/string16.h" | 10 #include "base/strings/string16.h" |
| 11 #include "url/gurl.h" | 11 #include "url/gurl.h" |
| 12 | 12 |
| 13 namespace base { | 13 namespace base { |
| 14 class FilePath; | 14 class FilePath; |
| 15 } | 15 } |
| 16 | 16 |
| 17 namespace url { | 17 namespace url { |
| 18 struct Component; | 18 struct Component; |
| 19 struct Parsed; | 19 struct Parsed; |
| 20 } | 20 } |
| 21 | 21 |
| 22 // This object is designed to convert various types of input into URLs that we | 22 // This object is designed to convert various types of input into URLs that we |
| 23 // know are valid. For example, user typing in the URL bar or command line | 23 // know are valid. For example, user typing in the URL bar or command line |
| 24 // options. This is NOT the place for converting between different types of | 24 // options. This is NOT the place for converting between different types of |
| 25 // URLs or parsing them, see net_util.h for that. | 25 // URLs or parsing them, see net_util.h for that. |
| 26 namespace URLFixerUpper { | 26 namespace url_fixer { |
| 27 | 27 |
| 28 // Segments the given text string into parts of a URL. This is most useful | 28 // Segments the given text string into parts of a URL. This is most useful |
| 29 // for schemes such as http, https, and ftp where |SegmentURL| will find many | 29 // for schemes such as http, https, and ftp where |SegmentURL| will find many |
| 30 // segments. Currently does not segment "file" schemes. | 30 // segments. Currently does not segment "file" schemes. |
| 31 // Returns the canonicalized scheme, or the empty string when |text| is only | 31 // Returns the canonicalized scheme, or the empty string when |text| is only |
| 32 // whitespace. | 32 // whitespace. |
| 33 std::string SegmentURL(const std::string& text, url::Parsed* parts); | 33 std::string SegmentURL(const std::string& text, url::Parsed* parts); |
| 34 base::string16 SegmentURL(const base::string16& text, url::Parsed* parts); | 34 base::string16 SegmentURL(const base::string16& text, url::Parsed* parts); |
| 35 | 35 |
| 36 // Converts |text| to a fixed-up URL and returns it. Attempts to make | 36 // Converts |text| to a fixed-up URL and returns it. Attempts to make |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 73 // scheme component no longer exists. In such a case, the beginning index is | 73 // scheme component no longer exists. In such a case, the beginning index is |
| 74 // set to 0. | 74 // set to 0. |
| 75 // Does nothing if |part| is invalid. | 75 // Does nothing if |part| is invalid. |
| 76 void OffsetComponent(int offset, url::Component* part); | 76 void OffsetComponent(int offset, url::Component* part); |
| 77 | 77 |
| 78 // For paths like ~, we use $HOME for the current user's home | 78 // For paths like ~, we use $HOME for the current user's home |
| 79 // directory. For tests, we allow our idea of $HOME to be overriden | 79 // directory. For tests, we allow our idea of $HOME to be overriden |
| 80 // by this variable. | 80 // by this variable. |
| 81 extern const char* home_directory_override; | 81 extern const char* home_directory_override; |
| 82 | 82 |
| 83 } // namespace URLFixerUpper | 83 } // namespace url_fixer |
| 84 | 84 |
| 85 #endif // CHROME_COMMON_NET_URL_FIXER_UPPER_H_ | 85 #endif // COMPONENTS_URL_FIXER_URL_FIXER_H_ |
| OLD | NEW |