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