2017-06-08 07:34:45 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2016-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2017-06-08 07:34:45 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "InspectorInterfaces.h"
|
|
|
|
|
2017-12-15 09:10:47 -08:00
|
|
|
#include <mutex>
|
|
|
|
#include <unordered_map>
|
2018-02-13 08:06:43 -08:00
|
|
|
#include <tuple>
|
2017-12-15 09:10:47 -08:00
|
|
|
|
2017-06-08 07:34:45 -07:00
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
|
|
|
// pure destructors in C++ are odd. You would think they don't want an
|
|
|
|
// implementation, but in fact the linker requires one. Define them to be
|
|
|
|
// empty so that people don't count on them for any particular behaviour.
|
2018-01-25 20:09:09 -08:00
|
|
|
IDestructible::~IDestructible() {}
|
|
|
|
ILocalConnection::~ILocalConnection() {}
|
|
|
|
IRemoteConnection::~IRemoteConnection() {}
|
|
|
|
IInspector::~IInspector() {}
|
2017-06-08 07:34:45 -07:00
|
|
|
|
2017-12-15 09:10:47 -08:00
|
|
|
namespace {
|
|
|
|
|
|
|
|
class InspectorImpl : public IInspector {
|
|
|
|
public:
|
2018-02-13 08:06:43 -08:00
|
|
|
int addPage(const std::string& title, const std::string& vm, ConnectFunc connectFunc) override;
|
2017-12-15 09:10:47 -08:00
|
|
|
void removePage(int pageId) override;
|
|
|
|
|
|
|
|
std::vector<InspectorPage> getPages() const override;
|
|
|
|
std::unique_ptr<ILocalConnection> connect(
|
|
|
|
int pageId,
|
|
|
|
std::unique_ptr<IRemoteConnection> remote) override;
|
|
|
|
|
|
|
|
private:
|
|
|
|
mutable std::mutex mutex_;
|
|
|
|
int nextPageId_{1};
|
2018-02-13 08:06:43 -08:00
|
|
|
std::unordered_map<int, std::tuple<std::string, std::string>> titles_;
|
2017-12-15 09:10:47 -08:00
|
|
|
std::unordered_map<int, ConnectFunc> connectFuncs_;
|
|
|
|
};
|
|
|
|
|
2018-02-13 08:06:43 -08:00
|
|
|
int InspectorImpl::addPage(const std::string& title, const std::string& vm, ConnectFunc connectFunc) {
|
2017-12-15 09:10:47 -08:00
|
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
|
|
|
|
|
|
int pageId = nextPageId_++;
|
2018-02-13 08:06:43 -08:00
|
|
|
titles_[pageId] = std::make_tuple(title, vm);
|
2017-12-15 09:10:47 -08:00
|
|
|
connectFuncs_[pageId] = std::move(connectFunc);
|
|
|
|
|
|
|
|
return pageId;
|
|
|
|
}
|
|
|
|
|
|
|
|
void InspectorImpl::removePage(int pageId) {
|
|
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
|
|
|
|
|
|
titles_.erase(pageId);
|
|
|
|
connectFuncs_.erase(pageId);
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<InspectorPage> InspectorImpl::getPages() const {
|
|
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
|
|
|
|
|
|
std::vector<InspectorPage> inspectorPages;
|
|
|
|
for (auto& it : titles_) {
|
2018-02-13 08:06:43 -08:00
|
|
|
inspectorPages.push_back(InspectorPage{it.first, std::get<0>(it.second), std::get<1>(it.second)});
|
2017-12-15 09:10:47 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
return inspectorPages;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::unique_ptr<ILocalConnection> InspectorImpl::connect(
|
|
|
|
int pageId,
|
|
|
|
std::unique_ptr<IRemoteConnection> remote) {
|
|
|
|
IInspector::ConnectFunc connectFunc;
|
|
|
|
|
|
|
|
{
|
|
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
|
|
|
|
|
|
auto it = connectFuncs_.find(pageId);
|
|
|
|
if (it != connectFuncs_.end()) {
|
|
|
|
connectFunc = it->second;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return connectFunc ? connectFunc(std::move(remote)) : nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
|
|
|
IInspector& getInspectorInstance() {
|
|
|
|
static InspectorImpl instance;
|
|
|
|
return instance;
|
2017-06-08 07:34:45 -07:00
|
|
|
}
|
2017-12-15 09:10:47 -08:00
|
|
|
|
|
|
|
std::unique_ptr<IInspector> makeTestInspectorInstance() {
|
|
|
|
return std::make_unique<InspectorImpl>();
|
2017-06-08 07:34:45 -07:00
|
|
|
}
|
2017-12-15 09:10:47 -08:00
|
|
|
|
|
|
|
} // namespace react
|
|
|
|
} // namespace facebook
|