Delphi-PRAXiS
Seite 7 von 25   « Erste     567 8917     Letzte »    

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Software-Projekte der Mitglieder (https://www.delphipraxis.net/26-software-projekte-der-mitglieder/)
-   -   UnitOptimizer (https://www.delphipraxis.net/196493-unitoptimizer.html)

stahli 9. Aug 2019 09:21

AW: UnitOptimizer
 
Liste der Anhänge anzeigen (Anzahl: 1)
Machen Code-Einrückungen in ähnlicher Art wie im Screenshot irgendwie Sinn?
Würde jemand so etwas nutzen wollen und nach welchen Kriterien?

Ich selbst bin da unschlüssig.

Aktuell kann ich z.B. alle Worte nach einen ":" untereinander ausrichten lassen - und zwar automatisch, solange ":" in aufeinander folgenden Zeilen vorkommen.

Ich könnte auch sagen, dass eine Ausrichtung nur erfolgen soll, wenn die X-Ausrichtung z.B. 4 Zeichen Unterschied nicht übersteigt.
Dann hätte man ggf. Blöcke von Ausrichtungen, gebündelt für ein paar Zeilen.
Ich weiß aber nicht, ob das übersichtlich wird. Vermutlich eher nicht.

Aviator 9. Aug 2019 09:31

AW: UnitOptimizer
 
Ich hatte das auch mal eine Zeit lang so gemacht. Allerdings händisch. Irgendwann wurde es mir zu blöd, die Zeilen immer nachzurücken wenn mal eine Variable mit einem längeren Namen hinzugefügt wurde. Diese Arbeit würde zwar von deinem Unit Optimizer abgenommen, aber ich hatte damals noch einen anderen Punkt, warum ich es nicht mehr mache. Bei Methoden hatte ich das aber nie gemacht. Das passt in meinen Augen gar nicht.

Wenn Variablen im Namen etwas länger sind und zugleich in einer anderen Zeile bspw. nur eine Zählervariable (wie i, j, k, ...) steht, dann ist der Abstand zwischen Variablennamen und Datentyp sehr groß. Somit kann man beim lesen relativ leicht in der Zeile verrutschen, was das Lesen von SourceCode im Endeffekt schwieriger macht anstatt leichter.

Also wenn du das einfügen wolltest, dann auf jeden Fall einstellbar/als Option. Dann kannst du, wie von dir vorgeschlagen, auch noch einstellen lassen, bis zu welcher Anzahl von Leerzeichen überhaupt eine solche Ausrichtung erfolgen soll.

So viel von mir dazu. :)

DieDolly 9. Aug 2019 09:43

AW: UnitOptimizer
 
Zitat:

Also wenn du das einfügen wolltest, dann auf jeden Fall einstellbar/als Option.
Im Prinzip wäre es wünschenswert, wenn alles irgendwie mit einer Option versehen würde.
So kann jeder sich die Formatierungen aktivieren, die gewünscht sind.

hsg 9. Aug 2019 11:04

AW: UnitOptimizer
 
Bei Typdeklaration mache ich so etwas nicht, allerdings bei der Variablendeklaration schon sehr gerne, da ich so optisch besser die Namen der Variablen erkennen kann. Allerdings benutze ich sehr selten die Auflistung von Variablen gleichen Types (var i,j,k : integer), sondern schreibe sie lieber untereinander in eigene Zeilen:

Code:
var
   i: Integer;
   j: Integer;
An einer anderen Stelle könntest du mir sehr viel Arbeit abnehmen 8-):
Ich schreibe bei mehreren Zuweisungen untereinander das := immer in der gleichen Spalte, das ganze sieht dann ungefähr so aus:
Code:
   oWnd                := TMeineFensterklasse.create( self );
   oWnd.Property1      := irgendEinWert;
   oWnd.AndereProp     := einAndererWert;
Für mich ist das optisch einfach besser lesbar. Ich erkenne sofort, wo Zuweisungen stehen und wem da was zugewiesen wird. Hab's mir durch eine andere Programmiersprache angewöhnt, die auch noch selbst die Groß- und Kleinschreibung von Feldern zum Teil selbst übernommen hat.

Ralf Kaiser 9. Aug 2019 11:24

AW: UnitOptimizer
 
Zitat:

Zitat von hsg (Beitrag 1440501)
Ich schreibe bei mehreren Zuweisungen untereinander das := immer in der gleichen Spalte, das ganze sieht dann ungefähr so aus:
Code:
   oWnd                := TMeineFensterklasse.create( self );
   oWnd.Property1      := irgendEinWert;
   oWnd.AndereProp     := einAndererWert;
Für mich ist das optisch einfach besser lesbar. Ich erkenne sofort, wo Zuweisungen stehen und wem da was zugewiesen wird. Hab's mir durch eine andere Programmiersprache angewöhnt, die auch noch selbst die Groß- und Kleinschreibung von Feldern zum Teil selbst übernommen hat.

Was ist wenn du mal im gesamten Code nach Stellen wie
Delphi-Quellcode:
oWnd := TMeineFensterklasse.create( self );
suchen willst? Bei so einer Formatierung weißt du nie, wie viele Leerzeichen da benutzt werden und musst anfangen mit RegExpressions zu suchen!

stahli 9. Aug 2019 11:32

AW: UnitOptimizer
 
Danke Euch!

Ich werde für verschiedene Abschnitte (const, var, Klassendeklaration, Code usw.) einige Optionen anbieten.

Intern arbeite ich mit benannten "Tabs". Bei Propertys z.B. mit "Tab 'read'" und "Tab 'write'".
Der Formatierer schiebt die dann untereinander.

Ich kann noch einen Toleranzwert zuweisen, so dass man variieren kann zwischen etwa:

