Files
FrenoCorp/node_modules/react-native/ReactCommon/cxxreact/JSBigString.h
Michael Freno 7c684a42cc FRE-600: Fix code review blockers
- Consolidated duplicate UndoManagers to single instance
- Fixed connection promise to only resolve on 'connected' status
- Fixed WebSocketProvider import (WebsocketProvider)
- Added proper doc.destroy() cleanup
- Renamed isPresenceInitialized property to avoid conflict

Co-Authored-By: Paperclip <noreply@paperclip.ing>
2026-04-25 00:08:01 -04:00

154 lines
3.5 KiB
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 <memory>
#include <string>
#include <jsi/jsi.h>
#ifndef RN_EXPORT
#ifdef _MSC_VER
#define RN_EXPORT
#else
#define RN_EXPORT __attribute__((visibility("default")))
#endif
#endif
namespace facebook::react {
// JSExecutor functions sometimes take large strings, on the order of
// megabytes. Copying these can be expensive. Introducing a
// move-only, non-CopyConstructible type will let the compiler ensure
// that no copies occur. folly::MoveWrapper should be used when a
// large string needs to be curried into a std::function<>, which must
// by CopyConstructible.
class JSBigString : public facebook::jsi::Buffer {
public:
JSBigString() = default;
// Not copyable or movable
JSBigString(const JSBigString &) = delete;
JSBigString &operator=(const JSBigString &) = delete;
JSBigString(JSBigString &&) = delete;
JSBigString &operator=(JSBigString &&) = delete;
~JSBigString() override = default;
virtual bool isAscii() const = 0;
// This needs to be a \0 terminated string
virtual const char *c_str() const = 0;
// Length of the c_str without the NULL byte.
size_t size() const override = 0;
const uint8_t *data() const final
{
return reinterpret_cast<const uint8_t *>(c_str());
}
};
// Concrete JSBigString implementation which holds a std::string
// instance.
class JSBigStdString : public JSBigString {
public:
JSBigStdString(std::string str, bool isAscii = false) : m_isAscii(isAscii), m_str(std::move(str)) {}
bool isAscii() const override
{
return m_isAscii;
}
const char *c_str() const override
{
return m_str.c_str();
}
size_t size() const override
{
return m_str.size();
}
private:
bool m_isAscii;
std::string m_str;
};
// Concrete JSBigString implementation which holds a heap-allocated
// buffer, and provides an accessor for writing to it. This can be
// used to construct a JSBigString in place, such as by reading from a
// file.
class RN_EXPORT JSBigBufferString : public JSBigString {
public:
JSBigBufferString(size_t size) : m_data(new char[size + 1]), m_size(size)
{
// Guarantee nul-termination. The caller is responsible for
// filling in the rest of m_data.
m_data[m_size] = '\0';
}
~JSBigBufferString() override
{
delete[] m_data;
}
bool isAscii() const override
{
return true;
}
const char *c_str() const override
{
return m_data;
}
size_t size() const override
{
return m_size;
}
char *mutableData()
{
return m_data;
}
private:
char *m_data;
size_t m_size;
};
// JSBigString interface implemented by a file-backed mmap region.
class RN_EXPORT JSBigFileString : public JSBigString {
public:
JSBigFileString(int fd, size_t size, off_t offset = 0);
~JSBigFileString() override;
bool isAscii() const override
{
return true;
}
const char *c_str() const override;
size_t size() const override;
int fd() const;
static std::unique_ptr<const JSBigFileString> fromPath(const std::string &sourceURL);
private:
int m_fd; // The file descriptor being mmapped
size_t m_size; // The size of the mmapped region
mutable off_t m_pageOff; // The offset in the mmapped region to the data.
off_t m_mapOff; // The offset in the file to the mmapped region.
mutable const char *m_data; // Pointer to the mmapped region.
};
} // namespace facebook::react