Rédacteur d'unité de chargement dynamique de dll

Description

Ce petit programme permet de faciliter la rédaction d'une unité permettant le chargement dynamique d'une dll en Delphi.

Il faut placer les déclarations telles qu'elles sont dans les fichiers de la dll, fournir quelques informations, et le code est généré automatiquement.

L'unité générée charge automatiquement la dll au démarrage de l'appli, et la décharge à sa fermeture.

Elle propose les routines telles qu'elles aurait été proposées si on avait simplement utilisé un chargement statique (external).

Le code généré reproduit presque le comportement exact de du chargement via external.

Presque, car une petite différence (inconnue) permet de se débarrasser d'un problème bien connu en Delphi.

En effet certains composants (Le GroupBox, par exemple) placés sur une fiche contenue dans une dll accèder depuis un exe sous thème XP conduit systématiquement à une violation d'accès à la fermeture de l'exe.

Le chargement dynamique de la librairie est pour le moment le seul remède que je connaisse à ce problème.

Si vous en avez un autre, n'hésitez pas à me le signaler !

Source / Exemple :


unit pasAccesDll;

{$DEFINE EXTERNAL}

//==============================================================================
{$IFDEF EXTERNAL}
interface

procedure AfficherForm(); stdcall; external 'Project2.dll';

implementation

end.
//==============================================================================
{$ELSE}

interface

uses
  SysUtils, Dialogs, Windows;

type TAfficherForm = procedure(); stdcall;

var
  hProject2LibraryHandle: Integer;

  AfficherForm: TAfficherForm;

implementation

initialization
  hProject2LibraryHandle:= SafeLoadLibrary('Project2.dll');
  if hProject2LibraryHandle = 0 then
    ShowMessage('Echec du chargement de la librairie Project2.dll')
  else
  begin
    AfficherForm:= GetProcAddress(hProject2LibraryHandle, 'AfficherForm');
    if @AfficherForm = nil then ShowMessage('Echec du chargement de la routine AfficherForm');
  end;
finalization
  FreeLibrary(hProject2LibraryHandle);
//==============================================================================
{$ENDIF}
end.

Conclusion :


Le zip contient l'appli de traduction dans le dossier 'StaticToDynamic'.

Le dossier 'fiche dans dll' contient quant à lui un exemple d'utilisation : une dll affichant une fiche avec le thème XP.
Par une directive de compilation de l'unité qui déclare la routine de la dll, on peut choisir entre les deux types de chargement :

1 Le code simple et concis avec external, mais qui peut planter si les conditions sont réunies (Comme c'est le cas dans l'exemple).
2 Le code généré, long et semblant inutile, mais qui ne plante pas !

Codes Sources

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.