TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
LecFicDistribue.cpp
1/****************************************************************************
2* Copyright (c) 2024, CEA
3* All rights reserved.
4*
5* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
6* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
7* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
8* 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
9*
10* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
11* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
12* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
13*
14*****************************************************************************/
15
16#include <LecFicDistribue.h>
17#include <communications.h>
18#include <Nom.h>
19
20Implemente_instanciable_sans_constructeur_ni_destructeur(LecFicDistribue,"LecFicDistribue",EFichier);
21
23{
24 throw;
25}
26
28{
29 throw;
30}
31
32LecFicDistribue::LecFicDistribue(int)
33{
34 bin_=0;
35}
36LecFicDistribue::LecFicDistribue():EFichier()
37{}
38LecFicDistribue::~LecFicDistribue()
39{
41}
42
43/*! @brief Constructeur Ouvre le fichier avec les parametres mode et prot donnes
44 *
45 * Ces parametres sont les parametres de la methode open standard
46 *
47 * @param (const char* name) nom du fichier
48 * @param (int mode) parametre passe a open
49 * @param (int prot) parametre passe a open
50 */
51LecFicDistribue::LecFicDistribue(const char* name, IOS_OPEN_MODE mode)
52{
53 LecFicDistribue::ouvrir(name, mode);
54}
55
56
57/*! @brief Ouvre le fichier avec les parametres mode et prot donnes Ces parametres sont les parametres de la methode open standard
58 *
59 * @param (const char* name) nom du fichier
60 * @param (int mode) parametre passe a open
61 * @param (int prot) parametre passe a open
62 * @return (Entree&) *this
63 */
64int LecFicDistribue::ouvrir(const char* name, IOS_OPEN_MODE mode)
65{
66 Nom nom_fic(name);
68 nom_fic=nom_fic.nom_me(Process::me());
69
70#ifdef FILESYSTEM_NON_GLOBAL
71 Nom localisation;
73 localisation = pwd();
74 envoyer_broadcast(localisation, 0);
75
76 nom_fic = localisation + "/" + nom_fic;
77#endif
78
79 if (!EFichier::ouvrir((const char*)nom_fic,mode))
80 {
81 Cerr << "File " << nom_fic << " not found or could not be opened." << finl;
82 return 0;
83 }
84 else
85 {
86 Process::Journal() << "File " << nom_fic << " is opened." << finl;
87 return 1;
88 }
89}
90
bool bin_
Is this a binary flux?
Definition AbstractIO.h:50
Fichier en lecture Cette classe est a la classe C++ ifstream ce que la classe Entree est a la.
Definition EFichier.h:29
virtual int ouvrir(const char *name, IOS_OPEN_MODE mode=ios::in)
Class defining operators and methods for all reading operation in an input flow (file,...
Definition Entree.h:42
Cette classe implemente les operateurs et les methodes virtuelles de la classe EFichier de la facon s...
int ouvrir(const char *name, IOS_OPEN_MODE mode=ios::in) override
Ouvre le fichier avec les parametres mode et prot donnes Ces parametres sont les parametres de la met...
class Nom Une chaine de caractere pour nommer les objets de TRUST
Definition Nom.h:31
Nom nom_me(int, const char *prefix=0, int without_padding=0) const
Insere _prefix000n (n=me() ou nproc()) dans un nom de fichier (par ex:toto.
Definition Nom.cpp:387
virtual Entree & readOn(Entree &)
Lecture d'un Objet_U sur un flot d'entree Methode a surcharger.
Definition Objet_U.cpp:293
virtual Sortie & printOn(Sortie &) const
Ecriture de l'objet sur un flot de sortie Methode a surcharger.
Definition Objet_U.cpp:282
static bool is_parallel()
Definition Process.cpp:110
static Sortie & Journal(int message_level=0)
Renvoie un objet statique de type Sortie qui sert de journal d'evenements.
Definition Process.cpp:588
static int me()
renvoie mon rang dans le groupe de communication courant.
Definition Process.cpp:125
static int je_suis_maitre()
renvoie 1 si on est sur le processeur maitre du groupe courant (c'est a dire me() == 0),...
Definition Process.cpp:86
Classe de base des flux de sortie.
Definition Sortie.h:52