]> git.ipfire.org Git - thirdparty/man-pages.git/commitdiff
man/man3attr/intro.3attr: Add page
authorAlejandro Colomar <alx@kernel.org>
Fri, 27 Jun 2025 03:13:30 +0000 (05:13 +0200)
committerAlejandro Colomar <alx@kernel.org>
Sat, 28 Jun 2025 14:51:42 +0000 (16:51 +0200)
Cc: Aaron Ballman <aaron@aaronballman.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
man/man3attr/intro.3attr [new file with mode: 0644]

diff --git a/man/man3attr/intro.3attr b/man/man3attr/intro.3attr
new file mode 100644 (file)
index 0000000..c488a06
--- /dev/null
@@ -0,0 +1,49 @@
+.\" Copyright, the authors of the Linux man-pages project
+.\"
+.\" SPDX-License-Identifier: Linux-man-pages-copyleft
+.\"
+.TH intro 3attr (date) "Linux man-pages (unreleased)"
+.SH NAME
+intro \- C/C++ attributes
+.SH SYNOPSIS
+.nf
+.BI [[ attr ]]
+.BI [[ vendor :: attr ]]
+.fi
+.SH DESCRIPTION
+Attributes modify the properties of a source construct,
+such as a type, a variable, or a function.
+.P
+The standard syntax allows specifying a
+.I vendor
+for non-standard attributes.
+.SH VERSIONS
+C and C++ dialects have provided various forms of attributes
+before standardization.
+.TP
+.BI __attribute__(( attr ))
+This is the GNU syntax for attributes.
+It is supported by both GCC and Clang.
+.TP
+.BI __declspec( attr )
+This is the MSVC syntax for attributes.
+It is supported by Clang.
+.SH STANDARDS
+C23, C++23.
+.SH HISTORY
+.TP
+.BI [[ attr ]]
+.TQ
+.BI [[ vendor :: attr ]]
+C23, C++11.
+.TP
+.BI [[ attr ]]
+.TQ
+.BI [[gnu:: attr ]]
+gcc 10, g++ 9, clang 9, clang++ 9.
+.TP
+.BI __attribute__(( attr ))
+gcc, g++, clang, clang++.
+.TP
+.BI __declspec( attr )
+clang, clang++.