source: XIOS/dev/branch_yushan/src/node/field_impl.hpp @ 1037

Last change on this file since 1037 was 1037, checked in by yushan, 7 years ago

initialize the branch

  • 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
2#ifndef __FIELD_IMPL_HPP__
3#define __FIELD_IMPL_HPP__
4
5#include "xios_spl.hpp"
6#include "field.hpp"
7#include "context.hpp"
8#include "grid.hpp"
9#include "timer.hpp"
10#include "array_new.hpp"
11#include "source_filter.hpp"
12#include "store_filter.hpp"
13
14
15namespace xios {
16
17  template <int N>
18  void CField::setData(const CArray<double, N>& _data)
19  {
20    if (clientSourceFilter)
21    {
22      clientSourceFilter->streamData(CContext::getCurrent()->getCalendar()->getCurrentDate(), _data);
23    }
24    else if (!field_ref.isEmpty() || !content.empty())
25      ERROR("void CField::setData(const CArray<double, N>& _data)",
26            << "Impossible to receive data from the model for a field [ id = " << getId() << " ] with a reference or an arithmetic operation.");
27  }
28
29  template <int N>
30  void CField::getData(CArray<double, N>& _data) const
31  {
32    if (storeFilter)
33    {
34      CDataPacket::StatusCode status = storeFilter->getData(CContext::getCurrent()->getCalendar()->getCurrentDate(), _data);
35
36      if (status == CDataPacket::END_OF_STREAM)
37        ERROR("void CField::getData(CArray<double, N>& _data) const",
38              << "Impossible to access field data, all the records of the field [ id = " << getId() << " ] have been already read.");
39    }
40    else
41    {
42      ERROR("void CField::getData(CArray<double, N>& _data) const",
43            << "Impossible to access field data, the field [ id = " << getId() << " ] does not have read access.");
44    }
45  }
46} // namespace xios
47
48#endif
Note: See TracBrowser for help on using the repository browser.