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

Visual C++ Discussion :

Type VARIANT depuis vba


Sujet :

Visual C++

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut Type VARIANT depuis vba
    bonjour,
    j'ai une dll c++ qui reçcoit depuis vba un VARIANT (tableau(2,n) hetérogène:vba.Date et double )
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    #include <wtypes.h> // pour DATE
    #include <oaidl.h> // pour VARIANT
     
    DllExport double __stdcall MyFunction(VARIANT * MyArray)
    {
        std::map<DATE, double> MyMap;
     
        for(int cpt=0; cpt<n;cpt++)
        {
             // comment vider MyArray dans MyMap??
        }
     
    }
    y'a-t-il des cast à faire?
    merci d'avance

  2. #2
    Membre chevronné
    Inscrit en
    Août 2004
    Messages
    556
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 556
    Par défaut
    Des cast, certainement.

    Le type Variant de VB et de C++ sont les mêmes, tu peux les passer l'un à l'autre et les utiliser directement. Il faut que tu fasses le cast au type correct une fois que tu as récupéré le type.

    Par contre je comprend pas ce que tu veux dire avec balancer ton Variant dans un map ? oO

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut
    comment acceder aux élements du tableau Variant..?

  4. #4
    Membre chevronné
    Inscrit en
    Août 2004
    Messages
    556
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 556
    Par défaut
    Ah parce que VARIANT *, c'est un pointeur vers un tableau ? (je savais pas qu'on pouvait faire passer des pointeurs en VB d'ailleurs).

    Tu dois alors aussi faire passer la taille du tableau.

    Après, tu récupères chaque élément en déréférencant le tableau avec l' opérateur [].

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Attends, si c'est un vrai tableau VB, ce n'est pas un simple pointeur, et le type du paramètre ne devrait pas être VARIANT mais SAFEARRAY*.

    En fait, il faut surtout voir comment la fonction est déclarée en VB et comment elle est appelée...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Attends, si c'est un vrai tableau VB, ce n'est pas un simple pointeur, et le type du paramètre ne devrait pas être VARIANT mais SAFEARRAY*.

    En fait, il faut surtout voir comment la fonction est déclarée en VB et comment elle est appelée...
    effectivement, SAFEARRAY semble mieux adaptée

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Public Declare Function Myfunction Lib "MyLibrary.dll" (ByRef Myarray() As Variant) As Double
    //puis
    Sub Test()
       Dim MyArray(50,2) as Variant
       Dim res As Double
       //remplissage du tableau
     
       res = Myfunction (MyArray)
    End Sub
    du coup

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    extern "C" __declspec(dllexport) double __stdcall MyFunction(SAFEARRAY ** MyArray)
    {
        // ???
    }
    ça convient??

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Ça m'en a tout l'air: Il s'agit d'un SAFEARRAY de VARIANT (donc, pour le C et le C++, un SAFEARRAY*) passé par référence (d'où la seconde astérisque).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Ça m'en a tout l'air: Il s'agit d'un SAFEARRAY de VARIANT (donc, pour le C et le C++, un SAFEARRAY*) passé par référence (d'où la seconde astérisque).
    je sait pas encore comment acceder aux élements du SAFEARRAY.
    je cherche ...

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Il y a des fonctions pour ça, du genre SafeArrayGetElement().
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  10. #10
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Il y a des fonctions pour ça, du genre SafeArrayGetElement().
    oui je viens de voir..
    sinon une autre question: je ne suis pas sure (dans le vb) du passage en paramètre du tableau (juste le nom). En fait pour un tableau unidimentionnel, je passait le premier élément (MyArray(0))...est-ce toujours le cas??

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Passer le premier élément par référence est un raccourci (que je ne recommande pas) pour passer un tableau à une fonction C/C++ sans avoir à s'occuper du SAFEARRAY.

    Passer le tableau lui-même passe systématiquement un SAFEARRAY* (ou un SAFEARRAY** si le tableau lui-même est passé par référence).

    En clair, dans un cas, tu passes vraiment le tableau lui-même, dans l'autre cas tu triches.
    Et je déconseille vivement d'essayer de tricher avec un tableau multidimensionnel.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  12. #12
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut
    merci
    je teste tous ça et vous tiens au courant

  13. #13
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 46
    Par défaut
    Je n'arrive toujours pas à savoir comment accéder aux élément de tableau.
    le problème est qu'il y a deux dimensions et de types différents

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    extern "C" __declspec(dllexport) double __stdcall MyFunction(SAFEARRAY ** MyArray)
    {
        std::map<DATE, double> MyMap;
     
        for(int cpt=0; cpt<n;cpt++)
        {
             // comment vider MyArray dans MyMap??
        }
     
    }

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    En fait, il n'y a qu'un seul type: VARIANT. Ce sont les variants en question qui contiennent deux types différents.

    Si tu veux l'élément (49, 1) du tableau, il te faudra un code de ce 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
    extern "C" __declspec(dllexport) double __stdcall MyFunction(SAFEARRAY ** refArray)
    {
    	VARIANT var;
    	long indices[2];
    	HRESULT hr;
     
    	VariantInit(&var);
     
    	indices[0] = 49;
    	indices[1] = 1;
     
    	hr = SafeArrayGetElement(*MyArray, indices, &var);
     
    	/*Travail sur le variant récupéré*/
    	/* ... */
     
    	VariantClear(&var);
    }
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Problème avec le type variant
    Par fabrice001 dans le forum C++Builder
    Réponses: 4
    Dernier message: 21/12/2005, 10h18
  2. locate - type variant incorrect
    Par lol_adele dans le forum Bases de données
    Réponses: 8
    Dernier message: 24/10/2005, 15h54
  3. Transaction depuis VBA--
    Par Fritzoune dans le forum Access
    Réponses: 1
    Dernier message: 16/09/2005, 16h05
  4. [D2005] Type Variant en .NET
    Par Harry dans le forum Delphi .NET
    Réponses: 5
    Dernier message: 28/04/2005, 18h00
  5. Convertion de type VARIANT à type CString
    Par j_grue dans le forum MFC
    Réponses: 2
    Dernier message: 07/11/2002, 14h18

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