Changeset 545 for XIOS/trunk/src/node


Ignore:
Timestamp:
12/17/14 11:14:05 (9 years ago)
Author:
rlacroix
Message:

Expose the calendar operations through the Fortran interface.

  • Add arithmetic operations on the xios_duration and xios_date types:
    • xios_duration + xios_duration = xios_duration
    • xios_duration - xios_duration = xios_duration
    • scalar * xios_duration = xios_duration * scalar = xios_duration
    • - xios_duration = xios_duration
    • xios_date + xios_duration = xios_date
    • xios_date - xios_duration = xios_date
    • xios_date - xios_date = xios_duration
  • Add comparison operations on the xios_duration and xios_date types:
    • xios_duration: ==, /=
    • xios_date: ==, /=, <, <=, >, >=
  • Add a new function "xios_date_convert_to_seconds" to convert a date into the number of seconds since the time origin of the calendar
  • Define some constant durations "xios_second", "xios_minute", "xios_hour", "xios_day", "xios_month", "xios_year" et "xios_timestep" to ease the definition of new durations (for example, 10h is just 10 * xios_hour)
  • Add a new function "xios_set_calendar" so that one can manually create the calendar attached to the current context and thus use the calendar operations before calling "xios_close_context_definition". This function can accept optional parameters so that the calendar attributes (calendar_type, start_date, time_origin and timestep) can be easily overwritten. Note that you cannot define a new calendar after one was already created (either because "xios_set_calendar" or "xios_close_context_definition" was used)
  • Readd the function "xios_set_timestep" as a simplified alias of "xios_set_context_attr(context, timestep)" for the current context
File:
1 edited

Legend:

Unmodified
Added
Removed
  • XIOS/trunk/src/node/context.cpp

    r541 r545  
    8181   void CContext::solveCalendar(void) 
    8282   { 
    83       if (this->calendar.get() != NULL) return; 
    8483      if (calendar_type.isEmpty()) 
    8584         ERROR(" CContext::solveCalendar(void)", 
     
    9493               << "[ context id = " << this->getId() << " ] " 
    9594               << "Impossible to define a calendar: the timestep is missing."); 
     95 
     96      if (this->calendar) 
     97      { 
     98        if (this->calendar->getId() != calendar_type.getStringValue() 
     99              || this->calendar->getInitDate() != start_date.getValue() 
     100              || (time_origin.isEmpty() && this->calendar->getTimeOrigin() != start_date.getValue()) 
     101              || (!time_origin.isEmpty() && this->calendar->getTimeOrigin() != time_origin.getValue()) 
     102              || this->calendar->getTimeStep() != timestep.getValue()) 
     103          ERROR(" CContext::solveCalendar(void)", 
     104                << "[ context id = " << this->getId() << " ] " 
     105                << "Impossible to define a calendar again with new parameters."); 
     106        return; 
     107      } 
    96108 
    97109#define DECLARE_CALENDAR(MType, eType)                                             \ 
Note: See TracChangeset for help on using the changeset viewer.