This source file includes following definitions.
- mpi_info_delete_
1
2
3
4
5
6
7
8 #include "mpio.h"
9 #include "adio.h"
10
11
12 #if defined(MPIO_BUILD_PROFILING) || defined(HAVE_WEAK_SYMBOLS)
13 #ifdef FORTRANCAPS
14 #define mpi_info_delete_ PMPI_INFO_DELETE
15 #elif defined(FORTRANDOUBLEUNDERSCORE)
16 #define mpi_info_delete_ pmpi_info_delete__
17 #elif !defined(FORTRANUNDERSCORE)
18 #if defined(HPUX) || defined(SPPUX)
19 #pragma _HP_SECONDARY_DEF pmpi_info_delete pmpi_info_delete_
20 #endif
21 #define mpi_info_delete_ pmpi_info_delete
22 #else
23 #if defined(HPUX) || defined(SPPUX)
24 #pragma _HP_SECONDARY_DEF pmpi_info_delete_ pmpi_info_delete
25 #endif
26 #define mpi_info_delete_ pmpi_info_delete_
27 #endif
28
29 #if defined(HAVE_WEAK_SYMBOLS)
30 #if defined(HAVE_PRAGMA_WEAK)
31 #if defined(FORTRANCAPS)
32 #pragma weak MPI_INFO_DELETE = PMPI_INFO_DELETE
33 #elif defined(FORTRANDOUBLEUNDERSCORE)
34 #pragma weak mpi_info_delete__ = pmpi_info_delete__
35 #elif !defined(FORTRANUNDERSCORE)
36 #pragma weak mpi_info_delete = pmpi_info_delete
37 #else
38 #pragma weak mpi_info_delete_ = pmpi_info_delete_
39 #endif
40
41 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
42 #if defined(FORTRANCAPS)
43 #pragma _HP_SECONDARY_DEF PMPI_INFO_DELETE MPI_INFO_DELETE
44 #elif defined(FORTRANDOUBLEUNDERSCORE)
45 #pragma _HP_SECONDARY_DEF pmpi_info_delete__ mpi_info_delete__
46 #elif !defined(FORTRANUNDERSCORE)
47 #pragma _HP_SECONDARY_DEF pmpi_info_delete mpi_info_delete
48 #else
49 #pragma _HP_SECONDARY_DEF pmpi_info_delete_ mpi_info_delete_
50 #endif
51
52 #elif defined(HAVE_PRAGMA_CRI_DUP)
53 #if defined(FORTRANCAPS)
54 #pragma _CRI duplicate MPI_INFO_DELETE as PMPI_INFO_DELETE
55 #elif defined(FORTRANDOUBLEUNDERSCORE)
56 #pragma _CRI duplicate mpi_info_delete__ as pmpi_info_delete__
57 #elif !defined(FORTRANUNDERSCORE)
58 #pragma _CRI duplicate mpi_info_delete as pmpi_info_delete
59 #else
60 #pragma _CRI duplicate mpi_info_delete_ as pmpi_info_delete_
61 #endif
62
63
64 #endif
65
66 #include "mpioprof.h"
67 #endif
68
69 #else
70
71 #ifdef FORTRANCAPS
72 #define mpi_info_delete_ MPI_INFO_DELETE
73 #elif defined(FORTRANDOUBLEUNDERSCORE)
74 #define mpi_info_delete_ mpi_info_delete__
75 #elif !defined(FORTRANUNDERSCORE)
76 #if defined(HPUX) || defined(SPPUX)
77 #pragma _HP_SECONDARY_DEF mpi_info_delete mpi_info_delete_
78 #endif
79 #define mpi_info_delete_ mpi_info_delete
80 #else
81 #if defined(HPUX) || defined(SPPUX)
82 #pragma _HP_SECONDARY_DEF mpi_info_delete_ mpi_info_delete
83 #endif
84 #endif
85 #endif
86
87 void mpi_info_delete_(MPI_Fint *info, char *key, int *ierr, int keylen)
88 {
89 MPI_Info info_c;
90 char *newkey;
91 int new_keylen, lead_blanks, i;
92
93 if (key <= (char *) 0) {
94 FPRINTF(stderr, "MPI_Info_delete: key is an invalid address\n");
95 MPI_Abort(MPI_COMM_WORLD, 1);
96 }
97
98
99 lead_blanks = 0;
100 for (i=0; i<keylen; i++)
101 if (key[i] == ' ') lead_blanks++;
102 else break;
103
104 for (i=keylen-1; i>=0; i--) if (key[i] != ' ') break;
105 if (i < 0) {
106 FPRINTF(stderr, "MPI_Info_delete: key is a blank string\n");
107 MPI_Abort(MPI_COMM_WORLD, 1);
108 }
109 new_keylen = i + 1 - lead_blanks;
110 key += lead_blanks;
111
112 newkey = (char *) ADIOI_Malloc((new_keylen+1)*sizeof(char));
113 ADIOI_Strncpy(newkey, key, new_keylen);
114 newkey[new_keylen] = '\0';
115
116 info_c = MPI_Info_f2c(*info);
117 *ierr = MPI_Info_delete(info_c, newkey);
118 ADIOI_Free(newkey);
119 }
120