source: XIOS/dev/dev_olga/src/interface/c/icfield.cpp @ 1612

Last change on this file since 1612 was 1612, checked in by oabramkina, 5 years ago

Dev: adding exception handling.

To activate it, compilation flag -DXIOS_EXCEPTION should be added.

  • 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
  • Property svn:eol-style set to native
File size: 3.9 KB
RevLine 
[325]1/* ************************************************************************** *
[335]2 *      Copyright © IPSL/LSCE, xios, Avril 2010 - Octobre 2011         *
[325]3 * ************************************************************************** */
4
5#include <boost/multi_array.hpp>
6
[1542]7#include <memory>
8
[591]9#include "xios.hpp"
[325]10
[352]11#include "attribute_template.hpp"
12#include "object_template.hpp"
13#include "group_template.hpp"
[325]14
15#include "icutil.hpp"
[347]16#include "timer.hpp"
[352]17#include "field.hpp"
[325]18
19extern "C"
20{
21// /////////////////////////////// Définitions ////////////////////////////// //
22
23   // ----------------------- Redéfinition de types ----------------------------
24   
[345]25   typedef xios::CField      * XFieldPtr;
26   typedef xios::CFieldGroup * XFieldGroupPtr;
[325]27   
[943]28   typedef xios::CDomain     * XDomainPtr;
29   typedef xios::CAxis       * XAxisPtr;
30   typedef xios::CScalar     * XScalarPtr;
31
[325]32// --------------------------------------------------------------------------   
33// ------------------------ Création des handle -----------------------------
34// --------------------------------------------------------------------------   
35   
36   void cxios_field_handle_create (XFieldPtr * _ret, const char * _id, int _id_len)
[1612]37   TRY
[325]38   {
39      std::string id; 
40      if (!cstr2string(_id, _id_len, id)) return;
[347]41      CTimer::get("XIOS").resume() ;
42      *_ret = CField::get(id);
43      CTimer::get("XIOS").suspend() ;
[325]44   }
[1612]45   CATCH_DUMP_STACK
[325]46   
47   void cxios_fieldgroup_handle_create (XFieldGroupPtr * _ret, const char * _id, int _id_len)
[1612]48   TRY
[325]49   {
50      std::string id; 
51      if (!cstr2string(_id, _id_len, id)) return;
[347]52      CTimer::get("XIOS").resume() ;
53      *_ret = CFieldGroup::get(id);
54      CTimer::get("XIOS").suspend() ;
[325]55   }
[1612]56   CATCH_DUMP_STACK
[325]57
58   // -------------------- Vérification des identifiants -----------------------
59
60   void cxios_field_valid_id (bool * _ret, const char * _id, int _id_len)
[1612]61   TRY
[325]62   {
63      std::string id;
64      if (!cstr2string(_id, _id_len, id)) return;
[347]65      CTimer::get("XIOS").resume() ;
[346]66      *_ret = CField::has(id);
[347]67      CTimer::get("XIOS").suspend() ;
[325]68   }
[1612]69   CATCH_DUMP_STACK
[325]70
71   void cxios_fieldgroup_valid_id (bool * _ret, const char * _id, int _id_len)
[1612]72   TRY
[325]73   {
74      std::string id;
75      if (!cstr2string(_id, _id_len, id)) return;
[347]76      CTimer::get("XIOS").resume() ;
[346]77      *_ret = CFieldGroup::has(id);
[347]78      CTimer::get("XIOS").suspend() ;
[325]79   }
[1612]80   CATCH_DUMP_STACK
[325]81
82// -----------------------------------------------------------------------------------------------------   
[943]83// ------------------------- Other functions
[325]84// -----------------------------------------------------------------------------------------------------   
85
[1158]86  void cxios_field_is_active (XFieldPtr field_hdl, bool at_current_timestep, bool* ret)
[1612]87  TRY
[325]88  {
[347]89    CTimer::get("XIOS").resume() ;
[1158]90    *ret = field_hdl->isActive(at_current_timestep);
[347]91    CTimer::get("XIOS").suspend() ;
[325]92  }
[1612]93  CATCH_DUMP_STACK
[943]94
95// -----------------------------------------------------------------------------------------------------
96// ------------------------- Retrieving information of grid associated to field
97// -----------------------------------------------------------------------------------------------------
98  void cxios_field_get_domain_handle(XDomainPtr * domain_hdl_ret, XFieldPtr field_hdl, int domainIndex)
[1612]99  TRY
[943]100  {
101     CTimer::get("XIOS").resume() ;
102     *domain_hdl_ret = field_hdl->grid->getDomain(domainIndex);
103     CTimer::get("XIOS").suspend();
104  }
[1612]105  CATCH_DUMP_STACK
[943]106
107  void cxios_field_get_axis_handle(XAxisPtr * axis_hdl_ret, XFieldPtr field_hdl, int axisIndex)
[1612]108  TRY
[943]109  {
110     CTimer::get("XIOS").resume() ;
111     *axis_hdl_ret = field_hdl->grid->getAxis(axisIndex);
112     CTimer::get("XIOS").suspend();
113  }
[1612]114  CATCH_DUMP_STACK
[943]115
116  void cxios_field_get_scalar_handle(XScalarPtr * scalar_hdl_ret, XFieldPtr field_hdl, int scalarIndex)
[1612]117  TRY
[943]118  {
119     CTimer::get("XIOS").resume() ;
120     *scalar_hdl_ret = field_hdl->grid->getScalar(scalarIndex);
121     CTimer::get("XIOS").suspend();
122  }
[1612]123  CATCH_DUMP_STACK
[325]124} // extern "C"
Note: See TracBrowser for help on using the repository browser.