15#include "arcane/std/SimpleCsvComparatorService.h"
17#include "arcane/Directory.h"
18#include "arcane/IMesh.h"
19#include "arcane/IParallelMng.h"
20#include "arcane/utils/Iostream.h"
42 if (!m_is_already_init) {
43 m_is_already_init =
true;
45 m_simple_table_internal_reference = makeRef(
new SimpleTableInternal(mesh()->parallelMng()));
47 m_simple_table_internal_comparator.
setInternalRef(m_simple_table_internal_reference);
48 m_simple_csv_reader_writer.
setInternal(m_simple_table_internal_reference);
51 m_simple_table_internal_to_compare = m_simple_table_output_ptr->
internal();
56 m_root_path =
Directory(subDomain()->exportDirectory(), m_simple_table_output_ptr->
fileType() +
"_refs");
57 m_reference_path =
Directory(m_root_path, m_output_directory);
58 m_table_name = m_simple_table_output_ptr->
tableName();
59 m_file_name = m_table_name +
"." + m_simple_table_output_ptr->
fileType();
69 m_is_file_read =
false;
71 if (m_is_already_init) {
72 m_simple_table_internal_reference->clear();
83 m_reference_path =
Directory(m_root_path, m_output_directory);
92 if (rank != -1 && subDomain()->parallelMng()->commRank() != rank)
94 m_simple_csv_reader_writer.
print();
105 ARCANE_CHECK_PTR(m_simple_table_output_ptr);
112 m_simple_table_output_ptr->
setPrecision(std::numeric_limits<Real>::max_digits10);
114 m_simple_table_output_ptr->
setFixed(
false);
117 bool fin = m_simple_table_output_ptr->writeFile(m_root_path, rank);
133 if (rank != -1 && subDomain()->parallelMng()->commRank() != rank)
136 m_is_file_read = m_simple_csv_reader_writer.
readTable(m_reference_path, m_table_name);
138 return m_is_file_read;
147 if (rank != -1 && subDomain()->parallelMng()->commRank() != rank)
160 if (rank != -1 && subDomain()->parallelMng()->commRank() != rank) {
165 error() <<
"Error with the file reader: invalid file";
179 if (rank != -1 && subDomain()->parallelMng()->commRank() != rank) {
184 error() <<
"Error with the file reader: invalid file";
198 if (rank != -1 && subDomain()->parallelMng()->commRank() != rank) {
203 error() <<
"Error with the file reader: invalid file";
Classe gérant un répertoire.
Interface représentant une sortie de tableau simple.
virtual void setPrecision(Integer precision)=0
Méthode permettant de modifier la précision du print.
virtual Ref< SimpleTableInternal > internal()=0
Méthode permettant de récupérer une référence vers l'objet SimpleTableInternal utilisé.
virtual String fileType()=0
Méthode permettant de connaitre le type de fichier du service.
virtual String outputDirectory()=0
Accesseur permettant de récupérer le nom du répertoire où sera placé les tableaux.
virtual Integer precision()=0
Méthode permettant de récupérer la précision actuellement utilisée pour l'écriture des valeurs.
virtual String tableName()=0
Accesseur permettant de récupérer le nom des tableaux.
virtual bool isForcedToUseScientificNotation()=0
Méthode permettant de savoir si le frag 'std::scientific' est actif ou non pour l'écriture des valeur...
virtual bool isFixed()=0
Méthode permettant de savoir si le frag 'std::fixed' est actif ou non pour l'écriture des valeurs.
virtual void setFixed(bool fixed)=0
Méthode permettant de définir le flag 'std::fixed' ou non.
virtual void setForcedToUseScientificNotation(bool use_scientific)=0
Méthode permettant de définir le flag 'std::scientific' ou non.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
void init(ISimpleTableOutput *simple_table_output_ptr) override
Méthode permettant d'initialiser le service.
bool addColumnForComparing(const String &column_name) override
Méthode permettant d'ajouter une colonne dans la liste des colonnes à comparer.
void editRegexColumns(const String ®ex_column) override
Méthode permettant d'ajouter une expression régulière permettant de déterminer les colonnes à compare...
bool addRowForComparing(const String &row_name) override
Méthode permettant d'ajouter une ligne dans la liste des lignes à comparer.
void isAnArrayExclusiveColumns(bool is_exclusive) override
Méthode permettant de définir si le tableau de colonnes représente les colonnes à inclure dans la com...
bool addEpsilonRow(const String &row_name, Real epsilon) override
Méthode permettant de définir un epsilon pour une ligne donnée. Cet epsilon doit être positif pour êt...
bool writeReferenceFile(Integer rank) override
void isARegexExclusiveColumns(bool is_exclusive) override
Méthode permettant de demander à ce que l'expression régulière exclut des colonnes au lieu d'en inclu...
void clear() override
Méthode permettant d'effacer les données lues par readReferenceFile().
void print(Integer rank) override
Méthode permettant d'afficher le tableau lu.
bool isReferenceExist(Integer rank) override
Méthode permettant de savoir si les fichiers de réferences existent.
void isAnArrayExclusiveRows(bool is_exclusive) override
Méthode permettant de définir si le tableau de lignes représente les lignes à inclure dans la compara...
bool compareWithReference(Integer rank, bool compare_dimension_too) override
Méthode permettant de comparer l'objet de type ISimpleTableOutput aux fichiers de réferences.
void editRegexRows(const String ®ex_row) override
Méthode permettant d'ajouter une expression régulière permettant de déterminer les lignes à comparer.
bool readReferenceFile(Integer rank) override
Méthode permettant de lire les fichiers de références.
bool addEpsilonColumn(const String &column_name, Real epsilon) override
Méthode permettant de définir un epsilon pour une colonne donnée. Cet epsilon doit être positif pour ...
void isARegexExclusiveRows(bool is_exclusive) override
Méthode permettant de demander à ce que l'expression régulière exclut des lignes au lieu d'en inclure...
bool compareElemWithReference(const String &column_name, const String &row_name, Integer rank) override
Méthode permettant de comparer uniquement un élement. Les deux SimpleTableInternal sont représentés p...
void editRootDirectory(const Directory &root_directory) override
Méthode permettant de modifier le répertoire racine. Cela permet d'écrire ou de rechercher des fichie...
void setInternal(const Ref< SimpleTableInternal > &simple_table_internal) override
Méthode permettant de définir une référence vers un SimpleTableInternal.
bool readTable(const Directory &src, const String &file_name) override
Méthode permettant de lire un fichier contenant un tableau simple.
void print() override
Méthode permettant d'écrire le tableau dans la sortie standard.
bool compare(bool compare_dimension_too) override
Méthode permettant de comparer les valeurs des deux STI.
void setInternalToCompare(const Ref< SimpleTableInternal > &simple_table_internal) override
Méthode permettant de définir une référence vers SimpleTableInternal "à comparer".
void isAnArrayExclusiveRows(bool is_exclusive) override
Méthode permettant de définir si le tableau de lignes représente les lignes à inclure dans la compara...
void setInternalRef(const Ref< SimpleTableInternal > &simple_table_internal) override
Méthode permettant de définir une référence vers un SimpleTableInternal "de référence".
void isAnArrayExclusiveColumns(bool is_exclusive) override
Méthode permettant de définir si le tableau de colonnes représente les colonnes à inclure dans la com...
bool addEpsilonRow(const String &row_name, Real epsilon) override
Méthode permettant de définir un epsilon pour une ligne donnée. Cet epsilon doit être positif pour êt...
bool addRowForComparing(const String &row_name) override
Méthode permettant d'ajouter une ligne dans la liste des lignes à comparer.
bool compareElem(const String &column_name, const String &row_name) override
Méthode permettant de comparer uniquement un élement. Les deux SimpleTableInternal sont représentés p...
void isARegexExclusiveRows(bool is_exclusive) override
Méthode permettant de demander à ce que l'expression régulière exclut des lignes au lieu d'en inclure...
bool addColumnForComparing(const String &column_name) override
Méthode permettant d'ajouter une colonne dans la liste des colonnes à comparer.
void editRegexColumns(const String ®ex_column) override
Méthode permettant d'ajouter une expression régulière permettant de déterminer les colonnes à compare...
void editRegexRows(const String ®ex_row) override
Méthode permettant d'ajouter une expression régulière permettant de déterminer les lignes à comparer.
void isARegexExclusiveColumns(bool is_exclusive) override
Méthode permettant de demander à ce que l'expression régulière exclut des colonnes au lieu d'en inclu...
void clearComparator() override
Méthode permettant de vider les tableaux de comparaison et les expressions régulières....
bool addEpsilonColumn(const String &column_name, Real epsilon) override
Méthode permettant de définir un epsilon pour une colonne donnée. Cet epsilon doit être positif pour ...
static bool isFileExist(const Directory &directory, const String &file)
Méthode statique permettant de vérifier l'existance d'un fichier.
Chaîne de caractères unicode.
TraceMessage error() const
Flot pour un message d'erreur.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
Structure représentant un tableau simple.