source: XIOS/dev/dev_ym/XIOS_COUPLING/src/filter/client_from_client_source_filter.cpp @ 1960

Last change on this file since 1960 was 1934, checked in by ymipsl, 4 years ago

Big update on on going work related to data distribution and transfer between clients and servers.
Revisite of the source and store filter using "connectors".

-> inputs work again

YM

  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 1.7 KB
Line 
1#include "source_filter.hpp"
2#include "grid.hpp"
3#include "exception.hpp"
4#include "calendar_util.hpp"
5#include "field.hpp"
6#include "context.hpp"
7#include "grid.hpp"
8#include <limits>
9
10namespace xios
11{
12    CClientFromClientSourceFilter::CClientFromClientSourceFilter(CGarbageCollector& gc, CField* field)
13     : COutputPin(gc, true)
14    {
15      CContext* context = CContext::getCurrent();
16      field_=field ;
17      grid_= field-> getGrid();
18
19      freqOp_ = field->freq_op ;
20      lastDateReceived_ = context->getCalendar()->getInitDate();
21      offset_ = field->freq_offset ;
22    }
23
24  void CClientFromClientSourceFilter::streamData(CEventServer& event)
25  {
26    // unlikely to input from file server where data are received at ts=0
27    // for coupling, it would be after the first freq_op, because for now we don't have
28    // restart mecanism to send the value at ts=0. It must be changed in future
29 
30    if (wasDataAlreadyReceived_) lastDateReceived_ = lastDateReceived_ + freqOp_;
31    else wasDataAlreadyReceived_ = true ;
32
33    CDate date = lastDateReceived_ + offset_; // not sure is usefull check it for all filters
34
35    CDataPacketPtr packet(new CDataPacket);
36    packet->date = date;
37    packet->timestamp = date;
38    packet->status = CDataPacket::NO_ERROR;
39
40    grid_->getClientFromClientConnector()->transfer(event,packet->data) ;
41    onOutputReady(packet);
42  }
43
44  bool CClientFromClientSourceFilter::isDataLate(void)
45  {
46    bool isDataLate ;
47    CDate currentDate = CContext::getCurrent()->getCalendar()->getCurrentDate() ;
48    if (wasDataAlreadyReceived_) isDataLate = lastDateReceived_ + offset_ + freqOp_ <= currentDate ;
49    else isDataLate = CContext::getCurrent()->getCalendar()->getInitDate()+ offset_ <= currentDate ;
50  }
51
52} // namespace xios
Note: See TracBrowser for help on using the repository browser.