Skip to content

Commit 4c64322

Browse files
authored
Merge pull request #6334 from jsquyres/pr/make-mpi-h-a-little-more-c++-friendly
mpi.h.in: use C++ static_cast<> where appropriate
2 parents c034073 + 30afdce commit 4c64322

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)