![]() |
Datamodule wird zu Formular
Hallo Freunde,
ich hatte zu diesen Thema schon einmal einen Thread erstellt, doch der ist verschwunden... Vermutlich, weil ich dachte, Problem sei gelöst. Ist es aber nicht, weder in D2010 noch in XE4 (auf das sich mein Thread damals bezog) und auch in XE7 nicht. Folgende Konstellation: - Ein Datenmodul, genannt TBaseDM. In diesem befinden sich eine ganze Reihe Methoden, die als
Delphi-Quellcode:
markiert sind.
abstract
- Davon abgeleitet ein weiteres Datenmodul (TLocalDM), das diese abstrakten Methoden überschreibt:
Delphi-Quellcode:
- Ebenfalls von TBaseDM abgeleitet ein drittes Datenmodul (TSQLDM), das ebenfalls diese abstrakten Methoden überschreibt.
type
TLocalDM = class(TBaseDM) //TLocalDM = class(TDataModule) ... end;
Delphi-Quellcode:
Nun das Phänomen: Ich öffne die Projektdatei mit dem TLocalDM. Mache irgendeine Änderung. Speichere und compiliere. Alles prima. Starte das Programm und es crasht mit der Meldung "Eigenschaft ClientHeight existiert nicht". Hat er ja recht, ClientHeight haben Datenmodule nicht - aber Formulare.
type
TSQLDM = class(TBaseDM) ... end; Öffne ich TLocalDM.pas erneut und gehe auf die Formularansicht, dann sehe ich kein Quadrat, das mein Datenmodul darstellt, sondern ein Formular (Titelzeile, Minimize-,Maximize-,Close-Button). Ich muß dann den Kopf der Unit umbauen:
Delphi-Quellcode:
Dann das Projekt speichern, schließen und neu öffnen, wo mir sofort entgegenspringt "Eigenschaft ClientHeight existiert nicht". Hier wähle ich "alle ignorieren", da noch etliche formularspezifische Properties folgen. Dann tausche ich die Kommentare zurück, compiliere und speichere neu und das Problem ist weg. Bis ich LocalDM.pas schließe und neu öffne - dann ist aus dem Datenmodul wieder ein Formular geworden.
type
//TLocalDM = class(TBaseDM) TLocalDM = class(TDataModule) //Kommentare nun vertauscht ! ... end; Ich hatte schon mal herumgeforscht und gesehen, das Delphi in der Projektdatei Hinweise hinterlegt, das mein LocalDM eigentlich ein TDataModule ist. Dies stimmt auch alles, trotzdem wird immer wieder ein Formular draus:
Delphi-Quellcode:
Der ganz große Witz ist nun: Mit TSQLDM passiert das nicht. Das bleibt ein Datenmodul, egal wie oft ich TSQLDM.pas öffne und wieder schließe.
FZW_BaseDM in 'FZW_BaseDM.pas' {BaseDM: TDataModule},
FZW_NoDBDM in 'FZW_NoDBDM.pas' {NoDBDM: TDataModule}, FZW_LocalDM in 'FZW_LocalDM.pas' {LocalDM: TDataModule}, FZW_SQLDM in 'FZW_SQLDM.pas' {SQLDM: TDataModule}, Ich hatte, wie schon erwähnt, während der Nutzung von XE4 schon einmal um Rat gefragt, wie man diese sehr nervige Sache abstellt (zumal dann immer wieder beim Kunden auftaucht "Eigenschaft ClientHeight existiert nicht", obwohl man eigentlich am SQLDM was geändert hat und das nur am LocalDM nachziehen wollte). Ich hatte die leise Hoffnung, das das unter XE7 verschwinden würde, tat es aber nicht. Also erneut die Frage in die Runde: Was mache ich falsch (oder habe ich falsch genmacht) und wie werde ich diesen Geist wieder los ? |
AW: Datamodule wird zu Formular
Hallo,
wie sieht denn die ".dfm" des Datenmoduls aus? Evtl. mal posten. EDIT: Und evtl. das Userprofil updaten, hier steht noch XE4 |
AW: Datamodule wird zu Formular
Vererbung von Datenmodulen kannst du ganz einfach vergessen, da der Formdesigner damit nicht klar kommt.
Wenn er nicht sicher erkennt, daß es ein TDataModule ist, oder es sich um einen ihm bekannte Klasse handelt, z.B. TService, dann springt der Designer immer auf TForm zurück. Also entweder vergiss das Vererben, registriere deinen Vorfahren bei Delphi (RegisterClass, RegisterComponent, ...) oder Vererbe nicht "sichtbar" (also ohne abgeleitete DFM). PS: Das Erkennen des Typs macht der kranke Designer auch nicht über die RTTI (schauen was für einen Vorfahren die Klasse hat), sondern anhand des Eintrags in der DPR/DPROJ
Delphi-Quellcode:
und wenn da nicht "TDataModule" steht ...
{BaseDM: TDataModule}
Das Problem besteht seit Jahrzehnten und ich würde nicht auf einen Bugfix hoffen (innerhalb der nächsten 20 Jahre) und wenn, dann höstens zum Kaufen (XE32). |
AW: Datamodule wird zu Formular
|
AW: Datamodule wird zu Formular
Zitat:
|
AW: Datamodule wird zu Formular
zum Pauschal: Es ist quasi fast unvorhersehbar, ob es funktioniert, also besser nicht benutzen. :stupid:
Man kann versuchen, ob es funktioniert (wird zumindestens besser, solange das Package mit dem Vorfahren in Delphi installiert/geladen ist), wenn man den Vorfahren registriert oder man verzichtet eben besser auf eine visuelle Vererbung von Nicht-TForms, von welchen Delphi den Vorfahren nicht direkt kennt. |
AW: Datamodule wird zu Formular
Liste der Anhänge anzeigen (Anzahl: 1)
Hi OlafSt
Zitat:
Anhand eines kurzen Beispielprogrammes lernte ich das Pattern Classfactory kennen. Das Beispiel verwendete Frames, genau wie ich. Im Gegensatz zu mir, der ich damals mit DelphiXE4 arbeitete, war das Beispiel mit DelphiXE7 erstellt worden. Erst liess sich dieses Beispiel nicht compilieren - Fehlermeldung war genau die, die du angegeben hast. Meine ![]() Und nun kommt der Clou: seit eiger Zeit arbeite ich mit Delphi XE8 und verwende in dem Immer noch selben Projekt Frames, die ich mit Delphi XE4 erstellt hatte - ich hätte also erwartet, dass DXE8 die in meinen Frames fehlenden Propertys ClientHeight und ClientWith anmeckert - aber nichts geschah. Desshalb hatte ich erst angenommen, dass Frames in XE8 diese Propertys doch nicht mehr haben - ein Blick in die Help belehrte mich allerdings eines besseren. Andrerseits habe ich nachgesehen, wie das jetzt bei Datamodulen ist. Da ist nnach wie vor sowas nicht vorhanden. Den Geist dürftest du loswerden, indem du ein neues Exemplar deines fehlerhaften moduls erzeugst (das alte Umbennen, das neue mit dem jetzigen Namen). Den Code aus dem jetzigen Modul kannst du zB. mit dem CnPack als *.txt-Datei sichern. Mit den GExperts habe ich nicht so gute Erfahrungen. Gruss Delbor |
AW: Datamodule wird zu Formular
Zitat:
Wurde schon nach der DFM gefragt? Poste doch mal eine abgeleitete DFM... Die ersten 10 Zeilen sollten reichen. |
AW: Datamodule wird zu Formular
Das Verhalten ist reproduzierbar:
Delphi-Quellcode:
unit dm1;
interface uses System.SysUtils, System.Classes; type TDataModule1 = class(TDataModule) private { Private-Deklarationen } public { Public-Deklarationen } end; var DataModule1: TDataModule1; implementation {%CLASSGROUP 'Vcl.Controls.TControl'} {$R *.dfm} end.
Delphi-Quellcode:
Bis hier ist die Welt noch in Ordnung ...
unit dm2;
interface uses System.SysUtils, System.Classes; type TDataModule2 = class(TDataModule) private { Private-Deklarationen } public { Public-Deklarationen } end; var DataModule2: TDataModule2; implementation {%CLASSGROUP 'Vcl.Controls.TControl'} {$R *.dfm} end. Jetzt den Fehler einbauen:
Delphi-Quellcode:
Speichern, Alles schliessen, Projekt wieder öffnen ... DataModule2 öffnen => eine Form!
unit dm2;
interface uses System.SysUtils, System.Classes, dm1; // <- da type TDataModule2 = class(TDataModule1) // <- da private { Private-Deklarationen } public { Public-Deklarationen } end; var DataModule2: TDataModule2; implementation {%CLASSGROUP 'Vcl.Controls.TControl'} {$R *.dfm} end.
|
AW: Datamodule wird zu Formular
Ich habe mal den Heilungsprozeß von Sir Rufo durchgeführt. Tatsächlich steht bei den Problem-Datamodules in den DFM-Files "object", während bei den "gesunden" DFMs ein "inherited" steht. Allerdings sind alle Datamodules "per Hand" abgeleitet, von daher muß da noch was anderes im Busch sein - aber wie schon erwähnt wurde, dürfte das in der IDE und ein Fix in sehr weiter Ferne liegen :wink:
Da findige Leute meinen Thread in der EE aufgespürt haben (hatte vergessen, das ich ihn da eröffnet hatte), werde ich den Thread hierhin verweisen lassen. Was lernen wir daraus ? Da will man mal was anderes ausprobieren und den empfohlenen Weg gehen und wird dann so dafür belohnt :-D Ich gelobe feierlich, von Datamodules gleich wieder die Finger zu lassen, so wie ich es all die Jahre zuvor auch getan habe :-D:-D |
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:16 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