Skip to content

OPENSSL_FILE

NAME

OPENSSL_FILE, OPENSSL_LINE, OPENSSL_FUNC, OSSL_BEGIN_ALLOW_DEPRECATED, OSSL_END_ALLOW_DEPRECATED, OPENSSL_MSTR, OPENSSL_MSTR_HELPER - generic C programming utility macros

SYNOPSIS

#include <openssl/macros.h>

#define OPENSSL_FILE /* typically: __FILE__ */
#define OPENSSL_LINE /* typically: __LINE__ */
#define OPENSSL_FUNC /* typically: __func__ */

#define OPENSSL_MSTR_HELPER(x) #x
#define OPENSSL_MSTR(x) OPENSSL_MSTR_HELPER(x)

#define OSSL_BEGIN_ALLOW_DEPRECATED /* compiler specific */
#define OSSL_END_ALLOW_DEPRECATED /* compiler specific */

DESCRIPTION

The macros OPENSSL_FILE and OPENSSL_LINE typically yield the current filename and line number during C compilation. When OPENSSL_NO_FILENAMES is defined they yield "" and 0, respectively.

The macro OPENSSL_FUNC attempts to yield the name of the C function currently being compiled, as far as language and compiler versions allow. Otherwise, it yields "(unknown function)".

The macro OPENSSL_MSTR yields the expansion of the macro given as argument, which is useful for concatenation with string constants. The macro OPENSSL_MSTR_HELPER is an auxiliary macro for this purpose.

The macros OSSL_BEGIN_ALLOW_DEPRECATED and OSSL_END_ALLOW_DEPRECATED respectively disable and then re-enable compiler warnings for deprecated functions within a source file, for compilers which OpenSSL supports. They are equivalent to disabling the warnings with compiler-specific options, but may be convenient when you wish to use deprecated OpenSSL functions temporarily in limited areas of code without turning off warnings more globally. It is nevertheless important to remember to eventually transition such code to replacement functions, as deprecated functions may be removed in later major OpenSSL releases.

RETURN VALUES

see above

SEE ALSO

crypto(7)

HISTORY

OPENSSL_FUNC, OPENSSL_MSTR, and OPENSSL_MSTR_HELPER were added in OpenSSL 3.0.

OSSL_BEGIN_ALLOW_DEPRECATED and OSSL_END_ALLOW_DEPRECATED were added in OpenSSL 4.0, inspired by BoringSSL.

Copyright 2018-2026 The OpenSSL Project Authors. All Rights Reserved.

Licensed under the Apache License 2.0 (the "License"). You may not use this file except in compliance with the License. You can obtain a copy in the file LICENSE in the source distribution or at https://www.openssl.org/source/license.html.