| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-present eyeo GmbH | 3 * Copyright (C) 2006-present eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| (...skipping 120 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 131 { | 131 { |
| 132 const JsContext context(*jsEngine); | 132 const JsContext context(*jsEngine); |
| 133 return Utils::StringBufferFromV8String(jsEngine->GetIsolate(), UnwrapValue()); | 133 return Utils::StringBufferFromV8String(jsEngine->GetIsolate(), UnwrapValue()); |
| 134 } | 134 } |
| 135 | 135 |
| 136 int64_t AdblockPlus::JsValue::AsInt() const | 136 int64_t AdblockPlus::JsValue::AsInt() const |
| 137 { | 137 { |
| 138 const JsContext context(*jsEngine); | 138 const JsContext context(*jsEngine); |
| 139 auto currentContext = jsEngine->GetIsolate()->GetCurrentContext(); | 139 auto currentContext = jsEngine->GetIsolate()->GetCurrentContext(); |
| 140 auto value = UnwrapValue()->IntegerValue(currentContext); | 140 auto value = UnwrapValue()->IntegerValue(currentContext); |
| 141 return value.IsJust() ? value.FromJust() : 0; | 141 return CHECKED_TO_VALUE(std::move(value)); |
|
hub
2018/06/22 21:32:39
The test expect that if accessing value throw a JS
|
sergei
2018/08/07 16:47:35
I find the usage of std::move good here too, for t
|
| 142 } | 142 } |
| 143 | 143 |
| 144 bool AdblockPlus::JsValue::AsBool() const | 144 bool AdblockPlus::JsValue::AsBool() const |
| 145 { | 145 { |
| 146 const JsContext context(*jsEngine); | 146 const JsContext context(*jsEngine); |
| 147 auto currentContext = jsEngine->GetIsolate()->GetCurrentContext(); | 147 auto currentContext = jsEngine->GetIsolate()->GetCurrentContext(); |
| 148 auto value = UnwrapValue()->BooleanValue(currentContext); | 148 auto value = UnwrapValue()->BooleanValue(currentContext); |
| 149 return value.IsJust() ? value.FromJust() : false; | 149 return CHECKED_TO_VALUE(std::move(value)); |
| 150 } | 150 } |
| 151 | 151 |
| 152 AdblockPlus::JsValueList AdblockPlus::JsValue::AsList() const | 152 AdblockPlus::JsValueList AdblockPlus::JsValue::AsList() const |
| 153 { | 153 { |
| 154 if (!IsArray()) | 154 if (!IsArray()) |
| 155 throw std::runtime_error("Cannot convert a non-array to list"); | 155 throw std::runtime_error("Cannot convert a non-array to list"); |
| 156 | 156 |
| 157 const JsContext context(*jsEngine); | 157 const JsContext context(*jsEngine); |
| 158 auto isolate = jsEngine->GetIsolate(); | 158 auto isolate = jsEngine->GetIsolate(); |
| 159 auto currentContext = isolate->GetCurrentContext(); | 159 auto currentContext = isolate->GetCurrentContext(); |
| 160 JsValueList result; | 160 JsValueList result; |
| 161 v8::Local<v8::Array> array = v8::Local<v8::Array>::Cast(UnwrapValue()); | 161 v8::Local<v8::Array> array = v8::Local<v8::Array>::Cast(UnwrapValue()); |
| 162 uint32_t length = array->Length(); | 162 uint32_t length = array->Length(); |
| 163 for (uint32_t i = 0; i < length; i++) | 163 for (uint32_t i = 0; i < length; i++) |
| 164 { | 164 { |
| 165 v8::Local<v8::Value> item = CHECKED_TO_LOCAL_NOTHROW( | 165 v8::Local<v8::Value> item = CHECKED_TO_LOCAL( |
| 166 isolate, array->Get(currentContext, i)); | 166 isolate, array->Get(currentContext, i)); |
| 167 result.push_back(JsValue(jsEngine, item)); | 167 result.push_back(JsValue(jsEngine, item)); |
| 168 } | 168 } |
| 169 return result; | 169 return result; |
| 170 } | 170 } |
| 171 | 171 |
| 172 std::vector<std::string> AdblockPlus::JsValue::GetOwnPropertyNames() const | 172 std::vector<std::string> AdblockPlus::JsValue::GetOwnPropertyNames() const |
| 173 { | 173 { |
| 174 if (!IsObject()) | 174 if (!IsObject()) |
| 175 throw std::runtime_error("Attempting to get propert list for a non-object"); | 175 throw std::runtime_error("Attempting to get propert list for a non-object"); |
| 176 | 176 |
| 177 const JsContext context(*jsEngine); | 177 const JsContext context(*jsEngine); |
| 178 auto isolate = jsEngine->GetIsolate(); | 178 auto isolate = jsEngine->GetIsolate(); |
| 179 v8::Local<v8::Object> object = v8::Local<v8::Object>::Cast(UnwrapValue()); | 179 v8::Local<v8::Object> object = v8::Local<v8::Object>::Cast(UnwrapValue()); |
| 180 auto propertyNames = CHECKED_TO_LOCAL_NOTHROW(isolate, | 180 auto propertyNames = CHECKED_TO_LOCAL(isolate, |
| 181 object->GetOwnPropertyNames(isolate->GetCurrentContext())); | 181 object->GetOwnPropertyNames(isolate->GetCurrentContext())); |
| 182 JsValueList properties = JsValue(jsEngine, propertyNames).AsList(); | 182 JsValueList properties = JsValue(jsEngine, propertyNames).AsList(); |
| 183 std::vector<std::string> result; | 183 std::vector<std::string> result; |
| 184 for (const auto& property : properties) | 184 for (const auto& property : properties) |
| 185 result.push_back(property.AsString()); | 185 result.push_back(property.AsString()); |
| 186 return result; | 186 return result; |
| 187 } | 187 } |
| 188 | 188 |
| 189 | 189 |
| 190 AdblockPlus::JsValue AdblockPlus::JsValue::GetProperty(const std::string& name) const | 190 AdblockPlus::JsValue AdblockPlus::JsValue::GetProperty(const std::string& name) const |
| 191 { | 191 { |
| 192 if (!IsObject()) | 192 if (!IsObject()) |
| 193 throw std::runtime_error("Attempting to get property of a non-object"); | 193 throw std::runtime_error("Attempting to get property of a non-object"); |
| 194 | 194 |
| 195 const JsContext context(*jsEngine); | 195 const JsContext context(*jsEngine); |
| 196 auto isolate = jsEngine->GetIsolate(); | 196 auto isolate = jsEngine->GetIsolate(); |
| 197 v8::Local<v8::String> property = CHECKED_TO_LOCAL_NOTHROW( | 197 v8::Local<v8::String> property = CHECKED_TO_LOCAL( |
| 198 isolate, Utils::ToV8String(isolate, name)); | 198 isolate, Utils::ToV8String(isolate, name)); |
| 199 v8::Local<v8::Object> obj = v8::Local<v8::Object>::Cast(UnwrapValue()); | 199 v8::Local<v8::Object> obj = v8::Local<v8::Object>::Cast(UnwrapValue()); |
| 200 return JsValue(jsEngine, CHECKED_TO_LOCAL_NOTHROW( | 200 return JsValue(jsEngine, CHECKED_TO_LOCAL( |
| 201 isolate, obj->Get(isolate->GetCurrentContext(), property))); | 201 isolate, obj->Get(isolate->GetCurrentContext(), property))); |
| 202 } | 202 } |
| 203 | 203 |
| 204 void AdblockPlus::JsValue::SetProperty(const std::string& name, v8::Local<v8::Va lue> val) | 204 void AdblockPlus::JsValue::SetProperty(const std::string& name, v8::Local<v8::Va lue> val) |
| 205 { | 205 { |
| 206 if (!IsObject()) | 206 if (!IsObject()) |
| 207 throw std::runtime_error("Attempting to set property on a non-object"); | 207 throw std::runtime_error("Attempting to set property on a non-object"); |
| 208 auto isolate = jsEngine->GetIsolate(); | 208 auto isolate = jsEngine->GetIsolate(); |
| 209 | 209 |
| 210 v8::Local<v8::String> property = CHECKED_TO_LOCAL_NOTHROW( | 210 v8::Local<v8::String> property = CHECKED_TO_LOCAL( |
| 211 isolate, Utils::ToV8String(isolate, name)); | 211 isolate, Utils::ToV8String(isolate, name)); |
| 212 v8::Local<v8::Object> obj = v8::Local<v8::Object>::Cast(UnwrapValue()); | 212 v8::Local<v8::Object> obj = v8::Local<v8::Object>::Cast(UnwrapValue()); |
| 213 CHECKED_TO_VALUE(obj->Set(isolate->GetCurrentContext(), property, val)); | 213 CHECKED_TO_VALUE(obj->Set(isolate->GetCurrentContext(), property, val)); |
| 214 } | 214 } |
| 215 | 215 |
| 216 v8::Local<v8::Value> AdblockPlus::JsValue::UnwrapValue() const | 216 v8::Local<v8::Value> AdblockPlus::JsValue::UnwrapValue() const |
| 217 { | 217 { |
| 218 return v8::Local<v8::Value>::New(jsEngine->GetIsolate(), *value); | 218 return v8::Local<v8::Value>::New(jsEngine->GetIsolate(), *value); |
| 219 } | 219 } |
| 220 | 220 |
| 221 void AdblockPlus::JsValue::SetProperty(const std::string& name, const std::strin g& val) | 221 void AdblockPlus::JsValue::SetProperty(const std::string& name, const std::strin g& val) |
| 222 { | 222 { |
| 223 const JsContext context(*jsEngine); | 223 const JsContext context(*jsEngine); |
| 224 auto isolate = jsEngine->GetIsolate(); | 224 auto isolate = jsEngine->GetIsolate(); |
| 225 | 225 |
| 226 SetProperty(name, CHECKED_TO_LOCAL_NOTHROW( | 226 SetProperty(name, CHECKED_TO_LOCAL( |
| 227 isolate, Utils::ToV8String(jsEngine->GetIsolate(), val))); | 227 isolate, Utils::ToV8String(jsEngine->GetIsolate(), val))); |
| 228 } | 228 } |
| 229 | 229 |
| 230 void AdblockPlus::JsValue::SetStringBufferProperty(const std::string& name, cons t StringBuffer& val) | 230 void AdblockPlus::JsValue::SetStringBufferProperty(const std::string& name, cons t StringBuffer& val) |
| 231 { | 231 { |
| 232 const JsContext context(*jsEngine); | 232 const JsContext context(*jsEngine); |
| 233 auto isolate = jsEngine->GetIsolate(); | 233 auto isolate = jsEngine->GetIsolate(); |
| 234 | 234 |
| 235 SetProperty(name, CHECKED_TO_LOCAL_NOTHROW( | 235 SetProperty(name, CHECKED_TO_LOCAL( |
| 236 isolate, Utils::StringBufferToV8String(isolate, val))); | 236 isolate, Utils::StringBufferToV8String(isolate, val))); |
| 237 } | 237 } |
| 238 | 238 |
| 239 void AdblockPlus::JsValue::SetProperty(const std::string& name, int64_t val) | 239 void AdblockPlus::JsValue::SetProperty(const std::string& name, int64_t val) |
| 240 { | 240 { |
| 241 const JsContext context(*jsEngine); | 241 const JsContext context(*jsEngine); |
| 242 SetProperty(name, v8::Number::New(jsEngine->GetIsolate(), val)); | 242 SetProperty(name, v8::Number::New(jsEngine->GetIsolate(), val)); |
| 243 } | 243 } |
| 244 | 244 |
| 245 void AdblockPlus::JsValue::SetProperty(const std::string& name, const JsValue& v al) | 245 void AdblockPlus::JsValue::SetProperty(const std::string& name, const JsValue& v al) |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 301 if (!IsFunction()) | 301 if (!IsFunction()) |
| 302 throw std::runtime_error("Attempting to call a non-function"); | 302 throw std::runtime_error("Attempting to call a non-function"); |
| 303 if (!thisObj->IsObject()) | 303 if (!thisObj->IsObject()) |
| 304 throw std::runtime_error("`this` pointer has to be an object"); | 304 throw std::runtime_error("`this` pointer has to be an object"); |
| 305 | 305 |
| 306 const JsContext context(*jsEngine); | 306 const JsContext context(*jsEngine); |
| 307 auto isolate = jsEngine->GetIsolate(); | 307 auto isolate = jsEngine->GetIsolate(); |
| 308 | 308 |
| 309 const v8::TryCatch tryCatch(isolate); | 309 const v8::TryCatch tryCatch(isolate); |
| 310 v8::Local<v8::Function> func = v8::Local<v8::Function>::Cast(UnwrapValue()); | 310 v8::Local<v8::Function> func = v8::Local<v8::Function>::Cast(UnwrapValue()); |
| 311 auto result = CHECKED_TO_LOCAL( | 311 auto result = CHECKED_TO_LOCAL_WITH_TRY_CATCH( |
| 312 isolate, func->Call(isolate->GetCurrentContext(), | 312 isolate, func->Call(isolate->GetCurrentContext(), |
| 313 thisObj, args.size(), args.size() ? &args[0] : nullptr), tryCatch); | 313 thisObj, args.size(), args.size() ? &args[0] : nullptr), tryCatch); |
| 314 | 314 |
| 315 return JsValue(jsEngine, result); | 315 return JsValue(jsEngine, result); |
| 316 } | 316 } |
| LEFT | RIGHT |