1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef INCLUDED_SAL_TYPES_H
21 #define INCLUDED_SAL_TYPES_H
23 #include "sal/config.h"
27 #include "sal/macros.h"
28 #include "sal/typesizes.h"
34 typedef unsigned char sal_Bool
;
35 # define sal_False ((sal_Bool)0)
36 # define sal_True ((sal_Bool)1)
38 /* char is assumed to always be 1 byte long */
39 typedef signed char sal_Int8
;
40 typedef unsigned char sal_uInt8
;
42 #if SAL_TYPES_SIZEOFSHORT == 2
43 typedef signed short sal_Int16
;
44 typedef unsigned short sal_uInt16
;
46 #error "Could not find 16-bit type, add support for your architecture"
49 #if SAL_TYPES_SIZEOFLONG == 4
50 typedef signed long sal_Int32
;
51 typedef unsigned long sal_uInt32
;
52 #define SAL_PRIdINT32 "ld"
53 #define SAL_PRIuUINT32 "lu"
54 #define SAL_PRIxUINT32 "lx"
55 #define SAL_PRIXUINT32 "lX"
56 #elif SAL_TYPES_SIZEOFINT == 4
57 typedef signed int sal_Int32
;
58 typedef unsigned int sal_uInt32
;
59 #define SAL_PRIdINT32 "d"
60 #define SAL_PRIuUINT32 "u"
61 #define SAL_PRIxUINT32 "x"
62 #define SAL_PRIXUINT32 "X"
64 #error "Could not find 32-bit type, add support for your architecture"
68 typedef __int64 sal_Int64
;
69 typedef unsigned __int64 sal_uInt64
;
71 /* The following are macros that will add the 64 bit constant suffix. */
72 #define SAL_CONST_INT64(x) x##i64
73 #define SAL_CONST_UINT64(x) x##ui64
75 #define SAL_PRIdINT64 "I64d"
76 #define SAL_PRIuUINT64 "I64u"
77 #define SAL_PRIxUINT64 "I64x"
78 #define SAL_PRIXUINT64 "I64X"
79 #elif defined (__GNUC__)
80 #if SAL_TYPES_SIZEOFLONG == 8
81 typedef signed long int sal_Int64
;
82 typedef unsigned long int sal_uInt64
;
85 /* The following are macros that will add the 64 bit constant suffix. */
86 #define SAL_CONST_INT64(x) x##l
87 #define SAL_CONST_UINT64(x) x##ul
89 #define SAL_PRIdINT64 "ld"
90 #define SAL_PRIuUINT64 "lu"
91 #define SAL_PRIxUINT64 "lx"
92 #define SAL_PRIXUINT64 "lX"
93 #elif SAL_TYPES_SIZEOFLONGLONG == 8
94 typedef signed long long sal_Int64
;
95 typedef unsigned long long sal_uInt64
;
97 /* The following are macros that will add the 64 bit constant suffix. */
98 #define SAL_CONST_INT64(x) x##ll
99 #define SAL_CONST_UINT64(x) x##ull
101 #define SAL_PRIdINT64 "lld"
102 #define SAL_PRIuUINT64 "llu"
103 #define SAL_PRIxUINT64 "llx"
104 #define SAL_PRIXUINT64 "llX"
106 #error "Could not find 64-bit type, add support for your architecture"
109 #error "Please define the 64-bit types for your architecture/compiler in include/sal/types.h"
112 #if defined LIBO_INTERNAL_ONLY && defined __cplusplus
113 #define SAL_UNICODE_NOTEQUAL_WCHAR_T
114 typedef char16_t sal_Unicode
;
115 #elif defined(_WIN32)
116 typedef wchar_t sal_Unicode
;
118 #define SAL_UNICODE_NOTEQUAL_WCHAR_T
119 typedef sal_uInt16 sal_Unicode
;
122 typedef void * sal_Handle
;
124 /* sal_Size should currently be the native width of the platform */
125 #if SAL_TYPES_SIZEOFPOINTER == 4
126 typedef sal_uInt32 sal_Size
;
127 typedef sal_Int32 sal_sSize
;
128 #elif SAL_TYPES_SIZEOFPOINTER == 8
129 typedef sal_uInt64 sal_Size
;
130 typedef sal_Int64 sal_sSize
;
132 #error "Please make sure SAL_TYPES_SIZEOFPOINTER is defined for your architecture/compiler"
135 /* sal_PtrDiff holds the result of a pointer subtraction */
136 #if SAL_TYPES_SIZEOFPOINTER == 4
137 typedef sal_Int32 sal_PtrDiff
;
138 #elif SAL_TYPES_SIZEOFPOINTER == 8
139 typedef sal_Int64 sal_PtrDiff
;
141 #error "Please make sure SAL_TYPES_SIZEOFPOINTER is defined for your architecture/compiler"
144 /* printf-style conversion specification length modifiers for size_t and
145 ptrdiff_t (most platforms support C99, MSC has its own extension) */
146 #if defined(_MSC_VER)
147 #define SAL_PRI_SIZET "I"
148 #define SAL_PRI_PTRDIFFT "I"
150 #define SAL_PRI_SIZET "z"
151 #define SAL_PRI_PTRDIFFT "t"
154 /* sal_IntPtr, sal_uIntPtr are integer types designed to hold pointers so that any valid
155 * pointer to void can be converted to this type and back to a pointer to void and the
156 * result will compare to the original pointer */
157 #if SAL_TYPES_SIZEOFPOINTER == 4
158 typedef sal_Int32 sal_IntPtr
;
159 typedef sal_uInt32 sal_uIntPtr
;
160 #define SAL_PRIdINTPTR SAL_PRIdINT32
161 #define SAL_PRIuUINTPTR SAL_PRIuUINT32
162 #define SAL_PRIxUINTPTR SAL_PRIxUINT32
163 #define SAL_PRIXUINTPTR SAL_PRIXUINT32
164 #elif SAL_TYPES_SIZEOFPOINTER == 8
165 typedef sal_Int64 sal_IntPtr
;
166 typedef sal_uInt64 sal_uIntPtr
;
167 #define SAL_PRIdINTPTR SAL_PRIdINT64
168 #define SAL_PRIuUINTPTR SAL_PRIuUINT64
169 #define SAL_PRIxUINTPTR SAL_PRIxUINT64
170 #define SAL_PRIXUINTPTR SAL_PRIXUINT64
172 #error "Please make sure SAL_TYPES_SIZEOFPOINTER is defined for your architecture/compiler"
175 /* The following SAL_MIN_INTn defines codify the assumption that the signed
176 * sal_Int types use two's complement representation. Defining them as
177 * "-0x7F... - 1" instead of as "-0x80..." prevents warnings about applying the
178 * unary minus operator to unsigned quantities.
180 #define SAL_MIN_INT8 ((sal_Int8) (-0x7F - 1))
181 #define SAL_MAX_INT8 ((sal_Int8) 0x7F)
182 #define SAL_MAX_UINT8 ((sal_uInt8) 0xFF)
183 #define SAL_MIN_INT16 ((sal_Int16) (-0x7FFF - 1))
184 #define SAL_MAX_INT16 ((sal_Int16) 0x7FFF)
185 #define SAL_MAX_UINT16 ((sal_uInt16) 0xFFFF)
186 #define SAL_MIN_INT32 ((sal_Int32) (-0x7FFFFFFF - 1))
187 #define SAL_MAX_INT32 ((sal_Int32) 0x7FFFFFFF)
188 #define SAL_MAX_UINT32 ((sal_uInt32) 0xFFFFFFFF)
189 #define SAL_MIN_INT64 ((sal_Int64) (SAL_CONST_INT64(-0x7FFFFFFFFFFFFFFF) - 1))
190 #define SAL_MAX_INT64 ((sal_Int64) SAL_CONST_INT64(0x7FFFFFFFFFFFFFFF))
191 #define SAL_MAX_UINT64 ((sal_uInt64) SAL_CONST_UINT64(0xFFFFFFFFFFFFFFFF))
193 #if SAL_TYPES_SIZEOFPOINTER == 4
194 #define SAL_MAX_SSIZE SAL_MAX_INT32
195 #define SAL_MAX_SIZE SAL_MAX_UINT32
196 #elif SAL_TYPES_SIZEOFPOINTER == 8
197 #define SAL_MAX_SSIZE SAL_MAX_INT64
198 #define SAL_MAX_SIZE SAL_MAX_UINT64
201 #define SAL_MAX_ENUM 0x7fffffff
203 #if defined(_MSC_VER)
204 # define SAL_DLLPUBLIC_EXPORT __declspec(dllexport)
205 # define SAL_JNI_EXPORT __declspec(dllexport)
206 # define SAL_DLLPUBLIC_IMPORT __declspec(dllimport)
207 # define SAL_DLLPRIVATE
208 # define SAL_DLLPUBLIC_TEMPLATE
209 # define SAL_DLLPUBLIC_RTTI
210 # define SAL_CALL __cdecl
211 #elif defined SAL_UNX
212 # if defined(__GNUC__)
213 # if defined(DISABLE_DYNLOADING)
214 # define SAL_DLLPUBLIC_EXPORT __attribute__ ((visibility("hidden")))
215 # define SAL_JNI_EXPORT __attribute__ ((visibility("default")))
216 # define SAL_DLLPUBLIC_IMPORT __attribute__ ((visibility("hidden")))
217 # define SAL_DLLPRIVATE __attribute__ ((visibility("hidden")))
218 # define SAL_DLLPUBLIC_TEMPLATE __attribute__ ((visibility("hidden")))
219 # define SAL_DLLPUBLIC_RTTI
221 # define SAL_DLLPUBLIC_EXPORT __attribute__ ((visibility("default")))
222 # define SAL_JNI_EXPORT __attribute__ ((visibility("default")))
223 # define SAL_DLLPUBLIC_IMPORT __attribute__ ((visibility("default")))
224 # define SAL_DLLPRIVATE __attribute__ ((visibility("hidden")))
225 # define SAL_DLLPUBLIC_TEMPLATE __attribute__ ((visibility("default")))
226 # if defined __clang__
227 # if __has_attribute(type_visibility)
228 # define SAL_DLLPUBLIC_RTTI __attribute__ ((type_visibility("default")))
230 # define SAL_DLLPUBLIC_RTTI __attribute__ ((visibility("default")))
233 # define SAL_DLLPUBLIC_RTTI
237 # define SAL_DLLPUBLIC_EXPORT
238 # define SAL_JNI_EXPORT
239 # define SAL_DLLPUBLIC_IMPORT
240 # define SAL_DLLPRIVATE
241 # define SAL_DLLPUBLIC_TEMPLATE
242 # define SAL_DLLPUBLIC_RTTI
246 # error("unknown platform")
250 Exporting the symbols necessary for exception handling on GCC.
252 These macros are used for inline declarations of exception classes, as in
253 rtl/malformeduriexception.hxx.
255 #if defined(__GNUC__)
256 # if defined(DISABLE_DYNLOADING)
257 # define SAL_EXCEPTION_DLLPUBLIC_EXPORT __attribute__((visibility("default")))
259 # define SAL_EXCEPTION_DLLPUBLIC_EXPORT SAL_DLLPUBLIC_EXPORT
261 # define SAL_EXCEPTION_DLLPRIVATE SAL_DLLPRIVATE
263 # define SAL_EXCEPTION_DLLPUBLIC_EXPORT
264 # define SAL_EXCEPTION_DLLPRIVATE
267 /** Use this as markup for functions and methods whose return value must be
270 Compilers that support a construct of this nature will emit a compile
271 time warning on unchecked return value.
273 #if defined LIBO_INTERNAL_ONLY && defined __cplusplus
274 #define SAL_WARN_UNUSED_RESULT [[nodiscard]]
275 #elif (defined __GNUC__ \
276 && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1))) \
278 # define SAL_WARN_UNUSED_RESULT __attribute__((warn_unused_result))
280 # define SAL_WARN_UNUSED_RESULT
283 /** Use this for pure virtual classes, e.g. class SAL_NO_VTABLE Foo { ...
284 This hinders the compiler from setting a generic vtable stating that
285 a pure virtual function was called and thus slightly reduces code size.
288 # define SAL_NO_VTABLE __declspec(novtable)
290 # define SAL_NO_VTABLE
294 # pragma pack(push, 8)
297 /** This is the binary specification of a SAL sequence.
299 typedef struct _sal_Sequence
301 /** reference count of sequence<br>
304 /** element count<br>
307 /** elements array<br>
312 #define SAL_SEQUENCE_HEADER_SIZE ((sal_Size) offsetof(sal_Sequence,elements))
318 #if defined __cplusplus
320 /** Nothrow specification for C functions.
322 This is a macro so it can expand to nothing in C code.
324 #define SAL_THROW_EXTERN_C() throw ()
326 /** To markup destructors that coverity warns might throw exceptions
327 which won't throw in practice, or where std::terminate is
328 an acceptable response if they do
330 #if defined(LIBO_INTERNAL_ONLY) && defined(__COVERITY__)
331 # define COVERITY_NOEXCEPT_FALSE noexcept(false)
333 # define COVERITY_NOEXCEPT_FALSE
338 #define SAL_THROW_EXTERN_C()
344 #endif /* __cplusplus */
350 /** definition of a no acquire enum for ctors
355 namespace com
{ namespace sun
{ namespace star
{ } } }
357 /** short-circuit extra-verbose API namespaces
359 @since LibreOffice 4.0
361 namespace css
= ::com::sun::star
;
363 /** C++11 "= delete" feature.
365 For LIBO_INTERNAL_ONLY, calling a deleted function will cause a compile-time
366 error, while otherwise it will only cause a link-time error as the declared
367 function is not defined.
369 @since LibreOffice 4.1
371 #if defined LIBO_INTERNAL_ONLY
372 #define SAL_DELETED_FUNCTION = delete
374 #define SAL_DELETED_FUNCTION
377 /** C++11 "override" feature.
379 For LIBO_INTERNAL_ONLY, force the method to override an existing method in
380 parent, error out if the method with the correct signature does not exist.
382 @since LibreOffice 4.1
384 #if defined LIBO_INTERNAL_ONLY
385 #define SAL_OVERRIDE override
390 #endif /* __cplusplus */
397 A static_cast between integral types, to avoid C++ compiler warnings.
399 In C++ source code, use sal::static_int_cast<T>(n) instead of
400 static_cast<T>(n) whenever a compiler warning about integral type problems
401 shall be silenced. That way, source code that needs to be modified when the
402 type of any of the expressions involved in the compiler warning is changed
403 can be found more easily.
405 Both template arguments T1 and T2 must be integral types.
407 template< typename T1
, typename T2
> inline T1
static_int_cast(T2 n
) {
408 return static_cast< T1
>(n
);
413 #else /* __cplusplus */
416 A cast between integer types, to avoid C compiler warnings.
418 In C source code, use SAL_INT_CAST(type, expr) instead of ((type) (expr))
419 whenever a compiler warning about integer type problems shall be silenced.
420 That way, source code that needs to be modified when the type of any of the
421 expressions involved in the compiler warning is changed can be found more
424 The argument 'type' must be an integer type and the argument 'expr' must be
425 an integer expression. Both arguments are evaluated exactly once.
427 #define SAL_INT_CAST(type, expr) ((type) (expr))
429 #endif /* __cplusplus */
433 SAL_DEPRECATED("Don't use, it's evil.") void doit(int nPara);
436 #if defined __GNUC__ || defined __clang__
437 #if defined LIBO_INTERNAL_ONLY
438 # define SAL_DEPRECATED(message) __attribute__((deprecated(message)))
440 # define SAL_DEPRECATED(message) __attribute__((deprecated))
442 #elif defined(_MSC_VER)
443 # define SAL_DEPRECATED(message) __declspec(deprecated(message))
445 # define SAL_DEPRECATED(message)
449 This macro is used in cppumaker-generated include files, to tag entities that
450 are marked as @deprecated in UNOIDL.
452 It causes deprecation warnings to be generated in external code, but for now
453 is silenced in internal code. It would need some substantial clean-up of
454 internal code to fix all warnings/errors generated by it. (Once that is
455 done, it can become a synonym for SAL_DEPRECATED under LIBO_INTERNAL_ONLY,
456 too. Completely removing the macro then would be incompatible, in case there
457 are include files still around generated with a cppumaker that emitted it.)
459 #ifdef LIBO_INTERNAL_ONLY
460 # define SAL_DEPRECATED_INTERNAL(message)
462 # define SAL_DEPRECATED_INTERNAL(message) SAL_DEPRECATED(message)
467 SAL_WNODEPRECATED_DECLARATIONS_PUSH
468 \::std::auto_ptr<X> ...
469 SAL_WNODEPRECATED_DECLARATIONS_POP
472 #if defined LIBO_INTERNAL_ONLY && defined __GNUC__
473 #define SAL_WNODEPRECATED_DECLARATIONS_PUSH \
474 _Pragma(SAL_STRINGIFY_ARG(GCC diagnostic push)) \
475 _Pragma(SAL_STRINGIFY_ARG(GCC diagnostic ignored "-Wdeprecated-declarations"))
476 #define SAL_WNODEPRECATED_DECLARATIONS_POP \
477 _Pragma(SAL_STRINGIFY_ARG(GCC diagnostic pop))
479 # define SAL_WNODEPRECATED_DECLARATIONS_PUSH
480 # define SAL_WNODEPRECATED_DECLARATIONS_POP
486 SAL_WNOUNREACHABLE_CODE_PUSH
490 SAL_WNOUNREACHABLE_CODE_POP
492 Useful in cases where the compiler is "too clever" like when doing
493 link-time code generation, and noticing that a called function
494 always throws, and fixing the problem cleanly so that it produces
495 no warnings in normal non-LTO compilations either is not easy.
500 #define SAL_WNOUNREACHABLE_CODE_PUSH \
501 __pragma(warning(push)) \
502 __pragma(warning(disable:4702)) \
503 __pragma(warning(disable:4722))
504 #define SAL_WNOUNREACHABLE_CODE_POP \
505 __pragma(warning(pop))
507 /* Add definitions for GCC and Clang if needed */
508 #define SAL_WNOUNREACHABLE_CODE_PUSH
509 #define SAL_WNOUNREACHABLE_CODE_POP
512 /** Annotate unused but required C++ function parameters.
514 An unused parameter is required if the function needs to adhere to a given
515 type (e.g., if its address is assigned to a function pointer of a specific
516 type, or if it is called from template code). This annotation helps static
517 analysis tools suppress false warnings. In the case of virtual functions
518 (where unused required parameters are common, too), the annotation is not
519 required (as static analysis tools can themselves derive the information
520 whether a function is virtual).
522 Use the annotation in function definitions like
524 void f(SAL_UNUSED_PARAMETER int) {}
526 C does not allow unnamed parameters, anyway, so a function definition like
527 the above needs to be written there as
529 void f(int dummy) { (void) dummy; / * avoid warnings * / }
531 without a SAL_UNUSED_PARAMETER annotation.
533 @since LibreOffice 3.6
535 #if defined __cplusplus
536 #if defined __GNUC__ || defined __clang__
537 #define SAL_UNUSED_PARAMETER __attribute__ ((unused))
539 #define SAL_UNUSED_PARAMETER
545 Annotate classes where a compiler should warn if an instance is unused.
547 The compiler cannot warn about unused instances if they have non-trivial
548 or external constructors or destructors. Classes marked with SAL_WARN_UNUSED
549 will be warned about.
551 @since LibreOffice 4.0
555 #if defined LIBO_INTERNAL_ONLY && (defined __GNUC__ || defined __clang__)
556 #define SAL_WARN_UNUSED __attribute__((warn_unused))
558 #define SAL_WARN_UNUSED
563 #if defined __GNUC__ || defined __clang__
564 // Macro to try to catch and warn on assignments inside expr.
565 # define SAL_DETAIL_BOOLEAN_EXPR(expr) \
567 int sal_boolean_var_; \
569 sal_boolean_var_ = 1; \
571 sal_boolean_var_ = 0; \
575 /** An optimization annotation: denotes that expression is likely to be true.
577 Use it to annotate paths that we think are likely eg.
578 if (SAL_LIKELY(ptr != nullptr))
579 // this path is the one that is ~always taken.
581 @since LibreOffice 5.2
583 Returns: the boolean value of expr (expressed as either int 1 or 0)
585 # define SAL_LIKELY(expr) __builtin_expect(SAL_DETAIL_BOOLEAN_EXPR((expr)), 1)
587 /** An optimization annotation: denotes that expression is unlikely to be true.
589 Use it to annotate paths that we think are likely eg.
590 if (SAL_UNLIKELY(ptr != nullptr))
591 // this path is the one that is ~never taken.
593 @since LibreOffice 5.2
595 Returns: the boolean value of expr (expressed as either int 1 or 0)
597 # define SAL_UNLIKELY(expr) __builtin_expect(SAL_DETAIL_BOOLEAN_EXPR((expr)), 0)
599 /** An optimization annotation: tells the compiler to work harder at this code
601 If the SAL_HOT annotation is present on a function or a label then
602 subsequent code statements may have more aggressive compiler
603 optimization and in-lining work performed on them.
605 In addition this code can end up in a special section, to be
606 grouped with other frequently used code.
608 @since LibreOffice 5.2
610 # define SAL_HOT __attribute__((hot))
612 /** An optimization annotation: tells the compiler to work less on this code
614 If the SAL_COLD annotation is present on a function or a label then
615 subsequent code statements are unlikely to be performed except in
616 exceptional circumstances, and optimizing for code-size rather
617 than performance is preferable.
619 In addition this code can end up in a special section, to be grouped
620 with (and away from) other more frequently used code, to improve
621 locality of reference.
623 @since LibreOffice 5.2
625 # define SAL_COLD __attribute__((cold))
627 # define SAL_LIKELY(expr) (expr)
628 # define SAL_UNLIKELY(expr) (expr)
636 /** Annotate pointer-returning functions to indicate that such a pointer
639 Note that MSVC supports this feature via it's SAL _Ret_notnull_
640 annotation, but since it's in a completely different place on
641 the function declaration, it's a little hard to support both.
643 @since LibreOffice 5.5
645 #ifndef __has_attribute
646 #define __has_attribute(x) 0
649 #if defined LIBO_INTERNAL_ONLY && ((defined __GNUC__ && !defined __clang__) || (defined __clang__ && __has_attribute(returns_nonnull)))
650 #define SAL_RETURNS_NONNULL __attribute__((returns_nonnull))
652 #define SAL_RETURNS_NONNULL
656 #endif // INCLUDED_SAL_TYPES_H
658 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */