Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(171)

Side by Side Diff: extensions/browser/file_highlighter.h

Issue 23624002: Add UI for RuntimeErrors in the ErrorConsole (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@dc_ec_merge
Patch Set: Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 EXTENSIONS_BROWSER_MANIFEST_HIGHLIGHTER_H_ 5 #ifndef EXTENSIONS_BROWSER_FILE_HIGHLIGHTER_H_
6 #define EXTENSIONS_BROWSER_MANIFEST_HIGHLIGHTER_H_ 6 #define EXTENSIONS_BROWSER_FILE_HIGHLIGHTER_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
11 11
12 namespace base {
13 class DictionaryValue;
14 }
15
12 namespace extensions { 16 namespace extensions {
13 17
18 // The FileHighlighter class is used in order to isolate and highlight a portion
19 // of a given file (in string form). The Highlighter will split the source into
20 // three portions: the portion before the highlighted feature, the highlighted
21 // feature, and the portion following the highlighted feature.
22 // The file will be parsed for highlighting upon construction of the Highlighter
23 // object.
24 class FileHighlighter {
25 public:
26 virtual ~FileHighlighter();
27
28 // Get the portion of the manifest which should not be highlighted and is
29 // before the feature.
30 std::string GetBeforeFeature() const;
31
32 // Get the feature portion of the manifest, which should be highlighted.
33 std::string GetFeature() const;
34
35 // Get the portion of the manifest which should not be highlighted and is
36 // after the feature.
37 std::string GetAfterFeature() const;
38
39 // Populate a DictionaryValue with the highlighted portions (in UTF16) of the
40 // source file.
41 void HighlightDictionary(base::DictionaryValue* dict) const;
Yoyo Zhou 2013/09/04 23:43:39 This name could be better, like SetHighlightedRegi
Devlin 2013/09/05 17:53:55 Done.
42
43 // The keys used in highlighting a dictionary.
Yoyo Zhou 2013/09/04 23:43:39 These needn't be declared in the header file if th
Devlin 2013/09/05 17:53:55 Done.
44 static const char kBeforeHighlightKey[];
45 static const char kHighlightKey[];
46 static const char kAfterHighlightKey[];
47
48 protected:
49 FileHighlighter(const std::string& contents);
50
51 // The contents of the file we are parsing.
52 std::string contents_;
53
54 // The start of the feature.
55 size_t start_;
56
57 // The end of the feature.
58 size_t end_;
59
60 DISALLOW_COPY_AND_ASSIGN(FileHighlighter);
61 };
62
14 // Use the ManifestHighlighter class to find the bounds of a feature in the 63 // Use the ManifestHighlighter class to find the bounds of a feature in the
15 // manifest. The manifest is parsed for the feature upon construction of the 64 // manifest.
16 // object.
17 // A feature can be at any level in the hierarchy. The "start" of a feature is 65 // A feature can be at any level in the hierarchy. The "start" of a feature is
18 // the first character of the feature name, or the beginning quote of the name, 66 // the first character of the feature name, or the beginning quote of the name,
19 // if present. The "end" of a feature is wherever the next item at the same 67 // if present. The "end" of a feature is wherever the next item at the same
20 // level starts. 68 // level starts.
21 // For instance, the bounds for the 'permissions' feature at the top level could 69 // For instance, the bounds for the 'permissions' feature at the top level could
22 // be '"permissions": { "tabs", "history", "downloads" }', but the feature for 70 // be '"permissions": { "tabs", "history", "downloads" }', but the feature for
23 // 'tabs' within 'permissions' would just be '"tabs"'. 71 // 'tabs' within 'permissions' would just be '"tabs"'.
24 // We can't use the JSONParser to do this, because we want to display the actual 72 // We can't use the JSONParser to do this, because we want to display the actual
25 // manifest, and once we parse it into Values, we lose any formatting the user 73 // manifest, and once we parse it into Values, we lose any formatting the user
26 // may have had. 74 // may have had.
27 // If a feature cannot be found, the feature will have zero-length. 75 // If a feature cannot be found, the feature will have zero-length.
28 class ManifestHighlighter { 76 class ManifestHighlighter : public FileHighlighter {
29 public: 77 public:
30 ManifestHighlighter(const std::string& manifest, 78 ManifestHighlighter(const std::string& manifest,
31 const std::string& key, 79 const std::string& key,
32 const std::string& specific /* optional */); 80 const std::string& specific /* optional */);
33 ~ManifestHighlighter(); 81 virtual ~ManifestHighlighter();
34
35 // Get the portion of the manifest which should not be highlighted and is
36 // before the feature.
37 std::string GetBeforeFeature() const;
38
39 // Get the feature portion of the manifest, which should be highlighted.
40 std::string GetFeature() const;
41
42 // Get the portion of the manifest which should not be highlighted and is
43 // after the feature.
44 std::string GetAfterFeature() const;
45 82
46 private: 83 private:
47 // Called from the constructor; determine the start and end bounds of a 84 // Called from the constructor; determine the start and end bounds of a
48 // feature, using both the key and specific information. 85 // feature, using both the key and specific information.
49 void Parse(const std::string& key, const std::string& specific); 86 void Parse(const std::string& key, const std::string& specific);
50 87
51 // Find the bounds of any feature, either a full key or a specific item within 88 // Find the bounds of any feature, either a full key or a specific item within
52 // the key. |enforce_at_top_level| means that the feature we find must be at 89 // the key. |enforce_at_top_level| means that the feature we find must be at
53 // the same level as |start_| (i.e., ignore nested elements). 90 // the same level as |start_| (i.e., ignore nested elements).
54 // Returns true on success. 91 // Returns true on success.
55 bool FindBounds(const std::string& feature, bool enforce_at_top_level); 92 bool FindBounds(const std::string& feature, bool enforce_at_top_level);
56 93
57 // Finds the end of the feature. 94 // Finds the end of the feature.
58 void FindBoundsEnd(const std::string& feature, size_t local_start); 95 void FindBoundsEnd(const std::string& feature, size_t local_start);
59 96
60 // The manifest we are parsing.
61 std::string manifest_;
62
63 // The start of the feature.
64 size_t start_;
65
66 // The end of the feature.
67 size_t end_;
68
69 DISALLOW_COPY_AND_ASSIGN(ManifestHighlighter); 97 DISALLOW_COPY_AND_ASSIGN(ManifestHighlighter);
70 }; 98 };
71 99
100 // Use the SourceHighlighter to highlight a particular line in a given source
101 // file.
102 class SourceHighlighter : public FileHighlighter {
103 public:
104 SourceHighlighter(const std::string& source, size_t line_number);
105 virtual ~SourceHighlighter();
106
107 private:
108 // Called from the constructor; determine the bounds of the line in the source
109 // file.
110 void Parse(size_t line_number);
111
112 DISALLOW_COPY_AND_ASSIGN(SourceHighlighter);
113 };
114
72 } // namespace extensions 115 } // namespace extensions
73 116
74 #endif // EXTENSIONS_BROWSER_MANIFEST_HIGHLIGHTER_H_ 117 #endif // EXTENSIONS_BROWSER_FILE_HIGHLIGHTER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698