| 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 #include "webkit/plugins/ppapi/npapi_glue.h" | 5 #include "webkit/plugins/ppapi/npapi_glue.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
| 9 #include "base/string_util.h" | 9 #include "base/string_util.h" |
| 10 #include "webkit/plugins/ppapi/npobject_var.h" | 10 #include "webkit/plugins/ppapi/npobject_var.h" |
| (...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 152 success_(false), | 152 success_(false), |
| 153 checked_exception_(false) { | 153 checked_exception_(false) { |
| 154 } | 154 } |
| 155 | 155 |
| 156 PPResultAndExceptionToNPResult::~PPResultAndExceptionToNPResult() { | 156 PPResultAndExceptionToNPResult::~PPResultAndExceptionToNPResult() { |
| 157 // The user should have called SetResult or CheckExceptionForNoResult | 157 // The user should have called SetResult or CheckExceptionForNoResult |
| 158 // before letting this class go out of scope, or the exception will have | 158 // before letting this class go out of scope, or the exception will have |
| 159 // been lost. | 159 // been lost. |
| 160 DCHECK(checked_exception_); | 160 DCHECK(checked_exception_); |
| 161 | 161 |
| 162 NPObjectVar::PluginReleasePPVar(exception_); | 162 ResourceTracker::Get()->GetVarTracker()->ReleaseVar(exception_); |
| 163 } | 163 } |
| 164 | 164 |
| 165 // Call this with the return value of the PPAPI function. It will convert | 165 // Call this with the return value of the PPAPI function. It will convert |
| 166 // the result to the NPVariant output parameter and pass any exception on to | 166 // the result to the NPVariant output parameter and pass any exception on to |
| 167 // the JS engine. It will update the success flag and return it. | 167 // the JS engine. It will update the success flag and return it. |
| 168 bool PPResultAndExceptionToNPResult::SetResult(PP_Var result) { | 168 bool PPResultAndExceptionToNPResult::SetResult(PP_Var result) { |
| 169 DCHECK(!checked_exception_); // Don't call more than once. | 169 DCHECK(!checked_exception_); // Don't call more than once. |
| 170 DCHECK(np_result_); // Should be expecting a result. | 170 DCHECK(np_result_); // Should be expecting a result. |
| 171 | 171 |
| 172 checked_exception_ = true; | 172 checked_exception_ = true; |
| 173 | 173 |
| 174 if (has_exception()) { | 174 if (has_exception()) { |
| 175 ThrowException(); | 175 ThrowException(); |
| 176 success_ = false; | 176 success_ = false; |
| 177 } else if (!PPVarToNPVariant(result, np_result_)) { | 177 } else if (!PPVarToNPVariant(result, np_result_)) { |
| 178 WebBindings::setException(object_var_, kInvalidPluginValue); | 178 WebBindings::setException(object_var_, kInvalidPluginValue); |
| 179 success_ = false; | 179 success_ = false; |
| 180 } else { | 180 } else { |
| 181 success_ = true; | 181 success_ = true; |
| 182 } | 182 } |
| 183 | 183 |
| 184 // No matter what happened, we need to release the reference to the | 184 // No matter what happened, we need to release the reference to the |
| 185 // value passed in. On success, a reference to this value will be in | 185 // value passed in. On success, a reference to this value will be in |
| 186 // the np_result_. | 186 // the np_result_. |
| 187 ::ppapi::Var::PluginReleasePPVar(result); | 187 ResourceTracker::Get()->GetVarTracker()->ReleaseVar(result); |
| 188 return success_; | 188 return success_; |
| 189 } | 189 } |
| 190 | 190 |
| 191 // Call this after calling a PPAPI function that could have set the | 191 // Call this after calling a PPAPI function that could have set the |
| 192 // exception. It will pass the exception on to the JS engine and update | 192 // exception. It will pass the exception on to the JS engine and update |
| 193 // the success flag. | 193 // the success flag. |
| 194 // | 194 // |
| 195 // The success flag will be returned. | 195 // The success flag will be returned. |
| 196 bool PPResultAndExceptionToNPResult::CheckExceptionForNoResult() { | 196 bool PPResultAndExceptionToNPResult::CheckExceptionForNoResult() { |
| 197 DCHECK(!checked_exception_); // Don't call more than once. | 197 DCHECK(!checked_exception_); // Don't call more than once. |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 230 const NPVariant* variants) | 230 const NPVariant* variants) |
| 231 : size_(size) { | 231 : size_(size) { |
| 232 if (size_ > 0) { | 232 if (size_ > 0) { |
| 233 array_.reset(new PP_Var[size_]); | 233 array_.reset(new PP_Var[size_]); |
| 234 for (size_t i = 0; i < size_; i++) | 234 for (size_t i = 0; i < size_; i++) |
| 235 array_[i] = NPVariantToPPVar(instance, &variants[i]); | 235 array_[i] = NPVariantToPPVar(instance, &variants[i]); |
| 236 } | 236 } |
| 237 } | 237 } |
| 238 | 238 |
| 239 PPVarArrayFromNPVariantArray::~PPVarArrayFromNPVariantArray() { | 239 PPVarArrayFromNPVariantArray::~PPVarArrayFromNPVariantArray() { |
| 240 ::ppapi::VarTracker* var_tracker = ResourceTracker::Get()->GetVarTracker(); |
| 240 for (size_t i = 0; i < size_; i++) | 241 for (size_t i = 0; i < size_; i++) |
| 241 ::ppapi::Var::PluginReleasePPVar(array_[i]); | 242 var_tracker->ReleaseVar(array_[i]); |
| 242 } | 243 } |
| 243 | 244 |
| 244 // PPVarFromNPObject ----------------------------------------------------------- | 245 // PPVarFromNPObject ----------------------------------------------------------- |
| 245 | 246 |
| 246 PPVarFromNPObject::PPVarFromNPObject(PluginInstance* instance, NPObject* object) | 247 PPVarFromNPObject::PPVarFromNPObject(PluginInstance* instance, NPObject* object) |
| 247 : var_(NPObjectToPPVar(instance, object)) { | 248 : var_(NPObjectToPPVar(instance, object)) { |
| 248 } | 249 } |
| 249 | 250 |
| 250 PPVarFromNPObject::~PPVarFromNPObject() { | 251 PPVarFromNPObject::~PPVarFromNPObject() { |
| 251 ::ppapi::Var::PluginReleasePPVar(var_); | 252 ResourceTracker::Get()->GetVarTracker()->ReleaseVar(var_); |
| 252 } | 253 } |
| 253 | 254 |
| 254 // NPObjectAccessorWithIdentifier ---------------------------------------------- | 255 // NPObjectAccessorWithIdentifier ---------------------------------------------- |
| 255 | 256 |
| 256 NPObjectAccessorWithIdentifier::NPObjectAccessorWithIdentifier( | 257 NPObjectAccessorWithIdentifier::NPObjectAccessorWithIdentifier( |
| 257 NPObject* object, | 258 NPObject* object, |
| 258 NPIdentifier identifier, | 259 NPIdentifier identifier, |
| 259 bool allow_integer_identifier) | 260 bool allow_integer_identifier) |
| 260 : object_(PluginObject::FromNPObject(object)), | 261 : object_(PluginObject::FromNPObject(object)), |
| 261 identifier_(PP_MakeUndefined()) { | 262 identifier_(PP_MakeUndefined()) { |
| 262 if (object_) { | 263 if (object_) { |
| 263 identifier_ = NPIdentifierToPPVar( | 264 identifier_ = NPIdentifierToPPVar( |
| 264 object_->instance()->module()->pp_module(), identifier); | 265 object_->instance()->module()->pp_module(), identifier); |
| 265 if (identifier_.type == PP_VARTYPE_INT32 && !allow_integer_identifier) | 266 if (identifier_.type == PP_VARTYPE_INT32 && !allow_integer_identifier) |
| 266 identifier_.type = PP_VARTYPE_UNDEFINED; // Mark it invalid. | 267 identifier_.type = PP_VARTYPE_UNDEFINED; // Mark it invalid. |
| 267 } | 268 } |
| 268 } | 269 } |
| 269 | 270 |
| 270 NPObjectAccessorWithIdentifier::~NPObjectAccessorWithIdentifier() { | 271 NPObjectAccessorWithIdentifier::~NPObjectAccessorWithIdentifier() { |
| 271 ::ppapi::Var::PluginReleasePPVar(identifier_); | 272 ResourceTracker::Get()->GetVarTracker()->ReleaseVar(identifier_); |
| 272 } | 273 } |
| 273 | 274 |
| 274 // TryCatch -------------------------------------------------------------------- | 275 // TryCatch -------------------------------------------------------------------- |
| 275 | 276 |
| 276 TryCatch::TryCatch(PP_Module module, PP_Var* exception) | 277 TryCatch::TryCatch(PP_Module module, PP_Var* exception) |
| 277 : pp_module_(module), | 278 : pp_module_(module), |
| 278 has_exception_(exception && exception->type != PP_VARTYPE_UNDEFINED), | 279 has_exception_(exception && exception->type != PP_VARTYPE_UNDEFINED), |
| 279 exception_(exception) { | 280 exception_(exception) { |
| 280 WebBindings::pushExceptionHandler(&TryCatch::Catch, this); | 281 WebBindings::pushExceptionHandler(&TryCatch::Catch, this); |
| 281 } | 282 } |
| (...skipping 28 matching lines...) Expand all Loading... |
| 310 } | 311 } |
| 311 } | 312 } |
| 312 | 313 |
| 313 // static | 314 // static |
| 314 void TryCatch::Catch(void* self, const char* message) { | 315 void TryCatch::Catch(void* self, const char* message) { |
| 315 static_cast<TryCatch*>(self)->SetException(message); | 316 static_cast<TryCatch*>(self)->SetException(message); |
| 316 } | 317 } |
| 317 | 318 |
| 318 } // namespace ppapi | 319 } // namespace ppapi |
| 319 } // namespace webkit | 320 } // namespace webkit |
| OLD | NEW |