Index: fxjs/cfxjse_isolatetracker.cpp |
diff --git a/fxjs/cfxjse_isolatetracker.cpp b/fxjs/cfxjse_isolatetracker.cpp |
index 9594df310915db8bcf19bb818a21ae0fc94e9e14..21d09e130e57327c011d6467d4e4be63ff1165f5 100644 |
--- a/fxjs/cfxjse_isolatetracker.cpp |
+++ b/fxjs/cfxjse_isolatetracker.cpp |
@@ -12,8 +12,11 @@ CFXJSE_IsolateTracker::CFXJSE_IsolateTracker() {} |
CFXJSE_IsolateTracker::~CFXJSE_IsolateTracker() {} |
-void CFXJSE_IsolateTracker::Append(v8::Isolate* pIsolate) { |
+void CFXJSE_IsolateTracker::Append( |
+ v8::Isolate* pIsolate, |
+ std::unique_ptr<v8::ArrayBuffer::Allocator> alloc) { |
m_OwnedIsolates.push_back(pIsolate); |
+ m_AllocatorMap[pIsolate] = std::move(alloc); |
} |
void CFXJSE_IsolateTracker::Remove( |
@@ -24,6 +27,10 @@ void CFXJSE_IsolateTracker::Remove( |
if (bFound) |
m_OwnedIsolates.erase(it); |
lpfnDisposeCallback(pIsolate, bFound); |
+ |
+ auto ret = m_AllocatorMap.find(pIsolate); |
Lei Zhang
2016/08/19 18:28:58
Just: m_AllocatorMap.erase(pIsolate);
Wei Li
2016/08/19 21:09:10
Done.
|
+ if (ret != m_AllocatorMap.end()) |
+ m_AllocatorMap.erase(ret); |
} |
void CFXJSE_IsolateTracker::RemoveAll( |
@@ -32,4 +39,5 @@ void CFXJSE_IsolateTracker::RemoveAll( |
lpfnDisposeCallback(pIsolate, true); |
m_OwnedIsolates.clear(); |
+ m_AllocatorMap.clear(); |
} |