Summary: `/*` is the standard throughout open source code. For example, Firefox uses single /*: https://hg.mozilla.org/mozilla-central/file/21d22b2f541258d3d1cf96c7ba5ad73e96e616b5/gfx/ipc/CompositorWidgetVsyncObserver.cpp#l3 In addition, Rust considers `/**` to be a doc comment (similar to Javadoc) and having such a comment at the beginning of the file causes `rustc` to barf. Note that some JavaScript tooling requires `/**`. This is OK since JavaScript files were not covered by the linter in the first place, but it would be good to have that tooling fixed too. Reviewed By: zertosh Differential Revision: D15640366 fbshipit-source-id: b4ed4599071516364d6109720750d6a43304c089
45 lines
1.1 KiB
C++
45 lines
1.1 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
|
|
|
|
#ifdef __cplusplus
|
|
#define YG_EXTERN_C_BEGIN extern "C" {
|
|
#define YG_EXTERN_C_END }
|
|
#else
|
|
#define YG_EXTERN_C_BEGIN
|
|
#define YG_EXTERN_C_END
|
|
#endif
|
|
|
|
#ifdef _WINDLL
|
|
#define WIN_EXPORT __declspec(dllexport)
|
|
#else
|
|
#define WIN_EXPORT
|
|
#endif
|
|
|
|
#ifdef NS_ENUM
|
|
// Cannot use NSInteger as NSInteger has a different size than int (which is the
|
|
// default type of a enum). Therefor when linking the Yoga C library into obj-c
|
|
// the header is a missmatch for the Yoga ABI.
|
|
#define YG_ENUM_BEGIN(name) NS_ENUM(int, name)
|
|
#define YG_ENUM_END(name)
|
|
#else
|
|
#define YG_ENUM_BEGIN(name) enum name
|
|
#define YG_ENUM_END(name) name
|
|
#endif
|
|
|
|
#ifdef __GNUC__
|
|
#define YG_DEPRECATED __attribute__((deprecated))
|
|
#elif defined(_MSC_VER)
|
|
#define YG_DEPRECATED __declspec(deprecated)
|
|
#elif __cplusplus >= 201402L
|
|
#if defined(__has_cpp_attribute)
|
|
#if __has_cpp_attribute(deprecated)
|
|
#define YG_DEPRECATED [[deprecated]]
|
|
#endif
|
|
#endif
|
|
#endif
|