2017-03-17 06:55:44 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*/
|
|
|
|
|
2017-04-11 11:57:06 -07:00
|
|
|
#include <React/RCTLog.h>
|
2017-03-17 06:55:44 -07:00
|
|
|
#include <cxxreact/MessageQueueThread.h>
|
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
|
|
|
// RCTNativeModule arranges for native methods to be invoked on a queue which
|
|
|
|
// is not the JS thread. C++ modules don't use RCTNativeModule, so this little
|
|
|
|
// adapter does the work.
|
|
|
|
|
|
|
|
class DispatchMessageQueueThread : public MessageQueueThread {
|
|
|
|
public:
|
|
|
|
DispatchMessageQueueThread(RCTModuleData *moduleData)
|
|
|
|
: moduleData_(moduleData) {}
|
|
|
|
|
|
|
|
void runOnQueue(std::function<void()>&& func) override {
|
2017-04-11 11:57:06 -07:00
|
|
|
dispatch_queue_t queue = moduleData_.methodQueue;
|
|
|
|
dispatch_block_t block = [func=std::move(func)] { func(); };
|
|
|
|
RCTAssert(block != nullptr, @"Invalid block generated in call to %@", moduleData_);
|
|
|
|
if (queue && block) {
|
|
|
|
dispatch_async(queue, block);
|
|
|
|
}
|
2017-03-17 06:55:44 -07:00
|
|
|
}
|
|
|
|
void runOnQueueSync(std::function<void()>&& func) override {
|
|
|
|
LOG(FATAL) << "Unsupported operation";
|
|
|
|
}
|
|
|
|
void quitSynchronous() override {
|
|
|
|
LOG(FATAL) << "Unsupported operation";
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
RCTModuleData *moduleData_;
|
|
|
|
};
|
|
|
|
|
|
|
|
} }
|