Arcane  v3.14.10.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
MeshHandle.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2023 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/* MeshHandle.h (C) 2000-2023 */
9/* */
10/* Handle sur un maillage. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_MESHHANDLE_H
13#define ARCANE_MESHHANDLE_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
18#include "arccore/base/StringView.h"
19#include "arccore/base/String.h"
20
22#include "arcane/ArcaneTypes.h"
23
24#include <atomic>
25
26/*---------------------------------------------------------------------------*/
27/*---------------------------------------------------------------------------*/
28
29namespace Arcane
30{
31
32/*---------------------------------------------------------------------------*/
33/*---------------------------------------------------------------------------*/
46class ARCANE_CORE_EXPORT MeshHandle
47{
48 private:
49
50 // Temporaire: pour accéder au constructeur qui utilise ISubDomain.
51 friend class MeshMng;
52
53 private:
54
57 {
58 public:
59
61 : m_is_null(true)
62 {}
63 MeshHandleRef(ISubDomain* sd, const String& name);
65
66 public:
67
68 const String& meshName() const { return m_mesh_name; }
69 bool isNull() const { return m_is_null; }
70 IMesh* mesh() const { return m_mesh_ptr; }
71 IMeshBase* meshBase() const { return m_mesh_base_ptr; }
72 ISubDomain* subDomain() const { return m_sub_domain; }
73 IMeshMng* meshMng() const { return m_mesh_mng; }
74 ITraceMng* traceMng() const { return m_trace_mng; }
75 IVariableMng* variableMng() const { return m_variable_mng; }
76 IUserDataList* userDataList() const { return m_user_data_list; }
77 Observable* onDestroyObservable() const { return m_on_destroy_observable; }
78 bool isDoFatalInMeshMethod() const { return m_do_fatal_in_mesh_method; }
79
80 public:
81
82 void _destroyMesh();
83 void _setMesh(IMesh* mesh);
84
85 private:
86
87 String m_mesh_name;
88 IMesh* m_mesh_ptr = nullptr;
89 IMeshBase* m_mesh_base_ptr = nullptr;
90 // Pour l'instant on en a besoin mais il faudrait le supprimer
91 ISubDomain* m_sub_domain = nullptr;
92 IUserDataList* m_user_data_list = nullptr;
93 IMeshMng* m_mesh_mng = nullptr;
94 ITraceMng* m_trace_mng = nullptr;
95 IVariableMng* m_variable_mng = nullptr;
96 Observable* m_on_destroy_observable = nullptr;
97 bool m_is_null = true;
98 bool m_do_fatal_in_mesh_method = false;
99 };
100
101 public:
102
103 MeshHandle();
104
105 private:
106
107 // TODO rendre accessible uniquement aux classes implémentant IMeshMng.
108 MeshHandle(ISubDomain* sd, const String& name);
109
110 public:
111
123 IMesh* mesh() const;
124
126 bool hasMesh() const;
127
134 IMesh* meshOrNull() const;
135
136 public:
137
139 ARCCORE_DEPRECATED_2020("Do not use this method. Try to get ISubDomain from another way")
140 ISubDomain* subDomain() const { return m_ref->subDomain(); }
141
142 public:
143
145 IMeshMng* meshMng() const;
146
148 ITraceMng* traceMng() const;
149
151 IVariableMng* variableMng() const;
152
154 IApplication* application() const;
155
157 IUserDataList* meshUserDataList() const { return m_ref->userDataList(); }
158
159 const String& meshName() const { return m_ref->meshName(); }
160
162 bool isNull() const { return m_ref->isNull(); }
163
165 IObservable* onDestroyObservable() const;
166
168 const void* reference() const { return m_ref.get(); }
169
170 public:
171
173 void _setMesh(IMesh* mesh) { m_ref->_setMesh(mesh); }
174
176 void _destroyMesh() { m_ref->_destroyMesh(); }
177
179 IMesh* _internalMeshOrNull() const { return m_ref->mesh(); }
180
181 private:
182
184};
185
186/*---------------------------------------------------------------------------*/
187/*---------------------------------------------------------------------------*/
193class ARCANE_CORE_EXPORT MeshHandleOrMesh
194{
195 public:
196
197 // NOTE: Les constructeurs ne doivent pas être explicites
198 // pour autoriser les conversions
199
201 MeshHandleOrMesh(const MeshHandle& handle);
202
208 MeshHandleOrMesh(IMesh* mesh);
209
211 IMesh* mesh() const { return m_handle.meshOrNull(); }
212
214 operator IMesh*() const { return mesh(); }
215
217 const MeshHandle& handle() const { return m_handle; }
218
219 private:
220
221 MeshHandle m_handle;
222};
223
224/*---------------------------------------------------------------------------*/
225/*---------------------------------------------------------------------------*/
226
227} // End namespace Arcane
228
229/*---------------------------------------------------------------------------*/
230/*---------------------------------------------------------------------------*/
231
232#endif
Déclarations des types utilisés dans Arcane.
Interface de l'application.
Interface du gestionnaire des maillages.
Definition IMeshMng.h:40
Interface d'un observable.
Interface du gestionnaire d'un sous-domaine.
Definition ISubDomain.h:74
Interface d'une liste qui gère des données utilisateurs.
Interface du gestionnaire de variables.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:120
Classe de compatibilité pour contenir un MeshHandle ou un IMesh*.
Definition MeshHandle.h:194
IMesh * mesh() const
Maillage associé. Peut être nul si le maillage n'a pas encore été créé
Definition MeshHandle.h:211
const MeshHandle & handle() const
handle associé.
Definition MeshHandle.h:217
Handle sur un maillage.
Definition MeshHandle.h:47
void _setMesh(IMesh *mesh)
Definition MeshHandle.h:173
const void * reference() const
Definition MeshHandle.h:168
bool isNull() const
Indique si le handle est nul (il ne référence aucun maillage existant ou non)
Definition MeshHandle.h:162
IUserDataList * meshUserDataList() const
Données utilisateurs associées.
Definition MeshHandle.h:157
IMesh * _internalMeshOrNull() const
Definition MeshHandle.h:179
Classe de base d'un observable.
Interface du gestionnaire de traces.
Implémentation thread-safe d'un compteur de référence.
Encapsulation d'un pointeur avec compteur de référence.
Chaîne de caractères unicode.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-