This file is indexed.

/usr/include/lam/mpi2cxx/pwin.h is in lam4-dev 7.1.4-3.1build1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
// -*- c++ -*- 
// 
// $Id: pwin.h,v 1.3 2003/01/20 03:43:06 vsahay Exp $ 
// 
// Copyright (c) 2001-2002 The Trustees of Indiana University.   
//                         All rights reserved. 
// Copyright (c) 1998-2001 University of Notre Dame.  
//                         All rights reserved. 
// Copyright (c) 1994-1998 The Ohio State University.   
//                         All rights reserved. 
//  
// This file is part of the LAM/MPI software package.  For license 
// information, see the LICENSE file in the top level directory of the 
// LAM/MPI source distribution. 
//  
// $HEADER$ 
//

class Win {

  friend class PComm; //so I can access pmpi_win data member in comm.cc
  friend class PRequest; //and also from request.cc

public:

  inline Win() { }
  // copy
  Win(const Win& data) : mpi_win(data.mpi_win) { }

  inline Win(const MPI_Win &i) : mpi_win(i) { }

  inline virtual ~Win() {}

  Win& operator=(const Win& data) {
    mpi_win = data.mpi_win; return *this; }

  // comparison, don't need for win

  // inter-language operability
  inline Win& operator= (const MPI_Win &i) {
    mpi_win = i; return *this; }
  inline operator MPI_Win () const { return mpi_win; }
  //  operator MPI_Win* () const { return (MPI_Win*)&mpi_win; }

  
  //
  // User defined functions
  //

  typedef int Copy_attr_function(const Win& oldwin, int win_keyval, 
				 void* extra_state, void* attribute_val_in, 
				 void* attribute_val_out, bool& flag); 
  
  typedef int Delete_attr_function(Win& win, int win_keyval, 
				   void* attribute_val, void* extra_state); 
  
  typedef void Errhandler_fn(Win &, int *, ... );
  
  //
  // Miscellany
  //
  static Errhandler Create_errhandler(Errhandler_fn* fn); 
  
  inline virtual Errhandler Get_errhandler() const; 

  inline virtual void Set_errhandler(const Errhandler& errhandler);

  //
  // One sided communication
  //
  inline virtual void Accumulate(const void* origin_addr, int origin_count, 
				 const Datatype& origin_datatype, 
				 int target_rank, Aint target_disp, 
				 int target_count, 
				 const Datatype& target_datatype, 
				 const Op& op) const;
  
  inline virtual void Complete() const;
  
  static  Win Create(const void* base, Aint size, int disp_unit, 
		     const Info& info, const Intracomm& comm);
  
  inline virtual void Fence(int assert) const;
  
  inline virtual void Free(); 
  
  inline virtual void Get(const void *origin_addr, int origin_count, 
			  const Datatype& origin_datatype, 
			  int target_rank, Aint target_disp, 
			  int target_count, 
			  const Datatype& target_datatype) const;
  
  inline virtual Group Get_group() const;  
  
#if LAM_WANT_MPI_STUBS  
  // This function is not yet implemented in LAM/MPI.  So it should
  // fail to compile if the user tries to use it.
  inline virtual void Lock(int lock_type, int rank, int assert) const;
#endif
  
  inline virtual void Post(const Group& group, int assert) const;
  
  inline virtual void Put(const void* origin_addr, int origin_count, 
			  const Datatype& origin_datatype, 
			  int target_rank, Aint target_disp, 
			  int target_count, 
			  const Datatype& target_datatype) const;
  
  inline virtual void Start(const Group& group, int assert) const; 
  
#if LAM_WANT_MPI_STUBS  
  // This function is not yet implemented in LAM/MPI.  So it should
  // fail to compile if the user tries to use it.
  inline virtual bool Test() const;
#endif
  
#if LAM_WANT_MPI_STUBS  
  // This function is not yet implemented in LAM/MPI.  So it should
  // fail to compile if the user tries to use it.
  inline virtual void Unlock(int rank) const;
#endif
  
  inline virtual void Wait() const;
  

  //
  // External Interfaces
  //


#if LAM_WANT_MPI_STUBS  
  // This function is not yet implemented in LAM/MPI.  So it should
  // fail to compile if the user tries to use it.
  inline virtual void Call_errhandler(int errorcode) const;
#endif
  
  static int Create_keyval(Copy_attr_function* win_copy_attr_fn, 
			   Delete_attr_function* win_delete_attr_fn, 
			   void* extra_state);
  
  inline virtual void Delete_attr(int win_keyval);
  
  static void Free_keyval(int& win_keyval); 
  
  bool Get_attr(const Win& win, int win_keyval, void* attribute_val) const;
  
  inline virtual void Get_name(char* win_name, int& resultlen) const;
  
  inline virtual void Set_attr(int win_keyval, const void* attribute_val);
  
  inline virtual void Set_name(const char* win_name);
  

protected:
  MPI_Win mpi_win;

};