post_wait_unpack_buffer.h
Go to the documentation of this file.
1 // The libMesh Finite Element Library.
2 // Copyright (C) 2002-2018 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner
3 
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either
7 // version 2.1 of the License, or (at your option) any later version.
8 
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 // Lesser General Public License for more details.
13 
14 // You should have received a copy of the GNU Lesser General Public
15 // License along with this library; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 
18 
19 #ifndef LIBMESH_POST_WAIT_UNPACK_BUFFER_H
20 #define LIBMESH_POST_WAIT_UNPACK_BUFFER_H
21 
22 // Parallel includes
23 #include "libmesh/post_wait_work.h"
24 #include "libmesh/packing.h"
25 
26 // libMesh Includes
27 #include "libmesh/libmesh_common.h"
28 
29 namespace libMesh
30 {
31 
32 namespace Parallel
33 {
34 
35 // PostWaitWork specialization for unpacking received buffers.
36 template <typename Container, typename Context, typename OutputIter,
37  typename T>
39  PostWaitUnpackBuffer(const Container & buffer, Context * context, OutputIter out) :
40  _buf(buffer), _context(context), _out(out) {}
41 
42  virtual void run() override {
43 
44  Parallel::unpack_range(_buf, _context, _out, (T*)nullptr);
45  }
46 
47 private:
48  const Container & _buf;
49  Context * _context;
50  OutputIter _out;
51 };
52 
53 } // namespace Parallel
54 
55 } // namespace libMesh
56 
57 #endif // LIBMESH_POST_WAIT_UNPACK_BUFFER_H
PostWaitUnpackBuffer(const Container &buffer, Context *context, OutputIter out)
OStreamProxy out(std::cout)
void unpack_range(const typename std::vector< buffertype > &buffer, Context *context, OutputIter out, const T *output_type)