summaryrefslogtreecommitdiffstats
path: root/chromium/ppapi/shared_impl/ppb_var_shared.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/ppapi/shared_impl/ppb_var_shared.cc')
-rw-r--r--chromium/ppapi/shared_impl/ppb_var_shared.cc49
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;
}