![]() |
With Auflösen Refactoring?
Habe gerade gegoogelt ob es irgendwo eine Funktion/Erweiterung gibt mit der man in einem existierenden Code
der sehr viele With Anweisungen verwendet (sogar der Form with a,b do) die Withs in normale Aufrufe umwandeln lassen kann. Quasi von hier:
Delphi-Quellcode:
nach da:
var
MyForm : TForm; begin with MyForm do begin Left := 100; Top := 100; Width := 600; Height := 400; end; end;
Delphi-Quellcode:
Hab' aber nichts gefunden.
var
MyForm : TForm; begin MyForm.Left := 100; MyForm.Top := 100; MyForm.Width := 600; MyForm.Height := 400; end; Gibt's sowas? Grüße TurboMagic |
AW: With Auflösen Refactoring?
Versuchs mal mit Bard. Das hat bei mir bisher immer gute Ergebnisse gezeigt.
|
AW: With Auflösen Refactoring?
Nein, das gibt es nicht. Durch die Probleme, die with mit sich bringt, kann nur der Compiler das sinnvoll auflösen. Denn dafür muss man genau wissen, welche Eigenschaften welches Objekt hat usw., damit man die Befehle richtig zuordnet. Das kann kein externes Tool sinnvoll machen. Das schafft ja nicht einmal der Debugger.
Wenn es nur um die reine Umsetzung wie im Beispiel geht, könnte man das sicher automatisieren, z.B. wie vorgeschlagen mit KI, aber meist ist es ja komplizierter. |
AW: With Auflösen Refactoring?
Wenn man absolut garnichts weiß, dann gibt es nur einen Weg.
Und der geht auch nur, wenn es nur einen Eintrag im With gibt. (ja, man kann mehr als einwas dort angeben) * Vor alles in dem WITH diesen Ausdruck mit Punkt hinzufügen, * das WITH entfernen * und dann alles wieder rauswerfen, was der Compiler bemängelt. Klar, man könnte bestimmt einer KI ALLES beibringen, was an Sourcen rein geht (auch alles vom USES und dem was wiederum darin vorkommt. Dann könnte man, ähnlich wie der Compiler, den Code analysieren und erkennen was zu wem gehört. Aber wie gefährtlich das ist, erkannt man daran, dass inzwischen Vieles auf ein gemeinsames LSP umgebaut wird, denn es wirde nie geschafft ALLE Parser so hinzubekommen, dass sie mit der gleichen Syntax/Optionen/Quellen arbeiten und tweilweise unterschiedlich/falsch reagieren, z.B. siehe das Error-Insight, welches bekanntlich oft nur Mist anzeigt(e). Problematisch sind dann auch noch Versionsunterschiede, also wo sich Objekte verändert haben. Denn folgender Code hat im Delphi 7 eine ganz andere Wirkung, als z.B. im Delphi 11:
Delphi-Quellcode:
end;
// in einer Methode einer TForm und Rect1=TRect;
with Rect1 do begin Width := Right - Left; Height := Botton - Top; end; |
AW: With Auflösen Refactoring?
Hallo,
danke für die Antworten. Dann wäre das doch ein Anwendungsfall für ein LSP basiertes Refactoring in der IDE. Oder? Grüße TurboMagic |
AW: With Auflösen Refactoring?
Zitat:
Irgendwann wird das Refactoring vielleicht mal auf der Basis umgesetzt... ich hoffe vor meiner Rente. :lol: Im Ernst: Ich fürchte, dass so etwas noch eine Weile auf sich warten lässt. Leider. |
AW: With Auflösen Refactoring?
Ich wollte ja mal schauen was da möglich ist, aber in der OTA fehlt komplett alles dazu, ebenso nichts zum GetIt.
Und Infos zu finden, wie man den LSP manuell ansprechen konnte, sind auch recht selten. |
AW: With Auflösen Refactoring?
Schon a bissl älter, aber vielleicht nutzt's was:
![]() |
AW: With Auflösen Refactoring?
Man bedenke:
Delphi-Quellcode:
Oder noch besser:
with ListView1.Items.Add do
begin Caption := 'wupp'; SubItems.Add('di'); ImageIndex := 42; end;
Delphi-Quellcode:
Das kann Refactor nicht wissen und müsste eigentlich alle with-do-Subjekte, die keine lokalen Variablen sind, in lokale Variablen schreiben, um sicher zu funkionieren, selbst wenn es unnötig ist.
with TWuppdi.Create() do
try TuWas(); TuNochWas(); finally Free(); end; |
AW: With Auflösen Refactoring?
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:55 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