pgsql: Add macros wrapping all usage of gcc's __attribute__.

From: Andres Freund <andres(at)anarazel(dot)de>
To: pgsql-committers(at)postgresql(dot)org
Subject: pgsql: Add macros wrapping all usage of gcc's __attribute__.
Date: 2015-03-11 13:49:35
Message-ID: E1YVh0x-0002Of-Rb@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers pgsql-hackers

Add macros wrapping all usage of gcc's __attribute__.

Until now __attribute__() was defined to be empty for all compilers but
gcc. That's problematic because it prevents using it in other compilers;
which is necessary e.g. for atomics portability. It's also just
generally dubious to do so in a header as widely included as c.h.

Instead add pg_attribute_format_arg, pg_attribute_printf,
pg_attribute_noreturn macros which are implemented in the compilers that
understand them. Also add pg_attribute_noreturn and pg_attribute_packed,
but don't provide fallbacks, since they can affect functionality.

This means that external code that, possibly unwittingly, relied on
__attribute__ defined to be empty on !gcc compilers may now run into
warnings or errors on those compilers. But there shouldn't be many
occurances of that and it's hard to work around...

Discussion: 54B58BA3(dot)8040302(at)ohmu(dot)fi
Author: Oskari Saarenmaa, with some minor changes by me.

Branch
------
master

Details
-------
http://git.postgresql.org/pg/commitdiff/bbfd7edae5aa5ad5553d3c7e102f2e450d4380d4

Modified Files
--------------
contrib/cube/cubescan.l | 2 +-
contrib/pg_upgrade/pg_upgrade.h | 14 ++++----
contrib/pg_upgrade/util.c | 2 +-
contrib/pg_xlogdump/pg_xlogdump.c | 2 +-
contrib/pgcrypto/px.h | 2 +-
contrib/seg/segscan.l | 2 +-
src/backend/access/transam/xlogreader.c | 2 +-
src/backend/postmaster/autovacuum.c | 4 +--
src/backend/postmaster/pgarch.c | 2 +-
src/backend/postmaster/pgstat.c | 2 +-
src/backend/postmaster/postmaster.c | 4 +--
src/backend/postmaster/syslogger.c | 2 +-
src/backend/replication/repl_scanner.l | 2 +-
src/backend/replication/walsender.c | 2 +-
src/backend/utils/error/elog.c | 2 +-
src/backend/utils/misc/guc.c | 2 +-
src/bin/pg_ctl/pg_ctl.c | 2 +-
src/bin/pg_dump/parallel.c | 2 +-
src/bin/pg_dump/pg_backup.h | 2 +-
src/bin/pg_dump/pg_backup_archiver.h | 6 ++--
src/bin/pg_dump/pg_backup_tar.c | 2 +-
src/bin/pg_dump/pg_backup_utils.h | 8 ++---
src/bin/psql/common.h | 2 +-
src/bin/psql/large_obj.c | 2 +-
src/include/bootstrap/bootstrap.h | 4 +--
src/include/c.h | 49 +++++++++++++++++++++++----
src/include/common/fe_memutils.h | 4 +--
src/include/lib/stringinfo.h | 4 +--
src/include/mb/pg_wchar.h | 4 +--
src/include/parser/parse_relation.h | 4 +--
src/include/parser/scanner.h | 2 +-
src/include/pgstat.h | 2 +-
src/include/port.h | 14 ++++----
src/include/port/atomics/generic-gcc.h | 2 +-
src/include/port/atomics/generic-sunpro.h | 2 +-
src/include/port/atomics/generic-xlc.h | 2 +-
src/include/postgres.h | 2 +-
src/include/postmaster/autovacuum.h | 4 +--
src/include/postmaster/bgworker_internals.h | 2 +-
src/include/postmaster/bgwriter.h | 4 +--
src/include/postmaster/pgarch.h | 2 +-
src/include/postmaster/postmaster.h | 4 +--
src/include/postmaster/startup.h | 2 +-
src/include/postmaster/syslogger.h | 2 +-
src/include/postmaster/walwriter.h | 2 +-
src/include/replication/walreceiver.h | 2 +-
src/include/storage/ipc.h | 2 +-
src/include/storage/itemptr.h | 2 +-
src/include/storage/lock.h | 2 +-
src/include/tcop/tcopprot.h | 6 ++--
src/include/utils/datetime.h | 2 +-
src/include/utils/elog.h | 38 ++++++++++-----------
src/include/utils/help_config.h | 2 +-
src/include/utils/palloc.h | 4 +--
src/interfaces/ecpg/ecpglib/extern.h | 2 +-
src/interfaces/ecpg/include/ecpglib.h | 2 +-
src/interfaces/ecpg/preproc/ecpg.header | 2 +-
src/interfaces/ecpg/preproc/extern.h | 4 +--
src/interfaces/libpq/libpq-int.h | 6 ++--
src/interfaces/libpq/pqexpbuffer.c | 2 +-
src/interfaces/libpq/pqexpbuffer.h | 4 +--
src/interfaces/libpq/win32.c | 2 +-
src/pl/plperl/plperl.h | 4 +--
src/pl/plpgsql/src/pl_scanner.c | 2 +-
src/pl/plpython/plpy_elog.h | 8 ++---
src/test/modules/test_shm_mq/test_shm_mq.h | 2 +-
src/test/modules/worker_spi/worker_spi.c | 2 +-
src/test/regress/pg_regress.c | 6 ++--
68 files changed, 167 insertions(+), 132 deletions(-)

Responses

Browse pgsql-committers by date

  From Date Subject
Next Message Michael Paquier 2015-03-11 14:15:14 Re: pgsql: Refactor Mkvcbuild.pm to facilitate modules migrations
Previous Message Alvaro Herrera 2015-03-11 13:20:58 pgsql: Refactor Mkvcbuild.pm to facilitate modules migrations

Browse pgsql-hackers by date

  From Date Subject
Next Message Andres Freund 2015-03-11 13:53:12 Re: __attribute__ for non-gcc compilers
Previous Message Alvaro Herrera 2015-03-11 13:23:36 Re: moving from contrib to bin