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 !
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.