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
64 lines
1.6 KiB
C++
64 lines
1.6 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.
|
|
*/
|
|
#include "YGConfig.h"
|
|
#include "YGMarker.h"
|
|
#include "YGNode.h"
|
|
|
|
namespace facebook {
|
|
namespace yoga {
|
|
namespace marker {
|
|
|
|
template <YGMarker MarkerType>
|
|
class MarkerSection {
|
|
private:
|
|
using Data = detail::MarkerData<MarkerType>;
|
|
|
|
public:
|
|
MarkerSection(YGNodeRef node) : MarkerSection{node, node->getConfig()} {}
|
|
~MarkerSection() {
|
|
if (endMarker_) {
|
|
endMarker_(MarkerType, node_, markerData(&data), userData_);
|
|
}
|
|
}
|
|
|
|
typename Data::type data = {};
|
|
|
|
template <typename Ret, typename... Args>
|
|
static Ret wrap(
|
|
YGNodeRef node,
|
|
Ret (YGNode::*method)(Args...),
|
|
Args... args) {
|
|
MarkerSection<MarkerType> section{node};
|
|
return (node->*method)(std::forward<Args>(args)...);
|
|
}
|
|
|
|
private:
|
|
decltype(YGMarkerCallbacks{}.endMarker) endMarker_;
|
|
YGNodeRef node_;
|
|
void* userData_;
|
|
|
|
MarkerSection(YGNodeRef node, YGConfigRef config)
|
|
: MarkerSection{node, config ? &config->markerCallbacks : nullptr} {}
|
|
MarkerSection(YGNodeRef node, YGMarkerCallbacks* callbacks)
|
|
: endMarker_{callbacks ? callbacks->endMarker : nullptr},
|
|
node_{node},
|
|
userData_{
|
|
callbacks && callbacks->startMarker
|
|
? callbacks->startMarker(MarkerType, node, markerData(&data))
|
|
: nullptr} {}
|
|
|
|
static YGMarkerData markerData(typename Data::type* d) {
|
|
YGMarkerData markerData = {};
|
|
Data::get(markerData) = d;
|
|
return markerData;
|
|
}
|
|
};
|
|
|
|
} // namespace marker
|
|
} // namespace yoga
|
|
} // namespace facebook
|