mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
2a46980535
Summary: For future diffs, we need to check AttributedStrings for equality. It turns out that any time props or state change, two `parentShadowView`s will never be equal to each other, even if we'd consider them equal for our use-cases here for AttributedStrings. Just compare the tags instead of the whole object. NOTE: I don't have any strong opinions about how we should be comparing them. It just isn't working currently for AndroidTextInput. Comparing tags seems convenient and reasonably correct for now. Changelog: [Internal] Reviewed By: shergin Differential Revision: D18786004 fbshipit-source-id: 13c0e881cd8d2c2a207e8891309b3c9b880b827f
124 lines
2.9 KiB
C++
124 lines
2.9 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 "AttributedString.h"
|
|
|
|
#include <react/debug/DebugStringConvertibleItem.h>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
using Fragment = AttributedString::Fragment;
|
|
using Fragments = AttributedString::Fragments;
|
|
|
|
#pragma mark - Fragment
|
|
|
|
std::string Fragment::AttachmentCharacter() {
|
|
return "\uFFFC"; // Unicode `OBJECT REPLACEMENT CHARACTER`
|
|
}
|
|
|
|
bool Fragment::isAttachment() const {
|
|
return string == AttachmentCharacter();
|
|
}
|
|
|
|
bool Fragment::operator==(const Fragment &rhs) const {
|
|
return std::tie(string, textAttributes, parentShadowView.tag) ==
|
|
std::tie(rhs.string, rhs.textAttributes, rhs.parentShadowView.tag);
|
|
}
|
|
|
|
bool Fragment::operator!=(const Fragment &rhs) const {
|
|
return !(*this == rhs);
|
|
}
|
|
|
|
#pragma mark - AttributedString
|
|
|
|
void AttributedString::appendFragment(const Fragment &fragment) {
|
|
ensureUnsealed();
|
|
|
|
if (fragment.string.empty()) {
|
|
return;
|
|
}
|
|
|
|
fragments_.push_back(fragment);
|
|
}
|
|
|
|
void AttributedString::prependFragment(const Fragment &fragment) {
|
|
ensureUnsealed();
|
|
|
|
if (fragment.string.empty()) {
|
|
return;
|
|
}
|
|
|
|
fragments_.insert(fragments_.begin(), fragment);
|
|
}
|
|
|
|
void AttributedString::appendAttributedString(
|
|
const AttributedString &attributedString) {
|
|
ensureUnsealed();
|
|
fragments_.insert(
|
|
fragments_.end(),
|
|
attributedString.fragments_.begin(),
|
|
attributedString.fragments_.end());
|
|
}
|
|
|
|
void AttributedString::prependAttributedString(
|
|
const AttributedString &attributedString) {
|
|
ensureUnsealed();
|
|
fragments_.insert(
|
|
fragments_.begin(),
|
|
attributedString.fragments_.begin(),
|
|
attributedString.fragments_.end());
|
|
}
|
|
|
|
const Fragments &AttributedString::getFragments() const {
|
|
return fragments_;
|
|
}
|
|
|
|
std::string AttributedString::getString() const {
|
|
auto string = std::string{};
|
|
for (const auto &fragment : fragments_) {
|
|
string += fragment.string;
|
|
}
|
|
return string;
|
|
}
|
|
|
|
bool AttributedString::isEmpty() const {
|
|
return fragments_.empty();
|
|
}
|
|
|
|
bool AttributedString::operator==(const AttributedString &rhs) const {
|
|
return fragments_ == rhs.fragments_;
|
|
}
|
|
|
|
bool AttributedString::operator!=(const AttributedString &rhs) const {
|
|
return !(*this == rhs);
|
|
}
|
|
|
|
#pragma mark - DebugStringConvertible
|
|
|
|
#if RN_DEBUG_STRING_CONVERTIBLE
|
|
SharedDebugStringConvertibleList AttributedString::getDebugChildren() const {
|
|
auto list = SharedDebugStringConvertibleList{};
|
|
|
|
for (auto &&fragment : fragments_) {
|
|
auto propsList =
|
|
fragment.textAttributes.DebugStringConvertible::getDebugProps();
|
|
|
|
list.push_back(std::make_shared<DebugStringConvertibleItem>(
|
|
"Fragment",
|
|
fragment.string,
|
|
SharedDebugStringConvertibleList(),
|
|
propsList));
|
|
}
|
|
|
|
return list;
|
|
}
|
|
#endif
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|