Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Vorsicht bei AnyDAC > FireDAC Migration mit reFind (https://www.delphipraxis.net/180846-vorsicht-bei-anydac-firedac-migration-mit-refind.html)

jensw_2000 23. Jun 2014 15:25

Datenbank: alle • Version: 0.0 • Zugriff über: FireDAC

Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Ich musste ein älteres XE2 Projekt ausgraben, um ein paar kleine Anpassungen für einen zu machen.
XE5 ist die einzige Delphi Version, die ich auf meinem Entwicklungssystem habe.

EMBT hat die FireDAC Komponenten (ehemals AnyDAC) ab XE5 mit einem neuen Präfix versehen und auch die Units umbenannt. Die Komponenten hießen vor XE5 "TAD<irgendwas>" und die Units "uAD<irgendwas>" (entsprechend der alten AnyDAC Namenskonvention). Seit XE5 haben die FireDAC Komponenten den Präfix "TFD ..." und auch die Unitnamen folgen einem anderen Schema.

Als Migrationshilfe liefert EMBT ab Werk das Tool "reFind" mit Delphi XE5 aus. Es soll alle AnyDAC Komponenten und Unitnamen im Projekt durch die entsprechenden FireDAC Komponentennamen ersetzen.

Am Ende war die "kleine Anpassung" mit reFind ein riesiger Aufwand.

Damit ihr nicht auch auf die Nase fallt oder euch zumindest darauf einstellen könnt, möchte ich hier alle gefundenen Fallstricke zusammentragen.


siehe DocWiki:
http://docwiki.embarcadero.com/RADSt...n_nach_FireDAC

Das reFind Tool hat keinerlei Intelligenz.
Es macht ein "stumpfsinniges" RegEx Search&Replace und ersetzt im Source alle Vorkommen von "AD" durch "FD" (auch in den DFMs). Zusätzlich ersetzt es die AnyDAC Unitnamen.

Thumbs up für dieses Meisterwerk des Software Engineerings! :thumb:

Resultat:
- alle Variablen und Konstanten die zufällig ein "aD" enthielten sind umbenannt
Delphi-Quellcode:
var aDetailView: TDetailView
wird zu
var FDetailView: TDetailView
Delphi-Quellcode:
procedure setDummy(aDummy :TDummy);
begin
  FDummy := aDummy;
end;
 wird zu
procedure setDummy(FDummy :TDummy);
begin
  FDummy := FDummy; // >> -- Pfff
end;
und so weiter.

Fast alle Glyphs und Images, die in den DFMs eingebettet waren, sind zerschossen, weil im Hex Code der Bilder schon einige "AD"s vorkamen, die durch reFind durch FD ersetzt wurden.

Captions wurden ebenfalls ersetzt.
Code:
"Bitte fragen Sie Ihren FDministrator"
.

Großes Kino, dieses Migrationstool.

Die Korrektur des XE5 Projektes hat mich einen glatten Arbeitstag gekostet.

reFind ist also mit viel viel Vorsicht zu genießen!

Sherlock 23. Jun 2014 15:34

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Beileid und Danke für den Hinweis!
Meisterhaft gemacht, das schafft keine Freeware schlechter.

Sherlock

Aviator 23. Jun 2014 15:40

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Ist natürlich wirklich ein A**ch voll Arbeit. Nur meine Frage an dich: Hattest du nicht vorher eine Sicherung des Projektes angelegt? So mache ich es zumindest immer wenn solch große Änderungen vorgenommen werden. Dann hättest du die Sicherung zurückspielen und ggf. die Unitnamen und Komponentennamen selbst ersetzen können. Ist natürlich so ziemlich blöd gelaufen. :?

jensw_2000 23. Jun 2014 15:49

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Ne. Ich wollte "nur schnell" den hart codierten Geschäftsführernamen ändern. Das war für mich keine große Änderung. Dem Tool habe ich genauso vertraut, wie ich es bei dem "Project Upgrade Wizard" von DevExpress mache.

Gegen 15:00 Uhr habe ich dann festgestellt, dass reFind ".Bak" Dateien anlegt :(.
Da war ich schon fast mit meinen Korrekturen durch...
(Ich weis. Oberdussel ... :oops:) Dafür brauche ich hier keinen extra Beifall :)

Aviator 23. Jun 2014 15:56

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Zitat:

Zitat von jensw_2000 (Beitrag 1263277)
Dafür brauche ich hier keinen extra Beifall :)

Das war jetzt auch ehrlich nicht böse gemeint. Ich kenne mich mit diesen Tool auch überhauüt nicht aus, da ich keine dieser Komponenten benutze. Aber naja. Jetzt hast du es ja erledigt und bist wieder etwas schlauer dadurch. :-D Wie sagt man so schön: Aus Fehlern lernt man. :thumb:

Daniel 23. Jun 2014 16:12

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Das war der Grund, warum wir damals ein eigenes Tool zur Komponenten-Ersetzung geschrieben hatten. Das arbeitet nämlich typ-sicher und wird durch Skripte gesteuert.

jensw_2000 23. Jun 2014 16:19

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Zitat:

Zitat von Daniel (Beitrag 1263279)
Das war der Grund, warum wir damals ein eigenes Tool zur Komponenten-Ersetzung geschrieben hatten. Das arbeitet nämlich typ-sicher und wird durch Skripte gesteuert.

Willst Du dein Tool nicht an EMBT spenden oder verkaufen oder geben einen großzügigen Wartungsvertrag eintauschen? :)

Der schöne Günther 23. Jun 2014 17:01

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Rein aus Interesse: XE5 Hotfix 4 installiert oder nicht?

http://cc.embarcadero.com/item/29698
This Hotfix provides an updated reFind.exe which can be found in the bin folder. [...]

jensw_2000 23. Jun 2014 17:13

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Zitat:

Zitat von Der schöne Günther (Beitrag 1263284)
Rein aus Interesse: XE5 Hotfix 4 installiert oder nicht?

http://cc.embarcadero.com/item/29698
This Hotfix provides an updated reFind.exe which can be found in the bin folder. [...]

Upd 2 ja. Hotfix 4 bin ich mir nicht sicher, wo ich das herausbekommen kann. Ich glaube aber schon das ich HF 4 installiert hatte.

reFind hat bei mir die Dateiversion 19.0.14356.6604


[EDIT]
Nein, war noch nicht drauf. Die Version aus dem Hotfix 4 ist neuer.
In der Readme gibt es allerdings keine richtigen Infos, was die neue Version anders macht.
Das Einzige was ich dort rauslesen konnte: Unitnamen kann das Tool jetzt auch kaputtmachen :)

Sherlock 24. Jun 2014 07:03

AW: Vorsicht bei AnyDAC > FireDAC Migration mit reFind
 
Und ich hatte in meinem ersten Beitrag noch im Zweifel zu Dir gehalten :lol:
So muss ich jetzt doch noch mein rausgestrichenes "Warum hast Du nicht einfach ein Update auf den letzten Projektstand gemacht, und eben schnell nochmal angefangen?" nachschieben. Oder hast Du etwa keine Versionsverwaltung? 8-)

Aber nachtreten, wenn einer am Boden liegt, machen nur U-Bahn Schläger... Du hast uns vor dem gleichen Fehler bewahrt.

Sherlock


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:42 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz