[C+GTK]Résultat diff de fonc GTK/DOS
Résolu
Thib42
Messages postés
12
Date d'inscription
Statut
Membre
Dernière intervention
-
Thib42 Messages postés 12 Date d'inscription Statut Membre Dernière intervention -
Thib42 Messages postés 12 Date d'inscription Statut Membre Dernière intervention -
Salut tous le monde !
J'aurais besoin de votre aide sur un problème des plus étrange : je travail sur un programme C effectuant une conversion de format de fichier (en gros lecture d'un fichier source et ecriture de fichier de destination ds un autre format), ce programme fonctionne parfaitement sans utiliser d'interface graphique mais ne fonctionne plus avec l'interface graphique GTK...
Je m'explique : pour faire au plus simple j'ai créé une fonction "int traitementAll (char* nomFichier, GtkWidget* pProgress)" qui s'occupe de réaliser tous les traitements et rend un code indiquant si l'opération s'est bien passée (1) ou un code d'erreur particulier. Le premier paramètre est le nom avec le chemin d'accès au fichier source et le second la référence à un widget "progress bar" permettant de suivre l'avancement du traitement de manière visuel.
Mon problème est le suivant : si j'exécute cette fonction dans un programme entierement DOS (pas de GTK) en ayant bien sur viré le "GtkWidget* pProgress" et j'affiche le resultat, j'obtient toujours ce qu'il faut a savoir 1. Le traitement est bien effectué (j'ai vérifier les données de sorties etc).
Si par contre j'exécute cette meme fonction dans un programme disposant d'une interface graphique GTK (quand on clique sur un bouton) l'un des sous traitement ne fonctionnera pas systématiquement ou presque (renvoie d'un code d'erreur). Et le pire c'est que sur une 10aine d'exécution j'obtiendrais des résultats différents avec parfois des traitement effectués correctement ...
Les deux programmes utilisent bien sur les même fichiers source (sauf celui pr l'interface graph/dos) et sont exécuter au même endroit en utilisant le même fichier source.
J'ai effectuer ces tests sur 2 ordinateurs différents tournant sous XP, même résultats.
Pour infos j'avais déja réalisé un programme de ce type et la transition DOS --> GTK n'avait posé aucun problème
Infos technique :
IDE --> DevC++ 4.9.9.2
Compilateur --> GCC 3.4.2
Glib 2.6.6
Gtk+ 2.6.9
atk 1.9.0
pango 1.8.2
Si vous avez besoin d'autres infos (j'en ai surement oubliées) demandez moi. :-)
Merci !!!
J'aurais besoin de votre aide sur un problème des plus étrange : je travail sur un programme C effectuant une conversion de format de fichier (en gros lecture d'un fichier source et ecriture de fichier de destination ds un autre format), ce programme fonctionne parfaitement sans utiliser d'interface graphique mais ne fonctionne plus avec l'interface graphique GTK...
Je m'explique : pour faire au plus simple j'ai créé une fonction "int traitementAll (char* nomFichier, GtkWidget* pProgress)" qui s'occupe de réaliser tous les traitements et rend un code indiquant si l'opération s'est bien passée (1) ou un code d'erreur particulier. Le premier paramètre est le nom avec le chemin d'accès au fichier source et le second la référence à un widget "progress bar" permettant de suivre l'avancement du traitement de manière visuel.
Mon problème est le suivant : si j'exécute cette fonction dans un programme entierement DOS (pas de GTK) en ayant bien sur viré le "GtkWidget* pProgress" et j'affiche le resultat, j'obtient toujours ce qu'il faut a savoir 1. Le traitement est bien effectué (j'ai vérifier les données de sorties etc).
Si par contre j'exécute cette meme fonction dans un programme disposant d'une interface graphique GTK (quand on clique sur un bouton) l'un des sous traitement ne fonctionnera pas systématiquement ou presque (renvoie d'un code d'erreur). Et le pire c'est que sur une 10aine d'exécution j'obtiendrais des résultats différents avec parfois des traitement effectués correctement ...
Les deux programmes utilisent bien sur les même fichiers source (sauf celui pr l'interface graph/dos) et sont exécuter au même endroit en utilisant le même fichier source.
J'ai effectuer ces tests sur 2 ordinateurs différents tournant sous XP, même résultats.
Pour infos j'avais déja réalisé un programme de ce type et la transition DOS --> GTK n'avait posé aucun problème
Infos technique :
IDE --> DevC++ 4.9.9.2
Compilateur --> GCC 3.4.2
Glib 2.6.6
Gtk+ 2.6.9
atk 1.9.0
pango 1.8.2
Si vous avez besoin d'autres infos (j'en ai surement oubliées) demandez moi. :-)
Merci !!!
A voir également:
- [C+GTK]Résultat diff de fonc GTK/DOS
- Resultat foot - Télécharger - Vie quotidienne
- Lexer resultat - Télécharger - Sport
- Gtk for net - Forum Programmation
- Console dos ✓ - Forum Programmation
- Samia, kevin et jason ont gardé la trace de leurs ventes quotidiennes du mois de juillet 2016. dans la feuille bilan, il manque les résultats de jason. insérez une colonne entre samia et kevin et reportez-y les résultats de jason. quel mot secret apparait en f2 ? - Forum LibreOffice / OpenOffice
2 réponses
Code simplifié :
Graphique :
DOS :
Graphique :
void OnButtonConvertir(GtkWidget *pWidget, gpointer data){ gchar* sUtf8; int res; char mess[256]; res = traitementAll("c:\\blabla\\fichiersource.txt", pApp->pProgress); // pApp->pProgress = var globale switch (res){ case 1: break; case -1: snprintf(mess,256,"Erreur 1\n"); break; case -2: snprintf(mess,256,"Erreur 2"); break; case -3: snprintf(mess,256,"Erreur 3"); break; case -4: snprintf(mess,256,"Erreur 4"); break; case -6: snprintf(mess,256,"Erreur 5"); break; default: snprintf(mess,256,"Erreur pendant le traitement. Code : %d",res); break; } if (res != 1){ sUtf8 = g_locale_to_utf8(mess, -1, NULL, NULL, NULL); pError = gtk_message_dialog_new (GTK_WINDOW(data), GTK_DIALOG_MODAL, GTK_MESSAGE_ERROR, GTK_BUTTONS_OK, sUtf8); /* Affichage de la boite de message */ gtk_dialog_run(GTK_DIALOG(pError)); /* Destruction de la boite de message */ gtk_widget_destroy(pError); } if (res == 1){ sUtf8 = g_locale_to_utf8("Le traitement d'importation a réussi.\nOK pour continuer.", -1, NULL, NULL, NULL); pFini = gtk_message_dialog_new (GTK_WINDOW(data), GTK_DIALOG_MODAL, GTK_MESSAGE_INFO, GTK_BUTTONS_OK, sUtf8); /* Affichage de la boite de message */ gtk_dialog_run(GTK_DIALOG(pFini)); /* Destruction de la boite de message */ gtk_widget_destroy(pFini); } g_free(sUtf8); }
DOS :
int main(int argc, char *argv[]){ int res; res = traitementAll("c:\\blabla\\fichiersource.txt"); switch (res){ case 1: break; case -1: snprintf(mess,256,"Erreur 1\n"); break; case -2: snprintf(mess,256,"Erreur 2"); break; case -3: snprintf(mess,256,"Erreur 3"); break; case -4: snprintf(mess,256,"Erreur 4"); break; case -6: snprintf(mess,256,"Erreur 5"); break; default: snprintf(mess,256,"Erreur pendant le traitement. Code : %d",res); break; } printf("%s\n",mess); return EXIT_SUCCESS; }
Problème résolu, j'ai trouvé la solution !
Voila donc ce que j'ai fait pour ceux qui rencontrerais ce type de problèmes ...
Le problème venais en fait de l'utilisation de la fonction sscanf, qui est très capricieuse ...
J'utilisais cette fonction pour lire ligne par ligne un fichier en identificant 7 valeurs (entiers,chaines et réels) et celle ci fonctionnait correctement en utilisant un programme "DOS" mais posait problème quand lancé par une fonction de l'interface GTK, associée au click sur un bouton : elle renvoyait systematiquement une valeur différente de 7 ...
Je me suis donc arranger pour séparer chacun des champs à identifier dans un buffer et j'ai utiliser le sscanf sur ce buffer (1 valeur à identifier à la fois). Et la miracle ca fonctionne !
Forcement le programme est beaucoup plus lourd (7 appels successif à sscanf au lieu d'un seul) mais au moin ca fonctionne aussi bien sous DOS qu'avec l'interface graphique !
Voila donc ce que j'ai fait pour ceux qui rencontrerais ce type de problèmes ...
Le problème venais en fait de l'utilisation de la fonction sscanf, qui est très capricieuse ...
J'utilisais cette fonction pour lire ligne par ligne un fichier en identificant 7 valeurs (entiers,chaines et réels) et celle ci fonctionnait correctement en utilisant un programme "DOS" mais posait problème quand lancé par une fonction de l'interface GTK, associée au click sur un bouton : elle renvoyait systematiquement une valeur différente de 7 ...
Je me suis donc arranger pour séparer chacun des champs à identifier dans un buffer et j'ai utiliser le sscanf sur ce buffer (1 valeur à identifier à la fois). Et la miracle ca fonctionne !
Forcement le programme est beaucoup plus lourd (7 appels successif à sscanf au lieu d'un seul) mais au moin ca fonctionne aussi bien sous DOS qu'avec l'interface graphique !