![]() |
DLL wegen RTTI zu einem Package umbauen
Hallo,
Ich muss ein DLL (wegen der RTTI)in ein Package umbauen und habe verschiedene Fragen. Ist ein Package zur laufzeit ladbar? Nach dem was ich über LoadPackage gelesen hab ist dem wohl so. Aber wie lautet dann das Äquivalent zu getProcAddress? Überhaupt was muss ich jetzt machen die DLL Methoden in eine Unit Packen und diese Unit in ein Package stecken? Kann ich ein Package getrennt von der Anwendung weitergeben? Eigentlich brauche ich nur zu wissen wie ich das in ein Runtime-Package packe. Hilfe!! |
Re: DLL wegen RTTI zu einem Package umbauen
Ein Package *ist* eine DLL, aber eine mit Metadaten, die die Delphi RTL verwerten kann.
"GetProcAddress" funktioniert dort also auch, genau wie die exports clause. |
Re: DLL wegen RTTI zu einem Package umbauen
Sähe das so aus
Delphi-Quellcode:
Und läst es sich dann auch mit
Package bla;
uses dbtables, classes, ect; Fn1(a,v:Tdatentyp):TBla; Begin Result := Rechnung1; end; Fn2(a,v:Tdatentyp):TBla; Begin Result := Rechnung2; end; Fn3(a,v:Tdatentyp):TBla; Begin Result := Rechnung3; end; exports Fn1,Fn2,Fn3; Begin end; GetModuleHandle bzw. LoadLibrary zur Laufzeit laden? Sorry, aber wenn ich hier im D7 versuche ein Package zu machen ists einfach nur eine Include und Contains Liste. Wie mache ich Runtime Packages? |
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
mkMinzler, in meinem Package ist ja keine Function enthalten
die sich exportieren ließe. ich kann da nur units und weiter packages hinzufügen. was soll ich damit schon anfangen? kann mich mal bitte jemand mit nem Beipiel von einem Package bewerfen das eine Funktion exportiert. |
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
Nur wie mache ich dem Package klar das es bestimmte Funktionen veröffentlichen soll? Soll ich meine DLL Funktionen in eine Unit packen. Die Köpfe ins Interface und fertig? Oder noch eienen Exports teil dazu? Sorry ich weiß das sich die fragen selten blöd anhören aber ich habe bisher immer nur Packages für Komponenten gebastelt die direkt mit in die Anwendung kompiliert wurden. Naja und jetzt bin ich dabei alle BDE Bezüge aus unserer Anwendung zu entfernen. Dafür habe ich mir eigene TDatasets geschrieben die die Datenbank Virtualisieren. So bracht man quasi nur ein neues DLL Schreiben um die Datebank zu wechseln, das ging auch gut. Doch leider ließ sich das RTTI Probelm irgendwann nicht mehr umgehen(sonst half immer in temporäres objekt kopieren). Und jetzt steh ich da mit ner DLL (bestimmt über Hundert Funktionen) auf der einen Seite und fertigen Wraperklassen auf der anderen Seite. Und hätte eigentlich ein Package gebraucht. :( Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
Ach ja und das Problem mit der RTTI könntest du auch dadurch lösen, dass die EXE sowie deine DLLs alle "Mit Runtime-Pckages kompilieren" aktiv haben und dort "rtl;vcl" eingetragen ist. Ggf. auch noch vcldb dazu.
|
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
Du meinst da problem wenn er meldet "Tstringlist ist nicht vom Typ Tstringlist" *g* das würde sich dann erübrigen? Ok, die Sache könnte ich zwar nicht entscheiden aber es wäre eine weiter Option. Du meinst also ich könnte ein package mit nur einer Unit mit meinen Funktionen und nem Exportteil machen und das ganze dann ohne Änderung auf der Anwendungsseite benutzen? |
Re: DLL wegen RTTI zu einem Package umbauen
Danke an alle
Diese Beispiel scheint zu funktionieren nochmals Danke! Das Package
Delphi-Quellcode:
Unit des Packages
package Test;
{$R *.res} {$ALIGN 8} {$ASSERTIONS OFF} {$BOOLEVAL OFF} {$DEBUGINFO ON} {$EXTENDEDSYNTAX ON} {$IMPORTEDDATA ON} {$IOCHECKS ON} {$LOCALSYMBOLS ON} {$LONGSTRINGS ON} {$OPENSTRINGS ON} {$OPTIMIZATION OFF} {$OVERFLOWCHECKS ON} {$RANGECHECKS ON} {$REFERENCEINFO OFF} {$SAFEDIVIDE OFF} {$STACKFRAMES OFF} {$TYPEDADDRESS OFF} {$VARSTRINGCHECKS ON} {$WRITEABLECONST ON} {$MINENUMSIZE 1} {$IMAGEBASE $400000} {$IMPLICITBUILD OFF} requires vcl, rtl; contains TESTLIB in 'TESTLIB.pas'; end.
Delphi-Quellcode:
Die Anwendung
unit TESTLIB;
interface uses dialogs; Procedure LoadLib; exports LoadLib; implementation Procedure LoadLib; Begin Showmessage('*Schnips*'); end; end.
Delphi-Quellcode:
unit Testformular;
interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Button1: TButton; procedure Button1Click(Sender: TObject); private { Private-Deklarationen } public { Public-Deklarationen } end; TTestProc = Procedure; var Form1: TForm1; Alib:Thandle; aMethod:TTestProc; implementation {$R *.dfm} procedure TForm1.Button1Click(Sender: TObject); var p:Pointer; begin alib := 0; alib := LoadPackage(Pchar('Test.bpl')); If alib<>0 then Begin p := nil; p := GetProcAddress(alib,PChar('LoadLib')); if p <> nil then Begin @AMethod := p; AMethod; end; UnloadPackage(alib); end; end; end. |
Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
|
Re: DLL wegen RTTI zu einem Package umbauen
Alles Umsonst sorry.
Aber eine BPL war nicht die lösung für das problem. denn Ich brauche in der DLL (oder bpl) und in der Anwendung unterschiedlich kompilierte Units und packages. Das kann ich nur mit einer DLL haben. Eine andere lösung wär COM aber 1. ist das Projekt schon zu weit fortgeschritten um jetzt noch com zu machen und 2. ist com nicht gerade performant. Werde jetzt DLL Seitig auch mit eigenen TDatasets arbeiten welches ohne assign, is, as funktionieren. (den Großteil kann man ja aus der DBTables(oder DbISAMTables) übernehmen) |
Re: DLL wegen RTTI zu einem Package umbauen
:?: Wie mache ich es, wenn ich alle units in packages gesteckt habe und von der exe datei aus jedoch nur bestimmte objekte aus einigen packages aufrufen will? :?:
|
AW: Re: DLL wegen RTTI zu einem Package umbauen
Zitat:
schaffe ich es auch damit (wenn ich EXE und DLL mit rtl und vcl packages compiliere), das ich in einer "normalen" DLL eine Objekt samt RTTI erzeuge, dieses Objekt dann in ner Funktion der EXE gebe und die EXE kann dann per RTTI auf die properties zugreifen? Oder hab ich dieses Aussage falsch verstanden? |
AW: DLL wegen RTTI zu einem Package umbauen
Wenn alles mit Runtime-Packages und alles mit dem absolut gleichen Kompiler erzeugt wurde, dann ja.
Dann kannst du aber auch gleich ein Package anstatt einer DLL verwenden. |
AW: DLL wegen RTTI zu einem Package umbauen
Man sollte nie Objekte im Interface einer Dll verwenden. Für diesen Zweck wurden die Bpls entwickelt (technisch handelt es sich ja um Dlls, mit erweitertem Interface)
|
AW: DLL wegen RTTI zu einem Package umbauen
Ich habe bei den BPL's Angst, das wenn sich viel in der EXE tut ich jedesmal die BPL's erneut erzeugen muss
Der Kompiler würde eh immer gleich sein/bleiben ... Nur muss ich eben von 2-3 Stellen dynamisch diese Objekte erzeugen und dynamisch auf RTTI Properties zugreifen können |
AW: DLL wegen RTTI zu einem Package umbauen
Und bei einer DLL wäre das anders? :roll:
|
AW: DLL wegen RTTI zu einem Package umbauen
Hmmmmm... ich hatte halt die Hoffnung ;)
Wenn ich nun eine DLL habe die hat ja dein ihre eigene RTTI. Sagen wir in der DLL habe ich folgendes Objekt.
Delphi-Quellcode:
in der EXE habe ich nun ein Objekt : TMeinDLLObjekt
type TMeinDLLObject = class
published Lines : TStringList; Text : string; end; Kann ich nun in der EXE rausfinden, das das Objekt eine RTTI hat die nicht in der EXE zu finden ist? Und es sind dann AUTOMATISCH alle properties (in dem Fall Lines : TStringList) auch in der RTTI der DLL zu finden oder? Bzw grob gesagt alles was in der DLL mit .Create erzeugt wird hat die RTTI in der EXE und umgekehrt oder? |
AW: DLL wegen RTTI zu einem Package umbauen
Warum sollte das notwendig sein? (Neuerzeugung BPL, wenn Exe sich ändert)
|
AW: DLL wegen RTTI zu einem Package umbauen
Rausfinden ob ein Objekt (dessen Klasse) in der RTTI der EXE ist, lässt sich leicht.
Du fragst einfach nach der RTTI zu dieser Klasse und es wird natürlich Keine gefunden. Aber nur weil die Klassen in beiden Modulen (EXE/DLL) die gleiche/selbe Deklaration haben, müssen die Instanzen und die RTTI nicht kompatibel sein. Beispiel: In der EXE wird auf ein Feld/Methode nicht zugegriffen, also lässt der Compiler das weg und schon ist alles Nachfolgende verschoben. Die Offsets zu den nachfolgenden Feldern/Variablen/VirtuellenMethoden stimmen nicht mehr überein und die Zugriffe gehen auf falsche Adressen. Zitat:
Da die EXE sich auf die BPL bezieht, braucht man nichts machen, wenn man an der EXE etwas ändert. Ändert sich was an der BPL, dann muß man auch nicht sofort die EXE neu kompilieren, solange sich keine öffentlichen/geteilten Schnittstellen ändern. Und wenn sich Schnittstellen ändern,dann muß man sowohl EXE, als auch BPL neu kompileren, aber mit dem Unterschied, daß bei der BPL ein Fehler geworfen wird, sobald die Schnittstellen nich zusammenpassen, was bei der DLL nicht passiert und man sich somit mit der DLL schöne Laufzeitfehler einfangen kann. |
AW: DLL wegen RTTI zu einem Package umbauen
Zitat:
Zitat:
|
AW: DLL wegen RTTI zu einem Package umbauen
Zitat:
|
AW: DLL wegen RTTI zu einem Package umbauen
Ok Danke
Dann werde ich das morgen mal probieren, ob es in meinem Fall so funktioniert wie ich es mir wünsche ... :D [edit]Würde das dann auch funktionieren, wenn mit dem SELBEN Compiler auf zwei verchiedenen Rechner das ganze mache? Also auf einem REchner spriche einem Delphi 2007 erzeuge ich die EXE und auf einem anderen Rechner auch mit Delphi 2007 dann die BPL dazu? Oder würde es da dann krachen?[/edit] |
AW: DLL wegen RTTI zu einem Package umbauen
Ja funktioniert. Mit verschieden Compiler meinte ich verschiedene Delphiversionen.
Wenn auf den 2 Rechner die selbe Version (inkl. Patchstand) installiert ist, funktioniert das. Sonst würden die ganzen 3rd-Party Komponenten/Plugins, welche nur als Bpl kommen auch nicht funkionieren. |
AW: DLL wegen RTTI zu einem Package umbauen
Ok danke
So hab noch mal einiges gelesen .... Also wenn ich meine BPL schreibe, und ich WILL ja KEINE NEUE EXE machen müssen wenn ich die BPL aktualisiere. Darf ich nichts in der interface section ändern, also alle Änderungen in der implemenation Section sind tabu Stimmt das so? Oder darf ich gewisse änderungen in der interface section machen? zB.: private variablen in eine Klasse hinzufügen oder gewissen funktionen/procedure dazu? Also welche Änderungen darf ich in einer unit machen ohne das sich die Version der Package ändert? Was passiert mit units die ich per uses in die BPL einbinde? Hat dazu noch wer interne infos? |
AW: DLL wegen RTTI zu einem Package umbauen
Zitat:
Dort darfst Du so viel verändern wie Du willst. Im Interface darfst Du nichts entfernen oder funktional verändern; erweitern kannst Du. Eine Bpl ist eine Dll, mit der zusätzlichen Möglichkeit komplexere (Objekt-)typen im Interface zu verwenden. |
AW: DLL wegen RTTI zu einem Package umbauen
Zitat:
... Aber was meinst du mit "erweitern kannst du" ? den published properties werde ich ja nichthinzufügen dürfen vermute ich mal oder? Das ich nichts entfernen kann/darf, das ist kein Problem, aber eben neue Sachen hinzufügen ... da habe ich noch wenig infos dazu gefunden. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:28 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz