Summary: `/*` is the standard throughout open source code. For example, Firefox uses single /*: https://hg.mozilla.org/mozilla-central/file/21d22b2f541258d3d1cf96c7ba5ad73e96e616b5/gfx/ipc/CompositorWidgetVsyncObserver.cpp#l3 In addition, Rust considers `/**` to be a doc comment (similar to Javadoc) and having such a comment at the beginning of the file causes `rustc` to barf. Note that some JavaScript tooling requires `/**`. This is OK since JavaScript files were not covered by the linter in the first place, but it would be good to have that tooling fixed too. Reviewed By: zertosh Differential Revision: D15640366 fbshipit-source-id: b4ed4599071516364d6109720750d6a43304c089
49 lines
1.2 KiB
C++
49 lines
1.2 KiB
C++
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the LICENSE
|
|
* file in the root directory of this source tree.
|
|
*/
|
|
#pragma once
|
|
|
|
#include "FlipperConnection.h"
|
|
#include <string>
|
|
|
|
namespace facebook {
|
|
namespace flipper {
|
|
|
|
class FlipperPlugin {
|
|
public:
|
|
virtual ~FlipperPlugin() {}
|
|
|
|
/**
|
|
The plugin's identifier. This should map to a javascript plugin
|
|
with the same identifier to ensure messages are sent correctly.
|
|
*/
|
|
virtual std::string identifier() const = 0;
|
|
|
|
/**
|
|
Called when a connection has been established between this plugin
|
|
and the corresponding plugin on the Flipper desktop app. The provided
|
|
connection can be used to register method receivers as well as send
|
|
messages back to the desktop app.
|
|
*/
|
|
virtual void didConnect(std::shared_ptr<FlipperConnection> conn) = 0;
|
|
|
|
/**
|
|
Called when a plugin has been disconnected and the FlipperConnection
|
|
provided in didConnect is no longer valid to use.
|
|
*/
|
|
virtual void didDisconnect() = 0;
|
|
|
|
/**
|
|
Returns true if the plugin is meant to be run in background too, otherwise it returns false.
|
|
*/
|
|
virtual bool runInBackground() {
|
|
return false;
|
|
}
|
|
};
|
|
|
|
} // namespace flipper
|
|
} // namespace facebook
|