[C+GTK]Résultat diff de fonc GTK/DOS

Résolu/Fermé
Thib42 Messages postés 12 Date d'inscription mardi 2 mai 2006 Statut Membre Dernière intervention 31 juillet 2006 - 13 juil. 2006 à 12:35
Thib42 Messages postés 12 Date d'inscription mardi 2 mai 2006 Statut Membre Dernière intervention 31 juillet 2006 - 17 juil. 2006 à 16:44
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 !!!
A voir également:

2 réponses

Thib42 Messages postés 12 Date d'inscription mardi 2 mai 2006 Statut Membre Dernière intervention 31 juillet 2006 1
13 juil. 2006 à 13:21
Code simplifié :
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;
}
0
Thib42 Messages postés 12 Date d'inscription mardi 2 mai 2006 Statut Membre Dernière intervention 31 juillet 2006 1
17 juil. 2006 à 16:44
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 !
0