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

Windows Discussion :

Probleme de pointer without of cast


Sujet :

Windows

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 68
    Points : 56
    Points
    56
    Par défaut Probleme de pointer without of cast
    COucou
    Bon il est tard, je suis fatigué... Arf... Non, j'arrete de chercher des excuses...
    Je suis nul ! Mais bon, je suis motivé

    Alors voici ma p'tite fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    EXPORT const char* get_name(char lecteur[5])
    {
             DWORD SerialNumber;
             char VolumeName;
             char SysName;
             GetVolumeInformation(lecteur,&VolumeName,12,&SerialNumber,NULL,NULL,&SysName,16); 
             return VolumeName; 
    }
    Mais lors de la compile, j'ai l'erreur :
    return make pointer from integer without a cast.

    Je suppose qu'il s'agit d'un probleme de char* ou autre p'tit truc con comme ça, mais malgré tous mes essais, impossible de renvoyer la variable VolumeName.
    Pourtant, si je renvoi une chaine de caractere comme "TEST" à la place de VolumeName, ben ça marche...

    Un p'tit coup de pouce (encor oui ) serait encor une fois super sympa

  2. #2
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 947
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 947
    Points : 5 660
    Points
    5 660
    Par défaut
    Ha,

    Ta fonction doit renvoyer un char *, et tu cherches à renvoyer un char

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 68
    Points : 56
    Points
    56
    Par défaut
    Oui, mais si je met :
    char* VolumeName;

    J'ai aussi un probleme lors de la compilation...


    Quand je fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    EXPORT const char* get_name(char lecteur[5])
    {
             DWORD SerialNumber;
             char VolumeName;
             char SysName;
             GetVolumeInformation(lecteur,&VolumeName,12,&SerialNumber,NULL,NULL,&SysName,16); 
             return "VolumeName"; 
    }
    ça me renvoi bien la chaine de caractere VolumeName.
    Mais si je veux plutot renvoyer le contenu de cette variable, alors là ça marche plus...

  4. #4
    Membre éclairé Avatar de stephl
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2007
    Messages
    643
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2007
    Messages : 643
    Points : 771
    Points
    771
    Par défaut
    Avez-vous regardé la doc de GetVolumeInformation()? Le second paramètre doit être un char * et c'est bien ce que vous fournissez dans votre appel (&VolumeName). Seulement, VolumeName est un char donc c'est un buffer ne pouvant contenir qu'un seul caractère. Etant donné qu'en C les chaînes se terminent par '\0', vous ne pourrez pas ranger grand chose dans VolumeName. D'ailleurs, je me demande d'où vous sortez votre troisième paramètre (12) qui est censé être la longueur du buffer passé en second paramètre?!?! Même chose pour SysName. Au final, il faut donc faire quelque chose du genre:
    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
    #include <windows.h>
    #include <stdio.h>
    
    
    char *get_name(char lecteur[5],char *VolumeName,int volumenamelength)
     {
     DWORD SerialNumber;
    
     GetVolumeInformation(lecteur,VolumeName,volumenamelength,&SerialNumber,NULL,
     NULL,NULL,0); 
     return VolumeName; 
     }
    
    
    int main(void)
     {
     char s[256];
     
     printf("%s\n",get_name("C:\\",s,sizeof s));
     return 0;
     }

  5. #5
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 379
    Points : 41 573
    Points
    41 573
    Par défaut
    Le premier paramètre devrait être un pointeur const.

    De plus, il faudrait utiliser des TCHAR plutôt que des char, mais bon...

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 68
    Points : 56
    Points
    56
    Par défaut
    Super !
    Merci bcp
    Et merci egalement pour votre patience en plus de toutes ces gentilles explications.

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 29/05/2014, 00h29
  2. assignment makes integer from pointer without a cast
    Par MaybeMaybe dans le forum Débuter
    Réponses: 6
    Dernier message: 05/01/2014, 20h50
  3. Réponses: 2
    Dernier message: 02/04/2010, 12h44
  4. Réponses: 3
    Dernier message: 19/03/2009, 10h56
  5. Réponses: 25
    Dernier message: 04/10/2006, 00h33

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