Summary: This mirrors the clang-format config used by fbsource to Yoga. They are pretty similar, except for an annoying habit where Yoga's previous forced small functions in headers to be a a single line, so you would get a combination of multiline and single line functions next to each other which are hard to read. That is what motivated this change. It also enforces header ordering (yay). I don't think we have any side-effect causing headers, so this should be safe. Reviewed By: yungsters Differential Revision: D49248994 fbshipit-source-id: 66998395e7c0158ff9d9fb1bee44e8401bdd8f21
30 lines
821 B
C++
30 lines
821 B
C++
/*
|
|
* Copyright (c) Meta Platforms, Inc. and 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 <yoga/Yoga.h>
|
|
#include "YGJTypesVanilla.h"
|
|
|
|
namespace facebook::yoga::vanillajni {
|
|
|
|
// TODO: This should not be exported or used outside of the JNI bindings
|
|
class YG_EXPORT LayoutContext {
|
|
public:
|
|
// Sets a context on the current thread for the duration of the Provider's
|
|
// lifetime. This context should be set during the layout process to allow
|
|
// layout callbacks to access context-data specific to the layout pass.
|
|
struct Provider {
|
|
explicit Provider(PtrJNodeMapVanilla* data);
|
|
~Provider();
|
|
};
|
|
|
|
static PtrJNodeMapVanilla* getNodeMap();
|
|
};
|
|
|
|
} // namespace facebook::yoga::vanillajni
|