IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

 C Discussion :

Probleme de Warnings assignment makes pointer from integer without a cast


Sujet :

C

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 34
    Points : 31
    Points
    31
    Par défaut Probleme de Warnings assignment makes pointer from integer without a cast
    Bonsoir,
    J'ai un petit soucis avec de warning avec mon code :



    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
     
    char    **directory(char *const envp[])
    {
      struct s_var  flop;
      char          *str;
      char          **res;
     
      flop.i = 0;
      flop.o = 0;
      flop.j = 0;
      flop.b = 5;
      str = xmalloc(sizeof(*str) * 50);
      res = xmalloc(sizeof(*res) * 100);
      while (flop.j < 50)
        res[flop.j++] = xmalloc(sizeof(**res) * 30);
      while (envp[flop.i])
        {
          if (envp[flop.i][flop.o] == 'P')
            if (envp[flop.i][flop.o + 1] == 'A')
              if (envp[flop.i][flop.o + 2] == 'T')
                {
                  while (envp[flop.i][flop.b] != '\0')
                    str[flop.o++] = envp[flop.i][flop.b++];
                  res = my_str_to_wordtab2(str);
                  return (res);
                }
          flop.i++;
        }
    }
    et la console me répond cela à la compilation
    ligne 12:7: warning: assignment makes pointer from integer without a cast
    ligne 13:7: warning: assignment makes pointer from integer without a cast
    ligne 15:19: warning: assignment makes pointer from integer without a cast
    ligne 24:13: warning: assignment makes pointer from integer without a cast

    Pour informations j'ai essayé de mettre la fonction malloc a la place de xmalloc (qui vérifie les valeurs de retour). La fonction my_str_to_wordtab est un double tableau également donc je vois vraiment pas pourquoi la console me renvois tout ces warnings j'ai du me tromper dans les mallocs mais je vois vraiment pas ou...
    Si vous pouvez m'éclairer sur ce probleme...
    Merci d'avance
    Cdt

  2. #2
    Membre éclairé
    Avatar de Pouet_forever
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    671
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 671
    Points : 842
    Points
    842
    Par défaut
    Tu dois sûrement compiler en C++ ! Essayes de configurer ton compilateur pour compiler en C.
    Plus tu pédales moins fort, moins t'avances plus vite.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 34
    Points : 31
    Points
    31
    Par défaut
    Je suis sous Fedora 14 j'ai bien vérifié, je compile toujours de cette manière et je n'ai jamais eu un soucis de ce genre mon Make file est toujours le même....

  4. #4
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Salut

    si xmalloc() n'est pas déclarée (et je n'ai pas vu de #include qui laisserait penser le contraire), alors le compilo la prépositionne en int. Ensuite ben il te dit qu'il n'aime pas copier un int dans un pointeur...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  5. #5
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 369
    Points : 23 623
    Points
    23 623
    Par défaut
    Il faut lire les messages d'erreur si tu veux les comprendre :

    warning: assignment makes pointer from integer without a cast

    ce qui signifie :

    Attention : l'assignation fabrique un pointeur à partir d'un entier sans transtypage.

    Ça veut dire que le compilateur estime que xmalloc() renvoie un entier, ce qui peut avoir deux causes :

    — Soit xmalloc() est réellement faite pour renvoyer un entier (il y a des prototypes correspondants sur le Net, sous AIX) ;
    — Soit tu as oublié d'inclure le fichier *.h qui définit la fonction. Comme il n'en avait pas connaissance jusque là et en l'absence de toute autre information, le compilateur considère que ta fonction est par défaut de type « int fnct (void) ». Cela dit, tu devrais avoir un message d'avertissement préalable pour te le dire, pour peu que ton compilo soit correctement configuré.

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 34
    Points : 31
    Points
    31
    Par défaut
    Ah en effet ca m'a régler 3 warning mais pour le res = my_str_to_wordtab2(str); il s'agit du meme probleme?

  7. #7
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 369
    Points : 23 623
    Points
    23 623
    Par défaut
    Citation Envoyé par arrakis42 Voir le message
    Ah en effet ca m'a régler 3 warning mais pour le res = my_str_to_wordtab2(str); il s'agit du meme probleme?
    Probablement, oui.

  8. #8
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 34
    Points : 31
    Points
    31
    Par défaut
    Par contre je ne comprend pas ca marche si je met malloc, mais par contre avec xmalloc ca laisse le warning alors que jai inclu un header juste avant cest assez bizarre
    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
     
     
    #ifndef __STRUCT_H__
    #define __STRUCT_H__
    #include <sys/types.h>
    #include <dirent.h>
    #include <signal.h>
     
     
    struct s_var
    {
      int   i;
      int   u;
      int   a;
      int   s;
      int   j;
      int   ret;
      int   pid;
      int   b;
      int   o;
      int   h;
      int   fd;
      int   statut;
    };
     
    int     xmalloc(int size);
    void    xfree(void *ptr);
    void    free_double_tab(char *str);
    int     prompt(char **argv, char *const envp[]);
    char    **my_str_to_wordtab(char *str);
    char    **my_str_to_wordtab2(char *str);
    void    signaux();
    char    *my_strcat(char *str, char *str2);
     
    #endif
    J'ai inclus ceci a chaque fonctions mais les warnings restent quand meme....

  9. #9
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par arrakis42 Voir le message
    Par contre je ne comprend pas ca marche si je met malloc, mais par contre avec xmalloc ca laisse le warning alors que jai inclu un header juste avant cest assez bizarre
    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
    #ifndef __STRUCT_H__
    #define __STRUCT_H__
    #include <sys/types.h>
    #include <dirent.h>
    #include <signal.h>
    
    
    int     xmalloc(int size);
    void    xfree(void *ptr);
    void    free_double_tab(char *str);
    int     prompt(char **argv, char *const envp[]);
    char    **my_str_to_wordtab(char *str);
    char    **my_str_to_wordtab2(char *str);
    void    signaux();
    char    *my_strcat(char *str, char *str2);
    
    #endif
    J'ai inclus ceci a chaque fonctions mais les warnings restent quand meme....
    Tu lis nos posts ou tu ne fais que les survoler ???
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  10. #10
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    34
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2011
    Messages : 34
    Points : 31
    Points
    31
    Par défaut
    Oups ben désolé du coup ca venait de la tout les warnings sont partis. Merci de m'avoir aidé

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. assignment makes pointer from integer without a cast
    Par morpheusmg dans le forum Débuter
    Réponses: 4
    Dernier message: 27/11/2011, 17h31
  2. Réponses: 5
    Dernier message: 17/02/2011, 20h19
  3. Réponses: 2
    Dernier message: 12/11/2010, 12h11
  4. Réponses: 3
    Dernier message: 08/09/2009, 09h40
  5. Réponses: 6
    Dernier message: 11/05/2006, 22h08

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo