Arcane  v3.15.0.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
IMeshReader.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2022 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/* IMeshReader.h (C) 2000-2008 */
9/* */
10/* Interface d'un service de lecture du maillage. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_IMESHREADER_H
13#define ARCANE_IMESHREADER_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/ArcaneTypes.h"
18
19/*---------------------------------------------------------------------------*/
20/*---------------------------------------------------------------------------*/
21
22ARCANE_BEGIN_NAMESPACE
23
24/*---------------------------------------------------------------------------*/
25/*---------------------------------------------------------------------------*/
26
27class IPrimaryMesh;
28class XmlNode;
29
30/*---------------------------------------------------------------------------*/
31/*---------------------------------------------------------------------------*/
32/*!
33 * \ingroup StandardService
34 * \brief Interface du service gérant la lecture d'un maillage.
35 */
36class ARCANE_CORE_EXPORT IMeshReader
37{
38 public:
39
40 //! Types des codes de retour d'une lecture ou écriture
42 {
43 RTOk, //!< Opération effectuée avec succès
44 RTError, //!< Erreur lors de l'opération
45 /*! \brief Non concerné par l'opération.
46 * Cela signifie que le format de fichier ne correspond
47 * pas à ce lecteur ou que le service ne prend pas en compte
48 * cette opération.
49 */
50 RTIrrelevant
51 };
52
53 public:
54
55 virtual ~IMeshReader() {} //<! Libère les ressources
56
57 public:
58
59 //! Vérifie si le service supporte les fichiers avec l'extension \a str
60 virtual bool allowExtension(const String& str) =0;
61
62 /*! \brief Lit un maillage à partir d'un fichier.
63 *
64 * Lit la géométrie d'un maillage à partir du fichier \a file_name
65 * ainsi que les informations de découpage correspondantes
66 * et construit le maillage correspondant dans \a mesh.
67 *
68 * Si \a use_internal_partition est vrai, cela signifie que le partitionnement
69 * n'est pas encore fait et qu'il sera fait par Arcane. Dans ce cas,
70 * un seul processeur peut lire le maillage. Cependant, les autres
71 * doivent tout de même créer tous les groupes possibles.
72 * Cet argument n'est utile qu'en parallèle.
73
74 * Si \a dir_name n'est pas nul, ce chemim sert de base pour la lecture
75 * des maillages et informations de découpage.
76 */
78 const XmlNode& mesh_element,
79 const String& file_name,
80 const String& dir_name,
81 bool use_internal_partition) =0;
82};
83
84/*---------------------------------------------------------------------------*/
85/*---------------------------------------------------------------------------*/
86
87ARCANE_END_NAMESPACE
88
89/*---------------------------------------------------------------------------*/
90/*---------------------------------------------------------------------------*/
91
92#endif
93
Interface du service gérant la lecture d'un maillage.
Definition IMeshReader.h:37
virtual bool allowExtension(const String &str)=0
Vérifie si le service supporte les fichiers avec l'extension str.
virtual eReturnType readMeshFromFile(IPrimaryMesh *mesh, const XmlNode &mesh_element, const String &file_name, const String &dir_name, bool use_internal_partition)=0
Lit un maillage à partir d'un fichier.
eReturnType
Types des codes de retour d'une lecture ou écriture.
Definition IMeshReader.h:42
@ RTError
Erreur lors de l'opération.
Definition IMeshReader.h:44
@ RTOk
Opération effectuée avec succès.
Definition IMeshReader.h:43
Noeud d'un arbre DOM.
Definition XmlNode.h:51
Chaîne de caractères unicode.