mon projet est fair un t-chat (c quand même plus styler que chat) la partie de lecture et celle d'écriture son déjà crée je fais donc celle de notification mon fichier est modifier par tout les utilisateur.le ficher est encrypter est lisible uniquement sur les t-chat donc vu que on ne peut que rajouter des ligne ou tout supprimer (super utilisateur seulement) donc le ficher ne peut pas changer sans un changement de taille.
mon scripte bug au niveaux de la ligne 31 a 43 mais je ne comprend pas pourquoi l'erreur est que mon ifstream fichier2("C:/nanoc/test.txt");
ne re-teste pas la taille du ficher a chaque tour de boucle
voici mon code:
merci d'avance
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47 #include <iostream> #include <fstream> #include <windows.h> using namespace std; int main() { int taille_final; ifstream fichier("C:/nanoc/test.txt"); //On ouvre le fichier fichier.seekg(0, ios::end); //On se déplace à la fin du fichier int taille; taille = fichier.tellg(); //On récupére la position qui correspond donc a la taille du fichier cout << "Taille du fichier au debut: " << taille << " octets." << endl; fichier.close(); string const nomFichier("C:/nanoc/test.txt"); ofstream monFlux(nomFichier.c_str(), ios::app); if(monFlux) { monFlux << "Bonjour, je suis une phrase écrite dans un fichier." << endl; } else { cout << "ERREUR: Impossible d'ouvrir le fichier." << endl; } do { ifstream fichier2("C:/nanoc/test.txt"); //On ouvre le fichier fichier2.seekg(0, ios::end); //On se déplace à la fin du fichier int taille_final; taille_final = fichier2.tellg();//On récupére la position qui correspond donc a la taille du fichier ! cout << "Taille du fichier actuellemet: " << taille << " octets." << endl; std::flush(std::cout); Sleep(1000); }while (taille != taille_final );//on tourne jusque ce soi diferant cout <<"le ficher a ete modifier"<<endl; cout << "le nouveaux message est :"<< endl; return 0; }
Partager