00001
00002
00003
00004
00005
00006
00007
00008
00009 #include "mpio.h"
00010 #include "adio.h"
00011
00012
00013 #if defined(MPIO_BUILD_PROFILING) || defined(HAVE_WEAK_SYMBOLS)
00014 #ifdef FORTRANCAPS
00015 #define mpi_info_set_ PMPI_INFO_SET
00016 #elif defined(FORTRANDOUBLEUNDERSCORE)
00017 #define mpi_info_set_ pmpi_info_set__
00018 #elif !defined(FORTRANUNDERSCORE)
00019 #if defined(HPUX) || defined(SPPUX)
00020 #pragma _HP_SECONDARY_DEF pmpi_info_set pmpi_info_set_
00021 #endif
00022 #define mpi_info_set_ pmpi_info_set
00023 #else
00024 #if defined(HPUX) || defined(SPPUX)
00025 #pragma _HP_SECONDARY_DEF pmpi_info_set_ pmpi_info_set
00026 #endif
00027 #define mpi_info_set_ pmpi_info_set_
00028 #endif
00029
00030 #if defined(HAVE_WEAK_SYMBOLS)
00031 #if defined(HAVE_PRAGMA_WEAK)
00032 #if defined(FORTRANCAPS)
00033 #pragma weak MPI_INFO_SET = PMPI_INFO_SET
00034 #elif defined(FORTRANDOUBLEUNDERSCORE)
00035 #pragma weak mpi_info_set__ = pmpi_info_set__
00036 #elif !defined(FORTRANUNDERSCORE)
00037 #pragma weak mpi_info_set = pmpi_info_set
00038 #else
00039 #pragma weak mpi_info_set_ = pmpi_info_set_
00040 #endif
00041
00042 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00043 #if defined(FORTRANCAPS)
00044 #pragma _HP_SECONDARY_DEF PMPI_INFO_SET MPI_INFO_SET
00045 #elif defined(FORTRANDOUBLEUNDERSCORE)
00046 #pragma _HP_SECONDARY_DEF pmpi_info_set__ mpi_info_set__
00047 #elif !defined(FORTRANUNDERSCORE)
00048 #pragma _HP_SECONDARY_DEF pmpi_info_set mpi_info_set
00049 #else
00050 #pragma _HP_SECONDARY_DEF pmpi_info_set_ mpi_info_set_
00051 #endif
00052
00053 #elif defined(HAVE_PRAGMA_CRI_DUP)
00054 #if defined(FORTRANCAPS)
00055 #pragma _CRI duplicate MPI_INFO_SET as PMPI_INFO_SET
00056 #elif defined(FORTRANDOUBLEUNDERSCORE)
00057 #pragma _CRI duplicate mpi_info_set__ as pmpi_info_set__
00058 #elif !defined(FORTRANUNDERSCORE)
00059 #pragma _CRI duplicate mpi_info_set as pmpi_info_set
00060 #else
00061 #pragma _CRI duplicate mpi_info_set_ as pmpi_info_set_
00062 #endif
00063
00064
00065 #endif
00066
00067 #include "mpioprof.h"
00068 #endif
00069
00070 #else
00071
00072 #ifdef FORTRANCAPS
00073 #define mpi_info_set_ MPI_INFO_SET
00074 #elif defined(FORTRANDOUBLEUNDERSCORE)
00075 #define mpi_info_set_ mpi_info_set__
00076 #elif !defined(FORTRANUNDERSCORE)
00077 #if defined(HPUX) || defined(SPPUX)
00078 #pragma _HP_SECONDARY_DEF mpi_info_set mpi_info_set_
00079 #endif
00080 #define mpi_info_set_ mpi_info_set
00081 #else
00082 #if defined(HPUX) || defined(SPPUX)
00083 #pragma _HP_SECONDARY_DEF mpi_info_set_ mpi_info_set
00084 #endif
00085 #endif
00086 #endif
00087
00088
00089 void mpi_info_set_(MPI_Fint *info, char *key, char *value, int *ierr,
00090 int keylen, int vallen)
00091 {
00092 MPI_Info info_c;
00093 char *newkey, *newvalue;
00094 int new_keylen, new_vallen, lead_blanks, i;
00095
00096 if (key <= (char *) 0) {
00097 FPRINTF(stderr, "MPI_Info_set: key is an invalid address\n");
00098 MPI_Abort(MPI_COMM_WORLD, 1);
00099 }
00100 if (value <= (char *) 0) {
00101 FPRINTF(stderr, "MPI_Info_set: value is an invalid address\n");
00102 MPI_Abort(MPI_COMM_WORLD, 1);
00103 }
00104
00105
00106 lead_blanks = 0;
00107 for (i=0; i<keylen; i++)
00108 if (key[i] == ' ') lead_blanks++;
00109 else break;
00110
00111 for (i=keylen-1; i>=0; i--) if (key[i] != ' ') break;
00112 if (i < 0) {
00113 FPRINTF(stderr, "MPI_Info_set: key is a blank string\n");
00114 MPI_Abort(MPI_COMM_WORLD, 1);
00115 }
00116 new_keylen = i + 1 - lead_blanks;
00117 key += lead_blanks;
00118
00119 newkey = (char *) ADIOI_Malloc((new_keylen+1)*sizeof(char));
00120 strncpy(newkey, key, new_keylen);
00121 newkey[new_keylen] = '\0';
00122
00123
00124
00125 lead_blanks = 0;
00126 for (i=0; i<vallen; i++)
00127 if (value[i] == ' ') lead_blanks++;
00128 else break;
00129
00130 for (i=vallen-1; i>=0; i--) if (value[i] != ' ') break;
00131 if (i < 0) {
00132 FPRINTF(stderr, "MPI_Info_set: value is a blank string\n");
00133 MPI_Abort(MPI_COMM_WORLD, 1);
00134 }
00135 new_vallen = i + 1 - lead_blanks;
00136 value += lead_blanks;
00137
00138 newvalue = (char *) ADIOI_Malloc((new_vallen+1)*sizeof(char));
00139 strncpy(newvalue, value, new_vallen);
00140 newvalue[new_vallen] = '\0';
00141
00142
00143 info_c = MPI_Info_f2c(*info);
00144 *ierr = MPI_Info_set(info_c, newkey, newvalue);
00145 ADIOI_Free(newkey);
00146 ADIOI_Free(newvalue);
00147 }