mirror of
https://github.com/zhigang1992/react-native.git
synced 2026-06-15 01:08:51 +08:00
Summary: @public In order to encapsulate property access on `YGStyle`, as a first measure we wrap all fields with accessors. This will e.g. enable dynamic property storage and instrumentation in the future. All accessors have a `const` version that allows direct access via `const&`. For mutation, bit fields are wrapped with a custom reference object. This style allows for the least amount of changes in client code. Property access simply needs appended parens, eg `style.direction` becomes `style.direction`. Reviewed By: shergin Differential Revision: D14999096 fbshipit-source-id: fbf29f7ddab520513d4618f5e70094c4f6330b30
96 lines
2.2 KiB
C++
96 lines
2.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 <folly/Optional.h>
|
|
#include <folly/dynamic.h>
|
|
#include <react/core/RawProps.h>
|
|
#include <react/graphics/Color.h>
|
|
#include <react/graphics/Geometry.h>
|
|
#include <react/graphics/conversions.h>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
template <typename T>
|
|
void fromRawValue(const RawValue &rawValue, T &result) {
|
|
result = (T)rawValue;
|
|
}
|
|
|
|
template <typename T>
|
|
void fromRawValue(const RawValue &rawValue, std::vector<T> &result) {
|
|
if (rawValue.hasType<std::vector<RawValue>>()) {
|
|
auto items = (std::vector<RawValue>)rawValue;
|
|
auto length = items.size();
|
|
result.clear();
|
|
result.reserve(length);
|
|
for (int i = 0; i < length; i++) {
|
|
T itemResult;
|
|
fromRawValue(items.at(i), itemResult);
|
|
result.push_back(itemResult);
|
|
}
|
|
return;
|
|
}
|
|
|
|
// The case where `value` is not an array.
|
|
result.clear();
|
|
result.reserve(1);
|
|
T itemResult;
|
|
fromRawValue(rawValue, itemResult);
|
|
result.push_back(itemResult);
|
|
}
|
|
|
|
template <typename T, typename U = T>
|
|
T convertRawProp(
|
|
const RawProps &rawProps,
|
|
const std::string &name,
|
|
const T &sourceValue,
|
|
const U &defaultValue = U()) {
|
|
const auto rawValue = rawProps.at(name);
|
|
|
|
if (!rawValue) {
|
|
return sourceValue;
|
|
}
|
|
|
|
// Special case: `null` always means "the prop was removed, use default
|
|
// value".
|
|
if (!rawValue->hasValue()) {
|
|
return defaultValue;
|
|
}
|
|
|
|
T result;
|
|
fromRawValue(*rawValue, result);
|
|
return result;
|
|
}
|
|
|
|
template <typename T>
|
|
static folly::Optional<T> convertRawProp(
|
|
const RawProps &rawProps,
|
|
const std::string &name,
|
|
const folly::Optional<T> &sourceValue,
|
|
const folly::Optional<T> &defaultValue = {}) {
|
|
const auto rawValue = rawProps.at(name);
|
|
|
|
if (!rawValue) {
|
|
return sourceValue;
|
|
}
|
|
|
|
// Special case: `null` always means `the prop was removed, use default
|
|
// value`.
|
|
if (!rawValue->hasValue()) {
|
|
return defaultValue;
|
|
}
|
|
|
|
T result;
|
|
fromRawValue(*rawValue, result);
|
|
return folly::Optional<T>{result};
|
|
}
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|