mirror of
https://github.com/status-im/react-native.git
synced 2025-01-23 07:49:25 +00:00
da7873563b
Reviewed By: fkgozali Differential Revision: D8065619 fbshipit-source-id: 719c303b40c96950bab8e5dde9a75f449b2956c6
65 lines
1.4 KiB
C++
65 lines
1.4 KiB
C++
// Copyright (c) 2004-present, Facebook, Inc.
|
|
|
|
// 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 <cstdint>
|
|
#include <cstring>
|
|
|
|
#ifndef RN_EXPORT
|
|
#define RN_EXPORT __attribute__((visibility("default")))
|
|
#endif
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
/*
|
|
* ScriptTag
|
|
*
|
|
* Scripts given to the JS Executors to run could be in any of the following
|
|
* formats. They are tagged so the executor knows how to run them.
|
|
*/
|
|
enum struct ScriptTag {
|
|
String = 0,
|
|
RAMBundle,
|
|
BCBundle,
|
|
};
|
|
|
|
/**
|
|
* BundleHeader
|
|
*
|
|
* RAM bundles and BC bundles begin with headers. For RAM bundles this is
|
|
* 4 bytes, for BC bundles this is 12 bytes. This structure holds the first 12
|
|
* bytes from a bundle in a way that gives access to that information.
|
|
*/
|
|
struct __attribute__((packed)) BundleHeader {
|
|
BundleHeader() {
|
|
std::memset(this, 0, sizeof(BundleHeader));
|
|
}
|
|
|
|
uint32_t magic;
|
|
uint32_t reserved_;
|
|
uint32_t version;
|
|
};
|
|
|
|
/**
|
|
* parseTypeFromHeader
|
|
*
|
|
* Takes the first 8 bytes of a bundle, and returns a tag describing the
|
|
* bundle's format.
|
|
*/
|
|
RN_EXPORT ScriptTag parseTypeFromHeader(const BundleHeader& header);
|
|
|
|
/**
|
|
* stringForScriptTag
|
|
*
|
|
* Convert an `ScriptTag` enum into a string, useful for emitting in errors
|
|
* and diagnostic messages.
|
|
*/
|
|
RN_EXPORT const char* stringForScriptTag(const ScriptTag& tag);
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|