Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Funktion als Exception markieren? (https://www.delphipraxis.net/211220-funktion-als-exception-markieren.html)

himitsu 16. Aug 2022 15:36

Delphi-Version: 11 Alexandria

Funktion als Exception markieren?
 
Fehlerbehandlung in eine Prozedur ausgelagert und schon fängt der Spaß an, weil überall der Compiler mit Warnungen um sich schmeißt, welche "eigentlich" garnicht stimmen.

Wen hat das noch nicht genervt? (voten wenn ja, wäre bestimmt nett)

https://quality.embarcadero.com/browse/RSP-38882


Es gibt ja viele Sprachen, wo man zumindestens für die Dokumentation
und teilweise auch für die Fehlerbehandlung
zu seinen Funktionen irgendwie angeben kann ob und welche Exceptions zu erwarten sind, wenn man jene Methode ausführt.



PS:
https://quality.embarcadero.com/browse/RSP-18827
https://quality.embarcadero.com/browse/RSP-26129
https://quality.embarcadero.com/browse/RSP-16508

Der schöne Günther 16. Aug 2022 16:05

AW: Funktion als Exception markieren?
 
Zitat:

Zitat von himitsu (Beitrag 1510214)
Es gibt ja viele Sprachen, (...) angeben kann ob und welche Exceptions zu erwarten sind,

Das vermisse ich von Java wirklich am meisten.
Vielleicht auch als einziges. Aber das war wirklich immer klasse - Das wurde nicht zur Info angegeben, sondern der Aufrufer muss die Exception behandeln. Sonst wirft der Compiler dir das um die Ohren und sagt "Hey, hier kann eine FileNotFoundException auftreten, behandelst du die bitte?"

himitsu 16. Aug 2022 16:52

AW: Funktion als Exception markieren?
 
Ein bissl Java ist im Delphi auch drin ... das muß auch GAAAAANZ viel sein, denn Jira will bei Quellcode immer zuerst {code:java} und man muß es selber nach delphi oder cpp umschreiben. :duck:

TurboMagic 17. Aug 2022 19:55

AW: Funktion als Exception markieren?
 
Zumindest per XMLDOC müsste es ab Delphi 11.1 gehen.
Habe aber den Namen des Tags vergessen...

Uwe Raabe 17. Aug 2022 20:20

AW: Funktion als Exception markieren?
 
Code:
/// <exception cref="ENotSupported">
///   Sender = nil
/// </exception>
Aber das keinen Einfluss auf den Compiler.

himitsu 17. Aug 2022 20:24

AW: Funktion als Exception markieren?
 
Ja, das gibt es einen Tag. Den müsste man unschön in der Code-Completion den Code-Templates finden können.

Und Documentation Insight (Werbung) kann noch bissl mehr und schöner.


Aber dem Compiler sind diese "Kommentare" leider Scheißegal. :cry:
(der müsste ja erstmal deren Inhalt mit parsen, bzw. er braucht eher [Attribute] oder eben Direktiven)

Dennis07 12. Sep 2022 11:25

AW: Funktion als Exception markieren?
 
Zitat:

Zitat von himitsu (Beitrag 1510214)
Fehlerbehandlung in eine Prozedur ausgelagert und schon fängt der Spaß an, weil überall der Compiler mit Warnungen um sich schmeißt, welche "eigentlich" garnicht stimmen.

Wie soll der Compiler das denn bitte checken können? Also möglich wäre sowas natürlich, aber sehr, sehr aufwändig. Du musst ja alle Programmpfade durchgehen und prüfen, ob sicher überall eine Exception geworfen wird. Und das bei CodeInsight bzw. LSP, was ja eh schon kaum vernünftig läuft und ständig abschmiert.

Zitat:

Zitat von himitsu (Beitrag 1510214)
Es gibt ja viele Sprachen, (...) angeben kann ob und welche Exceptions zu erwarten sind,

Joa, das stimmt. Und das zu validieren ist ja auch kein Hexenwerk. Aber das hilft hier in dem Szenario ja nicht weiter, weil es hier ja nicht darum geht, ob eine Exception geworfen werden könnte, sondern es geht darum, ob eine Exception geworfen werden muss.

Zitat:

Zitat von Uwe Raabe (Beitrag 1510255)
Code:
/// <exception cref="ENotSupported">
///   Sender = nil
/// </exception>
Aber das keinen Einfluss auf den Compiler.

Das hat bis 11.2 auf überhaupt gar nichts einen Einfluss, weil die XML-Hilfen ja seit Jahren nicht mehr richtig funktionieren ( -> funktioniert haben, wurde jetzt gefixt). Außerdem, wie oben beschrieben, hilft das ja nicht zu bestimmen, ob sicher ein Fehler geworfen wird.

himitsu 12. Sep 2022 11:41

AW: Funktion als Exception markieren?
 
Zitat:

Zitat von Dennis07 (Beitrag 1511655)
Wie soll der Compiler das denn bitte checken können? Also möglich wäre sowas natürlich, aber sehr, sehr aufwändig. Du musst ja alle Programmpfade durchgehen und prüfen, ob sicher überall eine Exception geworfen wird. Und das bei CodeInsight bzw. LSP, was ja eh schon kaum vernünftig läuft und ständig abschmiert.

Na so, wie jetzt auch schon?

Gibt es keinen Pfad, der bis zum END führt, oder bei einem EXIT endet,
bzw. gibt es ausschließlich Pfade, die bei einer Exception, Abort oder einer "mit exception" markierten Methode ankommen,
dann ist es so.

Und es muß nur noch an der Funktion gespeichert werden, dass es so ist, damit bei Verwendung/Aufruf das abgefragt werden kann.

Dennis07 12. Sep 2022 11:51

AW: Funktion als Exception markieren?
 
Ja okay, wie gesagt, möglich ist es ja. Zumindest, wenn man jetzt mal von ASM-Abschnitten, Zeigern, Labels/GoTos und OS-Fehlern absieht. Diese Sachen kann man halt nicht zuverlässig vorhersagen, aber das wird ja bei keiner der Warnungen auch nur versucht.
Aber ja, du hast wohl recht, wenn man das mit in den Methoden-Cache packt, dann ginge das schon ohne zu viel Overhead.

himitsu 12. Sep 2022 13:34

AW: Funktion als Exception markieren?
 
Alternativ, eben, wie hier ursprünglich "gewünscht", dass der Entwickler es einfach manuell setzt.
Wenn der Code dann doch keine Exception auslöst, dass ist es einfach ein Fehler.

So als Option an die Deklaration.
Attribute oder eben so wie inline/virtual/abstract/cdecl/...


Alle Zeitangaben in WEZ +1. Es ist jetzt 09:10 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