root/ompi/mca/io/romio321/romio/mpi2-other/info/fortran/info_deletef.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. mpi_info_delete_

   1 /* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil ; -*- */
   2 /* 
   3  *
   4  *   Copyright (C) 1997 University of Chicago. 
   5  *   See COPYRIGHT notice in top-level directory.
   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 /* end of weak pragmas */
  64 #endif
  65 /* Include mapping from MPI->PMPI */
  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     /* strip leading and trailing blanks in key */
  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 

/* [<][>][^][v][top][bottom][index][help] */