This app provides monitoring and information features for the common freifunk user and the technical stuff of a freifunk community.
Code base is taken from a TUM Practical Course project and added here to see if Freifunk Altdorf can use it.
https://www.freifunk-altdorf.de
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
43 lines
1.2 KiB
43 lines
1.2 KiB
6 years ago
|
/**
|
||
|
* Copyright (c) 2015-present, Facebook, Inc.
|
||
|
*
|
||
|
* This source code is licensed under the MIT license found in the
|
||
|
* LICENSE file in the root directory of this source tree.
|
||
|
*/
|
||
|
|
||
|
#include <React/RCTLog.h>
|
||
|
#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 {
|
||
|
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);
|
||
|
}
|
||
|
}
|
||
|
void runOnQueueSync(std::function<void()>&& func) override {
|
||
|
LOG(FATAL) << "Unsupported operation";
|
||
|
}
|
||
|
void quitSynchronous() override {
|
||
|
LOG(FATAL) << "Unsupported operation";
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
RCTModuleData *moduleData_;
|
||
|
};
|
||
|
|
||
|
} }
|