1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_SEARCH_ENGINES_TEMPLATE_URL_PARSER_H_
6 #define CHROME_BROWSER_SEARCH_ENGINES_TEMPLATE_URL_PARSER_H_
10 #include "base/basictypes.h"
15 // TemplateURLParser, as the name implies, handling reading of TemplateURLs
16 // from OpenSearch description documents.
17 class TemplateURLParser
{
19 class ParameterFilter
{
21 // Invoked for each parameter of the template URL while parsing. If this
22 // methods returns false, the parameter is not included.
23 virtual bool KeepParameter(const std::string
& key
,
24 const std::string
& value
) = 0;
27 virtual ~ParameterFilter() {}
30 // Decodes the chunk of data representing a TemplateURL, creates the
31 // TemplateURL, and returns it. The caller owns the returned object.
32 // |profile| should only be non-NULL if this function is called on the UI
33 // thread. Returns NULL if data does not describe a valid TemplateURL, the
34 // URLs referenced do not point to valid http/https resources, or for some
35 // other reason we do not support the described TemplateURL.
36 // |parameter_filter| can be used if you want to filter some parameters out of
37 // the URL. For example, when importing from another browser, we remove any
38 // parameter identifying that browser. If set to NULL, the URL is not
40 static TemplateURL
* Parse(Profile
* profile
,
41 bool show_in_default_list
,
44 ParameterFilter
* parameter_filter
);
47 // No one should create one of these.
50 DISALLOW_COPY_AND_ASSIGN(TemplateURLParser
);
53 #endif // CHROME_BROWSER_SEARCH_ENGINES_TEMPLATE_URL_PARSER_H_