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 :

SAFEARRAY dll en c utilisée en vba


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2008
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2008
    Messages : 97
    Par défaut SAFEARRAY dll en c utilisée en vba
    Bonjour à tous,

    J'aimerais utiliser une dll écrite en c dans du vba.
    J'ai parcouru ce tuto:
    http://rp.developpez.com/vb/tutoriels/dll/

    mais je n'arrive pas à appliquer cette histoire de SAFEARRAY et je ne suis même pas sur qu'il faille l'utiliser...

    le truc c'est que j'ai une fonction en c qui doit recevoir une structure contenant un tableau dynamique de chaine de caractères.

    en c j'ai donc:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    typedef struct Stops Stops;
    struct Stops{
        char stopId[7];
        size_t numberOfPicturesPath;
        char** picturesPath;
    };
     
    int __stdcall TestStruct(Stops* stopList);
    où la fonction TestStruct ajoute des chaines dans picturesPath et chaque ajout incrémente numberOfPicturesPath...

    et en vba j'ai donc écrit ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Private Declare Function TestStruct Lib "Machin.dll" (ByRef stopList As Stops) As Long
     
    Type Stops
        stopId As String * 7
        numberOfPictures As Long
        pictures() As String
    End Type
     
    (...)
    Private Sub TestMachin()
      Dim stopList As Stops
      Dim result As Long
      result = TestStruct(stopList)
    (...)
    Tel quel, le code s'exécute jusqu'au return de la fonction TestStruct dans laquelle stopList se remplit bien comme je veux mais une foi le return fait, access se gaufre complètement (fermeture + demande d'envois d'un rapport d'erreur...)

    que dois-je faire?

    j'imagine un truc du genre réécrire la structure du genre?:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    typedef struct Stops Stops;
    struct Stops{
        char stopId[7];
        size_t numberOfPicturesPath; //ceci deviendrait inutile?
        SAFEARRAY *picturesPath;
    };
    mais alors il faut réécrire toutes les fonctions utilisant la structure?

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2008
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2008
    Messages : 97
    Par défaut
    J'ai testé, j'ai avancé mais j'ai un problème.

    Je l'ai posté sur le forum vba, mais vu que ca concerne aussi le c, je demande aussi à la communauté C.

    donc ma dll devait à la base retourner un tableau de structures contenant un tableau de char*...

    J'ai déclaré cette structure comme ceci en VBA:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Type Stops
        stopId As String
        numberOfPictures As Long
        pictures() As String
    End Type
    la fonction c est déclarée en VBA comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Private Declare Function GetSafePictureFiles Lib "MaDLL.dll" (ByRef stopList() As Stops, ByRef size As Long) As Long
    Dans la dll le prototype de la fonction est comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int __stdcall GetSafePictureFiles(SAFEARRAY** safeStopList, size_t* numberOfStop);
    Et la structure est comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    typedef struct SafeStops SafeStops;
    struct SafeStops{
        BSTR stopId;
        size_t numberOfPictures;
        SAFEARRAY* pictures;
    };
    en VBA j'appelle la fonction comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Test()
      Dim stopList() As Stops
      Dim numberOfStops As Long
     
    On Error GoTo Catch
      ReDim stopList(1)
      result = GetSafePictureFiles(stopList, numberOfStops)
    ...
    Une foi la fonction appelée, le tableau stopList est remplis bizarrement... ce qui fait planter access.

    Le premier élément et tous les éléments d'indice multiples de 3 sont corrects mais pas les autres...
    De plus, tous les x derniers éléments du tableau sont vide

    donc pour mes 5489 cellules:
    stopList(0).stopId : Ok
    stopList(1).stopId : Contenu rien avoir
    stopList(2).stopId : fait planter access
    stopList(3).stopId : Ok
    stopList(4).stopId : Contenu rien avoir
    stopList(5).stopId : fait planter access
    ...
    stopList(4107).stopId : Ok
    stopList(4108).stopId : Contenu rien avoir
    stopList(4109).stopId : fait planter access
    ...
    stopList(4116).stopId : Ok
    stopList(4117).stopId : vide
    stopList(4118).stopId : vide
    stopList(4119).stopId : vide
    stopList(4120).stopId : vide
    ...
    stopList(5488).stopId : vide



    Or, quand j'affiche le contenu de mon safearray en c, tous les éléments sont justes...

    A mon avis, j'ai mal déclarer quelque chose quelque part... j'avoue que je ne vois pas dutout ce qui se passe.

    Quelqu'un aurait il une idée?

  3. #3
    Membre éprouvé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2008
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2008
    Messages : 97
    Par défaut
    Avec un tableau de structures:

    Quand on fait un:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SafeArrayCreateVector(VT_VARIANT, 0, numberOfRow);
    est ce bien VT_VARIANT qu'il faut mettre comme type?

  4. #4
    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
    J'ai bien peur que tu doives utiliser des fonctions plus spécifiques pour créer le SAFEARRAY. Des fonctions qui permettent d'utiliser le flag FADF_RECORD et le champ cbElements.

    Edit: Voilà qui est intéressant. Par contre, IRecordInfo a l'air compliquée. Si tu utilises MIDL, tu n'auras pas besoin de l'implémenter, mais sinon...
    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. DLL créée par delphi à utiliser dans VBA EXCEL
    Par AlfredKr dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 19/03/2015, 08h29
  2. Création DLL pour utilisation sur VBA
    Par Fbartolo dans le forum C++Builder
    Réponses: 1
    Dernier message: 21/11/2005, 20h44
  3. Réponses: 10
    Dernier message: 10/11/2005, 16h04
  4. Pb avec utilisation UPDATEsous VBA
    Par frevale dans le forum Access
    Réponses: 7
    Dernier message: 07/11/2005, 23h56

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