-
Notifications
You must be signed in to change notification settings - Fork 24.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Remove JNI Binding usage of layoutContext (#39402)
Summary: Pull Request resolved: #39402 X-link: facebook/yoga#1377 To avoid keeping a per-node mapping on native Yoga nodes to Java nodes, a per-layout context was added, to be able to pass information from the start of the layout, to measure functions, log functions, etc. The way this was done was super invasive, and added quite a few private APIs used only by the JNI functions. This change removes the context-using functions from the JNI bindings in favor of it managing its own context. Next diff removes all the cruft. Differential Revision: D49179243 fbshipit-source-id: 0bd0ac754bb47604963eea83644663dc5f99fc75
- Loading branch information
1 parent
7a51442
commit 8d86e23
Showing
4 changed files
with
85 additions
and
33 deletions.
There are no files selected for viewing
34 changes: 34 additions & 0 deletions
34
packages/react-native/ReactAndroid/src/main/jni/first-party/yogajni/jni/LayoutContext.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
/* | ||
* 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. | ||
*/ | ||
|
||
#include <stack> | ||
|
||
#include "LayoutContext.h" | ||
|
||
namespace facebook::yoga::vanillajni { | ||
|
||
namespace { | ||
std::stack<PtrJNodeMapVanilla*>& getContexts() { | ||
static thread_local std::stack<PtrJNodeMapVanilla*> contexts; | ||
return contexts; | ||
} | ||
|
||
} // namespace | ||
|
||
LayoutContext::Holder::Holder(PtrJNodeMapVanilla* data) { | ||
getContexts().push(data); | ||
} | ||
|
||
LayoutContext::Holder::~Holder() { | ||
getContexts().pop(); | ||
} | ||
|
||
/*static*/ PtrJNodeMapVanilla* LayoutContext::getNodeMap() { | ||
return getContexts().empty() ? nullptr : getContexts().top(); | ||
} | ||
|
||
} // namespace facebook::yoga::vanillajni |
26 changes: 26 additions & 0 deletions
26
packages/react-native/ReactAndroid/src/main/jni/first-party/yogajni/jni/LayoutContext.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
/* | ||
* 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: | ||
struct Holder { | ||
explicit Holder(PtrJNodeMapVanilla* data); | ||
~Holder(); | ||
}; | ||
|
||
static PtrJNodeMapVanilla* getNodeMap(); | ||
}; | ||
|
||
} // namespace facebook::yoga::vanillajni |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters