| 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_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ | 5 #ifndef CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ |
| 6 #define CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ | 6 #define CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 47 | 47 |
| 48 protected: | 48 protected: |
| 49 | 49 |
| 50 // Returns the path variable encoded at the |i|th index (0-based) in the | 50 // Returns the path variable encoded at the |i|th index (0-based) in the |
| 51 // request URL for this command. If the index is out of bounds, an empty | 51 // request URL for this command. If the index is out of bounds, an empty |
| 52 // string will be returned. | 52 // string will be returned. |
| 53 inline std::string GetPathVariable(const size_t i) const { | 53 inline std::string GetPathVariable(const size_t i) const { |
| 54 return i < path_segments_.size() ? path_segments_.at(i) : ""; | 54 return i < path_segments_.size() ? path_segments_.at(i) : ""; |
| 55 } | 55 } |
| 56 | 56 |
| 57 // Returns the command parameter with the given |key| as a UTF-16 string. | 57 // Provides the command parameter with the given |key| as a UTF-16 string. |
| 58 // Returns true on success. | 58 // Returns true on success. |
| 59 bool GetStringParameter(const std::string& key, string16* out) const; | 59 bool GetStringParameter(const std::string& key, string16* out) const; |
| 60 | 60 |
| 61 // Returns the command parameter with the given |key| as a UTF-8 string. | 61 // Provides the command parameter with the given |key| as a UTF-8 string. |
| 62 // Returns true on success. | 62 // Returns true on success. |
| 63 bool GetStringParameter(const std::string& key, std::string* out) const; | 63 bool GetStringParameter(const std::string& key, std::string* out) const; |
| 64 | 64 |
| 65 // Returns the command parameter with the given |key| as a ASCII string. | 65 // Provides the command parameter with the given |key| as a ASCII string. |
| 66 // Returns true on success. | 66 // Returns true on success. |
| 67 bool GetStringASCIIParameter(const std::string& key, std::string* out) const; | 67 bool GetStringASCIIParameter(const std::string& key, std::string* out) const; |
| 68 | 68 |
| 69 // Returns the command parameter with the given |key| as a boolean. Returns | 69 // Provides the command parameter with the given |key| as a boolean. Returns |
| 70 // false if there is no such parameter, or if it is not a boolean. | 70 // false if there is no such parameter, or if it is not a boolean. |
| 71 bool GetBooleanParameter(const std::string& key, bool* out) const; | 71 bool GetBooleanParameter(const std::string& key, bool* out) const; |
| 72 | 72 |
| 73 // Returns the command parameter with the given |key| as a int. Returns | 73 // Provides the command parameter with the given |key| as a int. Returns |
| 74 // false if there is no such parameter, or if it is not a int. | 74 // false if there is no such parameter, or if it is not a int. |
| 75 bool GetIntegerParameter(const std::string& key, int* out) const; | 75 bool GetIntegerParameter(const std::string& key, int* out) const; |
| 76 | 76 |
| 77 // Returns the command parameter with the given |key| as a list. Returns | 77 // Provides the command parameter with the given |key| as a Dictionary. |
| 78 // Returns false if there is no such parameter, or if it is not a Dictionary. |
| 79 bool GetDictionaryParameter(const std::string& key, |
| 80 DictionaryValue** out) const; |
| 81 |
| 82 // Provides the command parameter with the given |key| as a list. Returns |
| 78 // false if there is no such parameter, or if it is not a list. | 83 // false if there is no such parameter, or if it is not a list. |
| 79 bool GetListParameter(const std::string& key, ListValue** out) const; | 84 bool GetListParameter(const std::string& key, ListValue** out) const; |
| 80 | 85 |
| 81 private: | 86 private: |
| 82 const std::vector<std::string> path_segments_; | 87 const std::vector<std::string> path_segments_; |
| 83 const scoped_ptr<const DictionaryValue> parameters_; | 88 const scoped_ptr<const DictionaryValue> parameters_; |
| 84 | 89 |
| 85 // An autorelease pool must exist on any thread where Objective C is used, | 90 // An autorelease pool must exist on any thread where Objective C is used, |
| 86 // even implicitly. Otherwise the warning: | 91 // even implicitly. Otherwise the warning: |
| 87 // "Objects autoreleased with no pool in place." | 92 // "Objects autoreleased with no pool in place." |
| 88 // is printed for every object deallocted. Since every incomming command to | 93 // is printed for every object deallocted. Since every incomming command to |
| 89 // chrome driver is allocated a new thread, the release pool is declared here. | 94 // chrome driver is allocated a new thread, the release pool is declared here. |
| 90 base::mac::ScopedNSAutoreleasePool autorelease_pool; | 95 base::mac::ScopedNSAutoreleasePool autorelease_pool; |
| 91 | 96 |
| 92 DISALLOW_COPY_AND_ASSIGN(Command); | 97 DISALLOW_COPY_AND_ASSIGN(Command); |
| 93 }; | 98 }; |
| 94 | 99 |
| 95 } // namespace webdriver | 100 } // namespace webdriver |
| 96 | 101 |
| 97 #endif // CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ | 102 #endif // CHROME_TEST_WEBDRIVER_COMMANDS_COMMAND_H_ |
| 98 | 103 |
| OLD | NEW |