Code:
   oWnd                       := TMeineFensterklasse.create(self );
   oWnd.Property1              := irgendEinWert;
   I                          := 1;
   J                          := 2;
   oWnd.AndereProp            := einAndererWert;
   oWnd.NochGanzVollAndereProp := einAndererWert;
und

Code:
   oWnd     := TMeineFensterklasse.create(self );
   oWnd.Prop := irgendEinWert;
   I := 1;
   J := 2;
   oWnd.AnderePropLang        := einAndererWert;
   oWnd.NochGanzVollAndereProp := einAndererWert;
und

Code:
   oWnd     := TMeineFensterklasse.create(self );
   oWnd.Prop := irgendEinWert;
   I        := 1;
   J        := 2;
   oWnd.AnderePropLang        := einAndererWert;
   oWnd.NochGanzVollAndereProp := einAndererWert;

Wobei man dann halt auch mal damit leben muss, dass man subjektiv an der einen oder anderen Stelle doch lieber eine andere Einrückung hätte. Aber dann muss man halt für sich passende Durchschnittswerte finden...


@Ralf Kaiser

Ein sehr guter Einwand!
Vielleicht könnte man Emba dazu bewegen, bei Suchen Leerzeichen zu ignorieren oder immer auf eines zu kürzen.
Keine Ahnung ob das machbar wäre.

dataspider 9. Aug 2019 11:33

AW: UnitOptimizer
 
Zitat:

Zitat von Ralf Kaiser (Beitrag 1440502)
Zitat:

Zitat von hsg (Beitrag 1440501)
Ich schreibe bei mehreren Zuweisungen untereinander das := immer in der gleichen Spalte, das ganze sieht dann ungefähr so aus:
Code:
   oWnd                := TMeineFensterklasse.create( self );
   oWnd.Property1      := irgendEinWert;
   oWnd.AndereProp     := einAndererWert;
Für mich ist das optisch einfach besser lesbar. Ich erkenne sofort, wo Zuweisungen stehen und wem da was zugewiesen wird. Hab's mir durch eine andere Programmiersprache angewöhnt, die auch noch selbst die Groß- und Kleinschreibung von Feldern zum Teil selbst übernommen hat.

Was ist wenn du mal im gesamten Code nach Stellen wie
Delphi-Quellcode:
oWnd := TMeineFensterklasse.create( self );
suchen willst? Bei so einer Formatierung weißt du nie, wie viele Leerzeichen da benutzt werden und musst anfangen mit RegExpressions zu suchen!

Und wenn mal bei der 100. Zeile der Bezeichner 1 Zeichen länger ist, rückst du die 99 andernen 1 Zeichen weiter...
Wenn man sonst nichts zu tun hat :)

Frank

hsg 9. Aug 2019 11:39

AW: UnitOptimizer
 
Zitat:

Zitat von Ralf Kaiser (Beitrag 1440502)

Was ist wenn du mal im gesamten Code nach Stellen wie
Delphi-Quellcode:
oWnd := TMeineFensterklasse.create( self );
suchen willst? Bei so einer Formatierung weißt du nie, wie viele Leerzeichen da benutzt werden und musst anfangen mit RegExpressions zu suchen!

Das ist korrekt, aber bisher habe ich auch nicht wirklich nach solchen Sachen gesucht. Eine Suche nach "TMeineFensterklasse.create" hat mir eigentlich in solchen Fällen gereicht

DasWolf 9. Aug 2019 11:43

AW: UnitOptimizer
 
Zitat:

Zitat von dataspider (Beitrag 1440513)
Zitat:

Zitat von Ralf Kaiser (Beitrag 1440502)
Zitat:

Zitat von hsg (Beitrag 1440501)
Ich schreibe bei mehreren Zuweisungen untereinander das := immer in der gleichen Spalte, das ganze sieht dann ungefähr so aus:
Code:
   oWnd                := TMeineFensterklasse.create( self );
   oWnd.Property1      := irgendEinWert;
   oWnd.AndereProp     := einAndererWert;
Für mich ist das optisch einfach besser lesbar. Ich erkenne sofort, wo Zuweisungen stehen und wem da was zugewiesen wird. Hab's mir durch eine andere Programmiersprache angewöhnt, die auch noch selbst die Groß- und Kleinschreibung von Feldern zum Teil selbst übernommen hat.

Was ist wenn du mal im gesamten Code nach Stellen wie
Delphi-Quellcode:
oWnd := TMeineFensterklasse.create( self );
suchen willst? Bei so einer Formatierung weißt du nie, wie viele Leerzeichen da benutzt werden und musst anfangen mit RegExpressions zu suchen!

Und wenn mal bei der 100. Zeile der Bezeichner 1 Zeichen länger ist, rückst du die 99 andernen 1 Zeichen weiter...
Wenn man sonst nichts zu tun hat :)

Frank

Dann benutzt man Shift + Alt.
Ganz easy. :wink:

TiGü 9. Aug 2019 12:01

AW: UnitOptimizer
 
Wer Quelltext nach Spalten ausrichtet, der schubst auch kleine Babyenten in den Teich!

Wo ist der Sinn darin?
Man liest von links nach rechts Zeile für Zeile.
Das ist doch keine Monatsbilanz oder dergleichen.
Je weiter a von b weg ist (a := b, a: b), desto mehr muss das Auge beim Lesen springen und man kann sich in der Zeile vertun.
Kein normaler Mensch würde auf diese Weise einen normalen deutschen/englischen/whatever Text lesen wollen, aber bei Quelltext soll das sinnvoll sein?


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:52 Uhr.
Seite 7 von 25   « Erste     567 8917     Letzte »    

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