source: XIOS/dev/dev_olga/src/client.hpp @ 1132

Last change on this file since 1132 was 1130, checked in by oabramkina, 7 years ago

Two-level server: merging new grid functionalities and changes in the communication protocol (e.g. non-blocking context finalize, registries, oasis).

Tests on curie: test_client, test_complete, nemo (test_xios2_cmip6.exe).

To do: non-structured grid, check reading, possible bug in client/server initialization (?).

  • Property copyright set to
    Software name : XIOS (Xml I/O Server)
    http://forge.ipsl.jussieu.fr/ioserver
    Creation date : January 2009
    Licence : CeCCIL version2
    see license file in root directory : Licence_CeCILL_V2-en.txt
    or http://www.cecill.info/licences/Licence_CeCILL_V2-en.html
    Holder : CEA/LSCE (Laboratoire des Sciences du CLimat et de l'Environnement)
    CNRS/IPSL (Institut Pierre Simon Laplace)
    Project Manager : Yann Meurdesoif
    yann.meurdesoif@cea.fr
File size: 1.5 KB
Line 
1#ifndef __CLIENT_HPP__
2#define __CLIENT_HPP__
3
4#include "xios_spl.hpp"
5#include "mpi.hpp"
6
7namespace xios
8{
9    class CClient
10    {
11      public:
12        static void initialize(const string& codeId, MPI_Comm& localComm, MPI_Comm& returnComm);
13
14        static void finalize(void);
15        static void registerContext(const string& id, MPI_Comm contextComm);
16
17        static MPI_Comm intraComm;
18        static MPI_Comm interComm;
19        static std::list<MPI_Comm> contextInterComms;
20        static vector<int> serverLeader;
21        static bool is_MPI_Initialized ;
22
23        static MPI_Comm& getInterComm();
24
25        //! Get rank of the current process
26        static int getRank();
27
28        //! Open a file stream to write the info logs
29        static void openInfoStream(const StdString& fileName);
30        //! Write the info logs to standard output
31        static void openInfoStream();
32        //! Close the info logs file if it opens
33        static void closeInfoStream();
34
35        //! Open a file stream to write the error log
36        static void openErrorStream(const StdString& fileName);
37        //! Write the error log to standard error output
38        static void openErrorStream();
39        //! Close the error log file if it opens
40        static void closeErrorStream();
41
42      protected:
43        static int rank;
44        static StdOFStream m_infoStream;
45        static StdOFStream m_errorStream;
46
47        static void openStream(const StdString& fileName, const StdString& ext, std::filebuf* fb);
48    };
49}
50
51#endif
Note: See TracBrowser for help on using the repository browser.