Arcane  v3.16.4.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
ICodeService.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2025 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* ICodeService.h (C) 2000-2025 */
9/* */
10/* Interface du service du code. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_CORE_ICODESERVICE_H
13#define ARCANE_CORE_ICODESERVICE_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
18#include "arcane/core/IService.h"
19
20/*---------------------------------------------------------------------------*/
21/*---------------------------------------------------------------------------*/
22
23namespace Arcane
24{
25
26/*---------------------------------------------------------------------------*/
27/*---------------------------------------------------------------------------*/
28/*!
29 * \brief Interface d'un chargeur de cas.
30 * \ingroup StandardService
31 */
32class ARCANE_CORE_EXPORT ICodeService
33: public IService
34{
35 public:
36
37 ~ICodeService() = default; //!< Libère les ressources
38
39 public:
40
41 /*! \brief Crée une session.
42 *
43 * L'instance doit appeler IApplication::addSession().
44 */
45 virtual ISession* createSession() = 0;
46
47 /*!
48 * \brief Analyse les arguments de la ligne de commandes.
49 *
50 * Le tableau \a args ne contient que les arguments qui n'ont
51 * pas été interprétés par Arcane.
52 *
53 * Les arguments reconnus doivent être supprimés de la liste.
54 *
55 * \retval true si l'exéctution doit s'arrêter,
56 * \retval false si elle continue normalement
57 */
58 virtual bool parseArgs(StringList& args) = 0;
59
60 /*!
61 * \brief Créé et charge le cas avec les infos \a sdbi
62 * pour la session \a session.
63 */
64 virtual ISubDomain* createAndLoadCase(ISession* session, const SubDomainBuildInfo& sdbi) = 0;
65
66 /*!
67 * \brief Initialise la session \a session.
68 *
69 * \param is_continue indique si on est en reprise
70 * Le cas doit déjà avoir été chargé par loadCase()
71 */
72 virtual void initCase(ISubDomain* sub_domain, bool is_continue) = 0;
73
74 //! Retourne si le code accepte l'exécution.
75 virtual bool allowExecution() const = 0;
76
77 /*! \brief Retourne la liste des extensions de fichier traitées par l'instance.
78 * L'extension ne comprend pas le '.'.
79 */
80 virtual StringCollection validExtensions() const = 0;
81
82 /*!
83 * \brief Unité de longueur utilisé par le code.
84 *
85 * Cela doit valoir 1.0 si le code utilise le système international et donc
86 * le mêtre comme unité de longueur. Si l'unité est le centimètre par
87 * exemple, la valeur est 0.01.
88 *
89 * Cette valeur peut être utilisée par exemple lors de la lecture du
90 * maillage si le format de maillage supporte la notion d'unité de
91 * longueur.
92 */
93 virtual Real ARCANE_DEPRECATED lengthUnit() const = 0;
94};
95
96/*---------------------------------------------------------------------------*/
97/*---------------------------------------------------------------------------*/
98
99} // namespace Arcane
100
101/*---------------------------------------------------------------------------*/
102/*---------------------------------------------------------------------------*/
103
104#endif
Déclarations des types généraux de Arcane.
Interface d'un chargeur de cas.
virtual bool parseArgs(StringList &args)=0
Analyse les arguments de la ligne de commandes.
virtual ISubDomain * createAndLoadCase(ISession *session, const SubDomainBuildInfo &sdbi)=0
Créé et charge le cas avec les infos sdbi pour la session session.
virtual Real ARCANE_DEPRECATED lengthUnit() const =0
Unité de longueur utilisé par le code.
virtual bool allowExecution() const =0
Retourne si le code accepte l'exécution.
~ICodeService()=default
Libère les ressources.
virtual ISession * createSession()=0
Crée une session.
virtual void initCase(ISubDomain *sub_domain, bool is_continue)=0
Initialise la session session.
virtual StringCollection validExtensions() const =0
Retourne la liste des extensions de fichier traitées par l'instance. L'extension ne comprend pas le '...
IService()
Constructeur.
Definition IService.h:43
Interface d'une session d'exécution d'un cas.
Definition ISession.h:37
Interface du gestionnaire d'un sous-domaine.
Definition ISubDomain.h:74
Paramètres nécessaires à la construction d'un sous-domaine.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Collection< String > StringCollection
Collection de chaînes de caractères.
Definition UtilsTypes.h:593
List< String > StringList
Tableau de chaînes de caractères unicode.
Definition UtilsTypes.h:596
double Real
Type représentant un réel.