diff options
Diffstat (limited to 'chromium/ppapi/shared_impl/ppb_var_shared.cc')
-rw-r--r-- | chromium/ppapi/shared_impl/ppb_var_shared.cc | 49 |
1 files changed, 30 insertions, 19 deletions
diff --git a/chromium/ppapi/shared_impl/ppb_var_shared.cc b/chromium/ppapi/shared_impl/ppb_var_shared.cc index 702a89a6848..d256fc16c14 100644 --- a/chromium/ppapi/shared_impl/ppb_var_shared.cc +++ b/chromium/ppapi/shared_impl/ppb_var_shared.cc @@ -11,6 +11,8 @@ #include "ppapi/c/pp_var.h" #include "ppapi/shared_impl/ppapi_globals.h" #include "ppapi/shared_impl/proxy_lock.h" +#include "ppapi/shared_impl/resource_tracker.h" +#include "ppapi/shared_impl/resource_var.h" #include "ppapi/shared_impl/var.h" #include "ppapi/shared_impl/var_tracker.h" @@ -20,7 +22,6 @@ using ppapi::StringVar; namespace ppapi { namespace { - // PPB_Var methods ------------------------------------------------------------- void AddRefVar(PP_Var var) { @@ -53,20 +54,29 @@ const char* VarToUtf8(PP_Var var, uint32_t* len) { return NULL; } -const PPB_Var var_interface = { - &AddRefVar, - &ReleaseVar, - &VarFromUtf8, - &VarToUtf8 -}; +PP_Resource VarToResource(PP_Var var) { + ProxyAutoLock lock; + ResourceVar* resource = ResourceVar::FromPPVar(var); + if (!resource) + return 0; + PP_Resource pp_resource = resource->GetPPResource(); + PpapiGlobals::Get()->GetResourceTracker()->AddRefResource(pp_resource); + return pp_resource; +} + +PP_Var VarFromResource(PP_Resource resource) { + ProxyAutoLock lock; + return PpapiGlobals::Get()->GetVarTracker()->MakeResourcePPVar(resource); +} + +const PPB_Var var_interface = {&AddRefVar, &ReleaseVar, &VarFromUtf8, + &VarToUtf8, &VarToResource, &VarFromResource}; -const PPB_Var_1_0 var_interface1_0 = { - &AddRefVar, - &ReleaseVar, - &VarFromUtf8_1_0, - &VarToUtf8 -}; +const PPB_Var_1_1 var_interface1_1 = {&AddRefVar, &ReleaseVar, + &VarFromUtf8, &VarToUtf8}; +const PPB_Var_1_0 var_interface1_0 = {&AddRefVar, &ReleaseVar, + &VarFromUtf8_1_0, &VarToUtf8}; // PPB_VarArrayBuffer methods -------------------------------------------------- @@ -101,20 +111,21 @@ void Unmap(PP_Var array) { } const PPB_VarArrayBuffer_1_0 var_arraybuffer_interface = { - &CreateArrayBufferVar, - &ByteLength, - &Map, - &Unmap -}; + &CreateArrayBufferVar, &ByteLength, &Map, &Unmap}; } // namespace // static -const PPB_Var_1_1* PPB_Var_Shared::GetVarInterface1_1() { +const PPB_Var_1_2* PPB_Var_Shared::GetVarInterface1_2() { return &var_interface; } // static +const PPB_Var_1_1* PPB_Var_Shared::GetVarInterface1_1() { + return &var_interface1_1; +} + +// static const PPB_Var_1_0* PPB_Var_Shared::GetVarInterface1_0() { return &var_interface1_0; } |