![]() |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Das ganze könnte man als Bug bezeichnen, denn wenn du dir zur Laufzeit mal anschaust, ob MyDBEdit.DataSource assigned ist, wirst du feststellen, dass dies nicht der Fall ist. Die IDE nimmt einfach nur den Klassennamen des DataModules und streicht das T weg.
Wenn du mal händisch den Namen der globalen DataModule variable änderst, wirst du feststellen, dass dies dann auch passiert. Korrektur: Das lag bei mir nur daran, dass ich dann keine Instanz des DataModules hatte - siehe meinen Post weiter unten. |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Zitat:
Zur Frage an sich : das geht schon sehr, sehr tief in die Eingeweide von Delphi rein. Solche Fragen werden sich hier kaum lösen lassen. Zumindest, wenn man mal folgendes bedenkt : die einzige mir bekannte Quelle, wo das Verhalten, IDE/Laufzeit in punkto DB-Komponenten näher erläutert wird, das sind Marco Cantus Bücher. Und sogar der braucht ca. 10-50 Buchseiten, je nachdem wo man anfängt. :mrgreen: Zitat:
|
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Zitat:
|
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Zitat:
Delphi-Quellcode:
procedure TMyCustomForm.MyDBEditClick(Sender: TObject);
begin if MyDBEdit.DataSource = nil then Exit; Showmessage(MyDBEdit.DataSource.Owner.ClassName); // Rückgabe: "TMyDM" end; Zitat:
Zitat:
Früher haben wir mit den globalen Variablen gearbeitet, die Delphi uns vorgegeben hat. Das hatte zur Folge, dass das DM in jedem Projekt unter anderem Namen erreichbar war. D.h. bei jeder Übernahme von Quelltextpassagen aus anderen Projekten musste jede Referenz auf das DM per Suchen und Ersetzen ausgetauscht werden. In einem ersten Schritt haben wir also die Variable einheitlich genannt (ProjektDM). Wir haben uns nix weiter dabei gedacht und es funktioniert prima. Nun habe ich eine projektübergreifende Superklasse für das DM und das ProjektForm entworfen. Das entspricht nun genau meinem komplexeren Beispiel, über das hier nun diskutiert wird. |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Hmm, mal ein paar Überlegungen:
Was bringt denn:
Delphi-Quellcode:
Kann es denn sein, dass Du in Deinem Demobeispiel maßgebliche Variablen Deines echten Projektes "unterschlägst", dass also tatsächlich irgendwo eine solche Variable definiert ist?
Showmessage(MyDBEdit.DataSource.Owner.Name);
Showmessage(MyDBEdit.DataSource.Name); FindComponent('MyCustomDM')... Kannst Du Deinen Demotext mit vertretbarem Aufwand in ein echtes Projekt gießen und live testen? Dann könnten wir das vielleicht auch mal genauer nachvollziehen... |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Zitat:
2. "MyDS" 3. nil Das scheinen mir alles sehr korrekte Werte zu sein... Zitat:
Zitat:
|
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
"UMyCustomDM in 'pfad\UMyCustomDM.pas' {MyCustomDM: TDataModule},"
Ich weiß es nicht wie der Compiler genau vorgeht, aber vielleicht wertet er ja diesen "Kommentar" irgendwie aus und erzeugt beim Öffnen des Projektes eine passende Variable - eben zur Herstellung der Projektverbindungen. Ist nur Spekulation - wäre aber ja denkbar. Ändere doch mal testweise den Kommentar in {MyCustomDMXxx: TDataModule}. Wenn es dann nicht mehr funktioniert, hätte man eine Erklärung... |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Ich habe jetzt mal mein Beispiel implementiert... :pale: und es läuft nicht. :shock: Baue ich in das Originalprojekt genau die selbe DS und das selbe DBEdit ein, klappt es. :shock: Somit ist dem Thread gerade die Diskussionsgrundlage entzogen worden...
Ich werde mich auf die Suche machen und mich dann wieder melden. :oops: |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Liste der Anhänge anzeigen (Anzahl: 1)
Du kannst in deinem uns nicht vorliegenden Projekt gern widerlegen, was ich sagte, es stimmt dennoch. Erzeugst du allerdings irgendwo eine Instanz dieses DataModules, wird diesem DataModule ein Name verpasst (rat mal welcher) und sie wird gefunden, wenn die Form aus der dfm geladen wird bzw wenn dieses ominöse GlobalFixupReferences aufgerufen wird (Tip: kompilier mit debug dcus und setz nen Stoppunkt in TDBEdit.SetDataSource)
Die Identifizierung der Komponenten, die in der dfm einander zugewiesen werden, geschieht anhand des Namens. Siehe Anhang |
AW: Wie kommt ein TDBEdit an die Instanz meines DataModules? Warum/Wie funktioniert e
Liste der Anhänge anzeigen (Anzahl: 1)
Oha!
Also mit dem DataModuleName stimmt. Siehe Code + ScreenShot.
Delphi-Quellcode:
Dann sollte aber FindComponent die Komponente finden...
procedure TForm1.FormCreate(Sender: TObject);
var DM2a, DM2b: TDataModule2; begin DM2a := TDataModule2.Create(Application); Caption := Caption + '->' + DM2a.Name; DM2b := TDataModule2.Create(Application); Caption := Caption + '->' + DM2b.Name; end; Ich steige hier aus und warte auf einen Abschlussbericht des TE ;-) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:52 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-2025 by Thomas Breitkreuz