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

EDI Delphi Discussion :

Argument IStream dans la définition d'objet COM


Sujet :

EDI Delphi

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 5
    Points : 7
    Points
    7
    Par défaut Argument IStream dans la définition d'objet COM
    Bonjour,

    Comment est-il possible, dans l'éditeur d'une bibliothèque de types de Delphi,

    de définir un paramètre de type IStream pour une méthode d'un objet COM ?



    Ce type n'est pas proposé par Delphi alors qu'il s'agit d'une interface de base de Windows et qu'il n'y a pas de librairie particulière à utiliser pour disposer de ce type.

    Cordialement.

  2. #2
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 459
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 459
    Points : 24 873
    Points
    24 873
    Par défaut
    Tu voudrais hériter de IStream ou juste l'utiliser en paramètre d'une méthode ?

    Si héritage
    La ComboBox n'est pas exhaustive, IUnknown ou ton propre type IStreamDeMonProjet
    Avec Supports, tu pourras déterminer si l'objet échangé fourni une implementation de IStream même si déclaré IUnknown

    Tente aussi de modifier directement le MIDL, tente de remplacer par IStream mais il me semble que c'est galère !

    Si juste méthode,
    La Combox n'est pas tout à faire limité aux items de la liste, tu peux saisir manuellement des types, en fait tu peux ajouter des pointeurs !
    La combo est très capricieuse, tu dois mettre un type existant dans la liste ou un pointeur d'un type existant dans la liste, rien de plus

    Mais IStream même si tu pouvais le déclarer dans la ComboBox, le problème c'est qu'il ne sera pas ce que c'est dans le _TLB.pas car on peut pas modifier ce fichier généré pour y ajouter un uses (sauf si il inclu ActiveX qui déclare IStream), donc retour au IUnknown

    Pense que tu dois mettre IUnknown * pour un paramètre en entrée et IUnknown ** pour un paramètre de sortie (ou retour de fonction safecall)
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 5
    Points : 7
    Points
    7
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    Tu voudrais hériter de IStream ou juste l'utiliser en paramètre d'une méthode ?

    Si héritage
    La ComboBox n'est pas exhaustive, IUnknown ou ton propre type IStreamDeMonProjet
    Avec Supports, tu pourras déterminer si l'objet échangé fourni une implementation de IStream même si déclaré IUnknown

    Tente aussi de modifier directement le MIDL, tente de remplacer par IStream mais il me semble que c'est galère !

    Si juste méthode,
    La Combox n'est pas limité aux items de la liste, tu peux saisir manuellement des types non ? tu peux mettre ce que tu veux dedans ce que tu veux même si la combo est très capricieuse !
    Mais IStream, le problème c'est qu'il ne sera pas ce que c'est dans le _TLB.pas, donc retour au IUnknown

    Pense que tu dois mettre IUnknown * pour un paramètre en entrée et IUnknown ** pour un paramètre de sortie (ou retour de fonction safecall)
    Merci,

    Je désire uniquement utiliser le type IStream pour un des arguments des méthodes présentées par mon objet COM. Il m'est inutile de faire connaître aux utlisateurs la structure réelle du flux que je crée.

    Il est possible de saisir le texte "IStream* " dans la combobox de l'éditeur de type mais Delphi ne le conserve à la fin de la saisie car ce type est inconnu de l'éditeur.

    Bien sûr, je sais pouvoir utiliser le type IUnknown mais il ne permet pas à un utilisateur de mon objet COM de connaître le type utile du paramètre qu'il reçoit.

    Je considère que l'interface COM que je définis, doit être la plus claire/explicite possible. C'est pourquoi je désire disposer de tous les types d'interface basiques de Windows, en particulier tous ceux définis dans Ole32.dll.

  4. #4
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 459
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 459
    Points : 24 873
    Points
    24 873
    Par défaut
    Tu devrais regarder les contrôles ActiveX de plus près !
    Par défaut, un TActiveXControl servant de base à l'implémentation d'un objet ActiveX supporte IPersistStreamInit (et donc IPersistStream) ainsi que IPersistStorage
    Tu devrais voir si tu dois ne pas exploiter cela au lieu d'utiliser directement des IStream, semble qu'il y a des bcp de choses prévues (mais tordues comme toujours en MS)

    Sinon, rien ne t'empeche de faire ton propre IStreamLozac, avec juste Read et Write, derrière tu hérite TOleStream pour son implémentation, en interne, tu pourrais l'utiliser en IStream, si ça te fait plaisir, mais l'utilisateur de ton appli lui devra utiliser un IStreamLozac

    Tu as pensé au SafeArray, c'est le type tableau nativement géré par VB lors d'une utilisation entre OCX !

    Regarde sur Visual Studio (C++ ou VB), si il propose IStream dans son éditeur de MIDL (je ne ne connais absolument pas), si cela se trouve, IStream ne peut-être pas utilisable en MIDL et tu te fatigue pour rien !
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  5. #5
    Expert confirmé

    Profil pro
    Leader Technique
    Inscrit en
    Juin 2005
    Messages
    1 756
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Leader Technique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 756
    Points : 4 170
    Points
    4 170
    Par défaut
    Je considère que l'interface COM que je définis, doit être la plus claire/explicite possible. C'est pourquoi je désire disposer de tous les types d'interface basiques de Windows, en particulier tous ceux définis dans Ole32.dll.
    C'est un très bon principe. Le problème c'est que tu ne peux voir dans l'éditeur de la TLB que des éléments qui sont eux même publiés dans une bibliothèque de types.
    A priori, l'interface IStream est spécifiée par Microsoft mais n'a pas été publiée dans la TLB pour autant, ce qui fait que tu ne peux pas la référencer dans une bibliothèque de types.

  6. #6
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2006
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 5
    Points : 7
    Points
    7
    Par défaut
    Citation Envoyé par Franck SORIANO Voir le message
    C'est un très bon principe. Le problème c'est que tu ne peux voir dans l'éditeur de la TLB que des éléments qui sont eux même publiés dans une bibliothèque de types.
    A priori, l'interface IStream est spécifiée par Microsoft mais n'a pas été publiée dans la TLB pour autant, ce qui fait que tu ne peux pas la référencer dans une bibliothèque de types.
    Merci pour le commentaire et la réponse.

    Cette réponse n'est pas celle que j'espérais mais elle a l'énorme avantage d'être précise, claire et argumentée.
    Je vais donc me tourner une autre solution.

  7. #7
    Expert éminent sénior

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Points : 10 154
    Points
    10 154
    Par défaut
    IStream existe dans Delphi. Je crois même qu'elle est déclarée dans Classes. As-tu seulement googlé "delphi istream" ?
    sjrd, ancien rédacteur/modérateur Delphi.
    Auteur de Scala.js, le compilateur de Scala vers JavaScript, et directeur technique du Scala Center à l'EPFL.
    Découvrez Mes tutoriels.

  8. #8
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 459
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 459
    Points : 24 873
    Points
    24 873
    Par défaut
    IStream existe dans ActiveX comme je l'ai dit dans ma 1ère réponse du 17 Aout 2011 - 11h11

    Mais il est impossible de l'ajouter dans l'editeur MIDL donc impossible de l'utiliser comme type directement comme l'a parfaitement expliquer Franck SORIANO, IStream est déclaré dans Ole32.dll mais le stdole2.tlb que l'on utilise pour importer les types dans notre propre bibliothèque ne publie pas IStream
    Soit il faut trouver un TLB qui fourni IStream soit se résoudre à IUnknown

    Sinon, il semble que IStream est conçu pour être utilisé pour la sérialisation d'un ActiveX via IPersistStream en tout cas, c'est comme cela que fonctionne Word et Excel. On peut même penser que Microsoft n'a pas conçu cette interface pour d'autres utilisations que la leur !

    Si tu développe directement un objet ActiveX héritant de TActiveXControl, tu bénéficierait naturellement de IPersistStream et de son implementation par défaut mais tu peux faire un override sur LoadFromStream et SaveToStream
    au besoin !

    le soucis de TActiveXControl, c'est que c'est lourd, c'est un control visuel comme le TButton ou le TTreeView !

    Je ne l'ai fait qu'une seule fois, pour exporter le TTreeView dans une version de Navision qui n'avait pas ce contrôle, je n'ai fait que debugger cet ActiveX pour un pote (il n'avait plus de dev delphi chez son employeur)
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 17/04/2009, 17h56
  2. Réponses: 18
    Dernier message: 21/02/2007, 09h44
  3. [COM] Gestion d'events contenus dans un objet COM
    Par Marmottoc dans le forum Delphi
    Réponses: 1
    Dernier message: 19/05/2006, 14h43
  4. [POO] débutante dans les objets COM
    Par SandraG dans le forum Langage
    Réponses: 11
    Dernier message: 16/03/2006, 12h03
  5. [Définition] Objet COM
    Par Etanne dans le forum Windows
    Réponses: 4
    Dernier message: 19/08/2004, 18h44

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