48 строки
1014 B
C
48 строки
1014 B
C
|
// -*- c++ -*-
|
||
|
//
|
||
|
// $HEADER$
|
||
|
//
|
||
|
|
||
|
class Op {
|
||
|
public:
|
||
|
|
||
|
// construction
|
||
|
Op();
|
||
|
Op(const MPI_Op &i);
|
||
|
Op(const Op& op);
|
||
|
#if 0 /* OMPI_ENABLE_MPI_PROFILING */
|
||
|
Op(const PMPI::Op& op) : pmpi_op(op) { }
|
||
|
#endif
|
||
|
// destruction
|
||
|
virtual ~Op();
|
||
|
// assignment
|
||
|
Op& operator=(const Op& op);
|
||
|
Op& operator= (const MPI_Op &i);
|
||
|
// comparison
|
||
|
inline bool operator== (const Op &a);
|
||
|
inline bool operator!= (const Op &a);
|
||
|
// conversion functions for inter-language operability
|
||
|
inline operator MPI_Op () const;
|
||
|
// inline operator MPI_Op* (); //JGS const
|
||
|
#if 0 /* OMPI_ENABLE_MPI_PROFILING */
|
||
|
inline operator const PMPI::Op&() const { return pmpi_op; }
|
||
|
#endif
|
||
|
// Collective Communication
|
||
|
//JGS took const out
|
||
|
virtual void Init(User_function *func, bool commute);
|
||
|
virtual void Free();
|
||
|
|
||
|
#if ! 0 /* OMPI_ENABLE_MPI_PROFILING */
|
||
|
User_function *op_user_function; //JGS move to private
|
||
|
protected:
|
||
|
MPI_Op mpi_op;
|
||
|
#endif
|
||
|
|
||
|
#if 0 /* OMPI_ENABLE_MPI_PROFILING */
|
||
|
private:
|
||
|
PMPI::Op pmpi_op;
|
||
|
#endif
|
||
|
|
||
|
};
|
||
|
|