// -*- c++ -*- // // Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana // University Research and Technology // Corporation. All rights reserved. // Copyright (c) 2004-2005 The University of Tennessee and The University // of Tennessee Research Foundation. All rights // reserved. // Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, // University of Stuttgart. All rights reserved. // Copyright (c) 2004-2005 The Regents of the University of California. // All rights reserved. // $COPYRIGHT$ // // Additional copyrights may follow // // $HEADER$ // inline void MPI::File::Close() { (void) MPI_File_close(&mpi_file); } inline void MPI::File::Delete(const char* filename, const MPI::Info& info) { (void) MPI_File_delete(const_cast(filename), info); } inline int MPI::File::Get_amode() const { int amode; (void) MPI_File_get_amode(mpi_file, &amode); return amode; } inline bool MPI::File::Get_atomicity() const { int flag; (void) MPI_File_get_atomicity(mpi_file, &flag); return OPAL_INT_TO_BOOL(flag); } inline MPI::Offset MPI::File::Get_byte_offset(const MPI::Offset disp) const { MPI_Offset offset, ldisp; ldisp = disp; (void) MPI_File_get_byte_offset(mpi_file, ldisp, &offset); return offset; } inline MPI::Group MPI::File::Get_group() const { MPI_Group group; (void) MPI_File_get_group(mpi_file, &group); return group; } inline MPI::Info MPI::File::Get_info() const { MPI_Info info_used; (void) MPI_File_get_info(mpi_file, &info_used); return info_used; } inline MPI::Offset MPI::File::Get_position() const { MPI_Offset offset; (void) MPI_File_get_position(mpi_file, &offset); return offset; } inline MPI::Offset MPI::File::Get_position_shared() const { MPI_Offset offset; (void) MPI_File_get_position_shared(mpi_file, &offset); return offset; } inline MPI::Offset MPI::File::Get_size() const { MPI_Offset offset; (void) MPI_File_get_size(mpi_file, &offset); return offset; } inline MPI::Aint MPI::File::Get_type_extent(const MPI::Datatype& datatype) const { MPI_Aint extent; (void) MPI_File_get_type_extent(mpi_file, datatype, &extent); return extent; } inline void MPI::File::Get_view(MPI::Offset& disp, MPI::Datatype& etype, MPI::Datatype& filetype, char* datarep) const { MPI_Datatype type, ftype; type = etype; ftype = filetype; MPI::Offset odisp = disp; (void) MPI_File_get_view(mpi_file, &odisp, &type, &ftype, datarep); } inline MPI::Request MPI::File::Iread(void* buf, int count, const MPI::Datatype& datatype) { MPI_Request req; (void) MPI_File_iread(mpi_file, buf, count, datatype, &req); return req; } inline MPI::Request MPI::File::Iread_at(MPI::Offset offset, void* buf, int count, const MPI::Datatype& datatype) { MPI_Request req; (void) MPI_File_iread_at(mpi_file, offset, buf, count, datatype, &req); return req; } inline MPI::Request MPI::File::Iread_shared(void* buf, int count, const MPI::Datatype& datatype) { MPI_Request req; (void) MPI_File_iread_shared(mpi_file, buf, count, datatype, &req); return req; } inline MPI::Request MPI::File::Iwrite(const void* buf, int count, const MPI::Datatype& datatype) { MPI_Request req; (void) MPI_File_iwrite(mpi_file, const_cast(buf), count, datatype, &req); return req; } inline MPI::Request MPI::File::Iwrite_at(MPI::Offset offset, const void* buf, int count, const MPI::Datatype& datatype) { MPI_Request req; (void) MPI_File_iwrite_at(mpi_file, offset, const_cast(buf), count, datatype, &req); return req; } inline MPI::Request MPI::File::Iwrite_shared(const void* buf, int count, const MPI::Datatype& datatype) { MPI_Request req; (void) MPI_File_iwrite_shared(mpi_file, const_cast(buf), count, datatype, &req); return req; } inline MPI::File MPI::File::Open(const MPI::Intracomm& comm, const char* filename, int amode, const MPI::Info& info) { MPI_File fh; (void) MPI_File_open(comm, const_cast(filename), amode, info, &fh); return fh; } inline void MPI::File::Preallocate(MPI::Offset size) { (void) MPI_File_preallocate(mpi_file, size); } inline void MPI::File::Read(void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_read(mpi_file, buf, count, datatype, &status); } inline void MPI::File::Read(void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_read(mpi_file, buf, count, datatype, &status.mpi_status); } inline void MPI::File::Read_all(void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_read_all(mpi_file, buf, count, datatype, &status); } inline void MPI::File::Read_all(void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_read_all(mpi_file, buf, count, datatype, &status.mpi_status); } inline void MPI::File::Read_all_begin(void* buf, int count, const MPI::Datatype& datatype) { (void) MPI_File_read_all_begin(mpi_file, buf, count, datatype); } inline void MPI::File::Read_all_end(void* buf) { MPI_Status status; (void) MPI_File_read_all_end(mpi_file, buf, &status); } inline void MPI::File::Read_all_end(void* buf, MPI::Status& status) { (void) MPI_File_read_all_end(mpi_file, buf, &status.mpi_status); } inline void MPI::File::Read_at(MPI::Offset offset, void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_read_at(mpi_file, offset, buf, count, datatype, &status); } inline void MPI::File::Read_at(MPI::Offset offset, void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_read_at(mpi_file, offset, buf, count, datatype, &status.mpi_status); } inline void MPI::File::Read_at_all(MPI::Offset offset, void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_read_at_all(mpi_file, offset, buf, count, datatype, &status); } inline void MPI::File::Read_at_all(MPI::Offset offset, void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_read_at_all(mpi_file, offset, buf, count, datatype, &status.mpi_status); } inline void MPI::File::Read_at_all_begin(MPI::Offset offset, void* buf, int count, const MPI::Datatype& datatype) { (void) MPI_File_read_at_all_begin(mpi_file, offset, buf, count, datatype); } inline void MPI::File::Read_at_all_end(void* buf) { MPI_Status status; (void) MPI_File_read_at_all_end(mpi_file, buf, &status); } inline void MPI::File::Read_at_all_end(void* buf, MPI::Status& status) { (void) MPI_File_read_at_all_end(mpi_file, buf, &status.mpi_status); } inline void MPI::File::Read_ordered(void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_read_ordered(mpi_file, buf, count, datatype, &status); } inline void MPI::File::Read_ordered(void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_read_ordered(mpi_file, buf, count, datatype, &status.mpi_status); } inline void MPI::File::Read_ordered_begin(void* buf, int count, const MPI::Datatype& datatype) { (void) MPI_File_read_ordered_begin(mpi_file, buf, count, datatype); } inline void MPI::File::Read_ordered_end(void* buf) { MPI_Status status; (void) MPI_File_read_ordered_end(mpi_file, buf, &status); } inline void MPI::File::Read_ordered_end(void* buf, MPI::Status& status) { (void) MPI_File_read_ordered_end(mpi_file, buf, &status.mpi_status); } inline void MPI::File::Read_shared(void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_read_shared(mpi_file, buf, count, datatype, &status); } inline void MPI::File::Read_shared(void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_read_shared(mpi_file, buf, count, datatype, &status.mpi_status); } inline void MPI::File::Seek(MPI::Offset offset, int whence) { (void) MPI_File_seek(mpi_file, offset, whence); } inline void MPI::File::Seek_shared(MPI::Offset offset, int whence) { (void) MPI_File_seek_shared(mpi_file, offset, whence); } inline void MPI::File::Set_atomicity(bool flag) { (void) MPI_File_set_atomicity(mpi_file, flag); } inline void MPI::File::Set_info(const MPI::Info& info) { (void) MPI_File_set_info(mpi_file, info); } inline void MPI::File::Set_size(MPI::Offset size) { (void) MPI_File_set_size(mpi_file, size); } inline void MPI::File::Set_view(MPI::Offset disp, const MPI::Datatype& etype, const MPI::Datatype& filetype, const char* datarep, const MPI::Info& info) { (void) MPI_File_set_view(mpi_file, disp, etype, filetype, const_cast(datarep), info); } inline void MPI::File::Sync() { (void) MPI_File_sync(mpi_file); } inline void MPI::File::Write(const void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_write(mpi_file, const_cast(buf), count, datatype, &status); } inline void MPI::File::Write(const void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_write(mpi_file, const_cast(buf), count, datatype, &status.mpi_status); } inline void MPI::File::Write_all(const void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_write_all(mpi_file, const_cast(buf), count, datatype, &status); } inline void MPI::File::Write_all(const void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_write_all(mpi_file, const_cast(buf), count, datatype, &status.mpi_status); } inline void MPI::File::Write_all_begin(const void* buf, int count, const MPI::Datatype& datatype) { (void) MPI_File_write_all_begin(mpi_file, const_cast(buf), count, datatype); } inline void MPI::File::Write_all_end(const void* buf) { MPI_Status status; (void) MPI_File_write_all_end(mpi_file, const_cast(buf), &status); } inline void MPI::File::Write_all_end(const void* buf, MPI::Status& status) { (void) MPI_File_write_all_end(mpi_file, const_cast(buf), &status.mpi_status); } inline void MPI::File::Write_at(MPI::Offset offset, const void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_write_at(mpi_file, offset, const_cast(buf), count, datatype, &status); } inline void MPI::File::Write_at(MPI::Offset offset, const void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_write_at(mpi_file, offset, const_cast(buf), count, datatype, &status.mpi_status); } inline void MPI::File::Write_at_all(MPI::Offset offset, const void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_write_at_all(mpi_file, offset, const_cast(buf), count, datatype, &status); } inline void MPI::File::Write_at_all(MPI::Offset offset, const void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_write_at_all(mpi_file, offset, const_cast(buf), count, datatype, &status.mpi_status); } inline void MPI::File::Write_at_all_begin(MPI::Offset offset, const void* buf, int count, const MPI::Datatype& datatype) { (void) MPI_File_write_at_all_begin(mpi_file, offset, const_cast(buf), count, datatype); } inline void MPI::File::Write_at_all_end(const void* buf) { MPI_Status status; (void) MPI_File_write_at_all_end(mpi_file, const_cast(buf), &status); } inline void MPI::File::Write_at_all_end(const void* buf, MPI::Status& status) { (void) MPI_File_write_at_all_end(mpi_file, const_cast(buf), &status.mpi_status); } inline void MPI::File::Write_ordered(const void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_write_ordered(mpi_file, const_cast(buf), count, datatype, &status); } inline void MPI::File::Write_ordered(const void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_write_ordered(mpi_file, const_cast(buf), count, datatype, &status.mpi_status); } inline void MPI::File::Write_ordered_begin(const void* buf, int count, const MPI::Datatype& datatype) { (void) MPI_File_write_ordered_begin(mpi_file, const_cast(buf), count, datatype); } inline void MPI::File::Write_ordered_end(const void* buf) { MPI_Status status; (void) MPI_File_write_ordered_end(mpi_file, const_cast(buf), &status); } inline void MPI::File::Write_ordered_end(const void* buf, MPI::Status& status) { (void) MPI_File_write_ordered_end(mpi_file, const_cast(buf), &status.mpi_status); } inline void MPI::File::Write_shared(const void* buf, int count, const MPI::Datatype& datatype) { MPI_Status status; (void) MPI_File_write_shared(mpi_file, const_cast(buf), count, datatype, &status); } inline void MPI::File::Write_shared(const void* buf, int count, const MPI::Datatype& datatype, MPI::Status& status) { (void) MPI_File_write_shared(mpi_file, const_cast(buf), count, datatype, &status.mpi_status); } inline MPI::Errhandler MPI::File::Get_errhandler() const { MPI_Errhandler err; (void) MPI_File_get_errhandler(mpi_file, &err); return err; } inline void MPI::File::Set_errhandler(const MPI::Errhandler& errhandler) { (void) MPI_File_set_errhandler(mpi_file, errhandler); }