Skip to content

Commit 30afdce

Browse files
committed
mpi.h.in: use C++ static_cast<> where appropriate
When compiling mpi.h with a modern C++ compiler and a high degree of pickyness (e.g., -Wold-style-cast), casting using (void*) in the OMPI_PREDEFINED_GLOBAL and MPI_STATUS*_IGNORE macros will emit warnings. So if we're compiling with a C++ compiler, use C++'s static_cast<> instead of (void*). Thanks to @shadow-fax for identifying the issue. Signed-off-by: Jeff Squyres <jsquyres@cisco.com>
1 parent ea40d48 commit 30afdce

File tree

1 file changed

+10
-1
lines changed

1 file changed

+10
-1
lines changed

ompi/include/mpi.h.in

Lines changed: 10 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@
99
* University of Stuttgart. All rights reserved.
1010
* Copyright (c) 2004-2005 The Regents of the University of California.
1111
* All rights reserved.
12-
* Copyright (c) 2007-2018 Cisco Systems, Inc. All rights reserved
12+
* Copyright (c) 2007-2019 Cisco Systems, Inc. All rights reserved
1313
* Copyright (c) 2008-2009 Sun Microsystems, Inc. All rights reserved.
1414
* Copyright (c) 2009-2012 Oak Rigde National Laboratory. All rights reserved.
1515
* Copyright (c) 2011 Sandia National Laboratories. All rights reserved.
@@ -325,7 +325,11 @@
325325
* when building OMPI).
326326
*/
327327
#if !OMPI_BUILDING
328+
#if defined(c_plusplus) || defined(__cplusplus)
329+
#define OMPI_PREDEFINED_GLOBAL(type, global) (static_cast<type> (static_cast<void *> (&(global))))
330+
#else
328331
#define OMPI_PREDEFINED_GLOBAL(type, global) ((type) ((void *) &(global)))
332+
#endif
329333
#else
330334
#define OMPI_PREDEFINED_GLOBAL(type, global) ((type) &(global))
331335
#endif
@@ -758,8 +762,13 @@ enum {
758762
*/
759763
#define MPI_INFO_ENV OMPI_PREDEFINED_GLOBAL(MPI_Info, ompi_mpi_info_env)
760764

765+
#if defined(c_plusplus) || defined(__cplusplus)
766+
#define MPI_STATUS_IGNORE (static_cast<MPI_Status *> (0))
767+
#define MPI_STATUSES_IGNORE (static_cast<MPI_Status *> (0))
768+
#else
761769
#define MPI_STATUS_IGNORE ((MPI_Status *) 0)
762770
#define MPI_STATUSES_IGNORE ((MPI_Status *) 0)
771+
#endif
763772

764773
/*
765774
* Special MPI_T handles

0 commit comments

Comments
 (0)