2018-08-30 09:30:29 +02:00
|
|
|
/*
|
|
|
|
|
* Copyright 2016 The WebRTC Project Authors. All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef SDK_OBJC_BASE_RTCMACROS_H_
|
|
|
|
|
#define SDK_OBJC_BASE_RTCMACROS_H_
|
|
|
|
|
|
2021-07-30 22:32:55 +02:00
|
|
|
#ifdef WEBRTC_ENABLE_OBJC_SYMBOL_EXPORT
|
2020-12-17 15:56:13 +01:00
|
|
|
|
|
|
|
|
#if defined(WEBRTC_LIBRARY_IMPL)
|
|
|
|
|
#define RTC_OBJC_EXPORT __attribute__((visibility("default")))
|
|
|
|
|
#endif
|
|
|
|
|
|
2021-07-30 22:32:55 +02:00
|
|
|
#endif // WEBRTC_ENABLE_OBJC_SYMBOL_EXPORT
|
2020-12-17 15:56:13 +01:00
|
|
|
|
|
|
|
|
#ifndef RTC_OBJC_EXPORT
|
|
|
|
|
#define RTC_OBJC_EXPORT
|
|
|
|
|
#endif
|
|
|
|
|
|
2020-05-04 16:14:32 +02:00
|
|
|
// Internal macros used to correctly concatenate symbols.
|
|
|
|
|
#define RTC_SYMBOL_CONCAT_HELPER(a, b) a##b
|
|
|
|
|
#define RTC_SYMBOL_CONCAT(a, b) RTC_SYMBOL_CONCAT_HELPER(a, b)
|
|
|
|
|
|
|
|
|
|
// RTC_OBJC_TYPE_PREFIX
|
|
|
|
|
//
|
|
|
|
|
// Macro used to prepend a prefix to the API types that are exported with
|
|
|
|
|
// RTC_OBJC_EXPORT.
|
|
|
|
|
//
|
|
|
|
|
// Clients can patch the definition of this macro locally and build
|
|
|
|
|
// WebRTC.framework with their own prefix in case symbol clashing is a
|
|
|
|
|
// problem.
|
|
|
|
|
//
|
2023-07-26 13:01:43 +02:00
|
|
|
// This macro must be defined uniformily across all the translation units.
|
|
|
|
|
#ifndef RTC_OBJC_TYPE_PREFIX
|
2020-05-04 16:14:32 +02:00
|
|
|
#define RTC_OBJC_TYPE_PREFIX
|
2023-07-26 13:01:43 +02:00
|
|
|
#endif
|
2020-05-04 16:14:32 +02:00
|
|
|
|
|
|
|
|
// RCT_OBJC_TYPE
|
|
|
|
|
//
|
|
|
|
|
// Macro used internally to declare API types. Declaring an API type without
|
|
|
|
|
// using this macro will not include the declared type in the set of types
|
|
|
|
|
// that will be affected by the configurable RTC_OBJC_TYPE_PREFIX.
|
|
|
|
|
#define RTC_OBJC_TYPE(type_name) RTC_SYMBOL_CONCAT(RTC_OBJC_TYPE_PREFIX, type_name)
|
|
|
|
|
|
2018-08-30 09:30:29 +02:00
|
|
|
#if defined(__cplusplus)
|
2018-09-17 10:22:56 +02:00
|
|
|
#define RTC_EXTERN extern "C" RTC_OBJC_EXPORT
|
2018-08-30 09:30:29 +02:00
|
|
|
#else
|
2018-09-17 10:22:56 +02:00
|
|
|
#define RTC_EXTERN extern RTC_OBJC_EXPORT
|
2018-08-30 09:30:29 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#ifdef __OBJC__
|
|
|
|
|
#define RTC_FWD_DECL_OBJC_CLASS(classname) @class classname
|
|
|
|
|
#else
|
|
|
|
|
#define RTC_FWD_DECL_OBJC_CLASS(classname) typedef struct objc_object classname
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif // SDK_OBJC_BASE_RTCMACROS_H_
|