AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Konzept: Eigene Warnungen erzeugen

Ein Thema von Xong · begonnen am 10. Sep 2009 · letzter Beitrag vom 11. Sep 2009
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Xong
Xong

Registriert seit: 9. Jan 2008
186 Beiträge
 
Delphi 2006 Professional
 
#1

Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 15:37
Mahlzeit, Herrschaften!
Ich melde mich nach langer Abstinenz wieder in der Delphi-Szene zurück.

Natürlich habe ich auch gleich eine knifflige Frage.
Mein aktuelles Problem ist konzeptueller Natur.

Kurzfassung: Wie konzipiere ich eigene Warnungen?

Konkretes Beispiel:
Ich definiere eine Klasse die als Zeichenkettencontainer dienen soll. Dabei gibt es strenge Auflagen für den Zeichensatz und die -länge. [1]
Bei Aufruf der Setter-Methode dieser Klasse sollen zu lange Strings einfach auf die maximal mögliche Länge gekürzt, sowie unerlaubte Zeichen konvertiert werden. Ist solch eine Konvertierung nötig, soll die aufrufende Klasse mit einer Warnung (Achtung: nicht Fehlermeldung) davon benachrichtigt werden.
Fehler können natürlich trotzdem auftauchen und werden über Exceptions vermittelt.

Für die Warnungen allerdings sind Exceptions leider nicht geeignet, da nachfolgender Code nicht weiter ausgeführt wird.
Die Rückgabe eines Fehlercodes ist natürlich möglich, würde mMn aber durch die Kombination verschiedener Warnhinweise nur unnötig kompliziert werden.

Gibt es eine andere Möglichkeit, Warnungen zu erzeugen aber den Code trotzdem weiterlaufen zu lassen (ähnlich dem Fehlerkonzept beim Kompilieren)?
Wie wird das allgemein gelöst?

Vielleicht denke ich ja zu verworren und die Lösung ist eigentlich ganz einfach.

Danke fürs Lesen.

LG,
Xong


[1] Wen es interessiert: Ich programmiere eine DTAUS-Klasse für den elektronischen Zahlungsverkehr.
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#2

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 15:44
Zitat von Xong:
M
Ich definiere eine Klasse die als Zeichenkettencontainer dienen soll. Dabei gibt es strenge Auflagen für den Zeichensatz und die -länge. [1]
Bei Aufruf der Setter-Methode dieser Klasse sollen zu lange Strings einfach auf die maximal mögliche Länge gekürzt, sowie unerlaubte Zeichen konvertiert werden. Ist solch eine Konvertierung nötig, soll die aufrufende Klasse mit einer Warnung (Achtung: nicht Fehlermeldung) davon benachrichtigt werden.
Fehler können natürlich trotzdem auftauchen und werden über Exceptions vermittelt.
Wenn der übergeben String ungültig ist sollte ein Exception geworfen werden

Eine Warnung, wie du sie dir grad vorstellst, gibts so nicht. Du könntest natürlich ein Event einbauen, dass dem Aufrufer solche Warnungen mitteilt. Die kann der Aufrufer dann mitloggen, oder es sein lassen. Aber trotzdem kann (wenn man das Event nicht benutzt) dann so ein Fehler auftreten wie "Ich übergebe der Klasse etwas, und die vermukst das, irgendwas stimmt da nicht"

DTAUS sagt mir jetzt nix, aber wenn es um Geld geht würde ich erst recht nicht wollen, dass da Code versucht, das ungültigen Eingabedaten irgendwas passendes zu rekonstruieren
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.166 Beiträge
 
Delphi 12 Athens
 
#3

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 15:46
Die Fehlerkodes als Rückgabewerte hast du ja schon genannt,
dann bleiben noch ein Fehler-Property (a)
und eine Ereignisprozedur (b).

Fehlerproperty


A)
Ein Property in deiner Klasse, welche sich den letzen Fehler/Status merkt (als Fehlercode oder Fehlertext),
> ähnlich GetLastError
wo man dann nach Ausführen eines Befehls (z.B. einer Prozedur der Klasse) nachfragen kann, wie es gelaufen ist.

B)
Man kann eine Ereignisprozedur bei deiner Klasse registrieren ala .OnWarning (so wie .OnClick beim Button), welche dann bei einem Problem aufgerufen wird.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von Sko
Sko

Registriert seit: 11. Sep 2005
327 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 15:52
Ich bau mir für sowas auch immer gerne Ereignisprozeduren. Diese haben als Parameter meist einen Ereignistyp (i. d. R. ein Aufzählungstyp), eine Meldung und eventuell einen Fehlercode. Aber wie jfheins schon angemerkt hat: das Event muss man auch nutzen und darfs nicht vergessen, an der Stelle ist eine Exception im Vorteil.
MfG Sko
Zitat von Phoenix:
[OT]Phoenix guckt in die Glaskugel, zuckt mit den Flügelspitzen, krächzt etwas von wegen 'Boden' und 'Scherben' und schubbst die Kugel in Richtung Tischkante.[/OT]
Rockbox
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.429 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 15:59
Man könnte als Standardverhalten auch eine Exception vorsehen, die im Ausnahmefall durch die Eventmethode über einen Rückgabewert verhindert werden kann.
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.356 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 16:36
Man kann es doch einfach einstellbar machen. Wenn Property SuppressExceptions nicht gesetzt ist, dann raise ..., fertig.
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#7

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 16:37
Man könnte auch eine Exception werfen, falls das Event nicht benutzt wird

if not Assigned(OnWarning) then
raise WarningException.Create(...);

Ob das sinnvoll ist, steht auf einem anderen Blatt
  Mit Zitat antworten Zitat
Benutzerbild von Ralf Kaiser
Ralf Kaiser

Registriert seit: 21. Mär 2005
Ort: Wuppertal
932 Beiträge
 
Delphi 10.3 Rio
 
#8

Re: Konzept: Eigene Warnungen erzeugen

  Alt 10. Sep 2009, 16:48
Zitat von Xong:
Gibt es eine andere Möglichkeit, Warnungen zu erzeugen aber den Code trotzdem weiterlaufen zu lassen (ähnlich dem Fehlerkonzept beim Kompilieren)?
Sollen diese Warnungen denn irgendwo angezeigt werden? Sieht der Benutzer die Warnungen und kann dann irgendwelche Massnahmen ergreifen? (wenn beim compillieren Warnungen angezeigt werden dann kann man diese ja nacher auch beheben, idem man den Code ändert und anpasst)

Wenn der Benutzer die Warnungen irgendwo sehen kann dann bietet sich doch eine Loggingausgabe an die irgendwo im Programmfenster angezeigt wird:

Zitat:
[Nachricht]: Vorgang gestartet
[Nachricht]: Beginne mit dem Import
[Warnung]: Datei enthält falsche Zeichen
[Nachricht]: Import beendet
[Nachricht]: Beim letzten Import wurde eine Warnung erzeugt!
Analog zum compillieren würde eine Meldungsliste angezeigt die den aktuellen Vorgang beschreibt und Warnungen eventuell noch farblich hervorhebt.

Im einfachsten Fall werden die Warnungen in einer Stringliste gespeichert dei, getriggert durch ein Event, vom Hauptprogramm ausgegeben wird (oder man greift auf fertige Logging-Lösungen zurück)
Ralf Kaiser
  Mit Zitat antworten Zitat
Benutzerbild von Xong
Xong

Registriert seit: 9. Jan 2008
186 Beiträge
 
Delphi 2006 Professional
 
#9

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 09:34
Ich danke euch für eure Antworten.

Da ist ja auch schon viel Schönes dabei.

Ich habe inzwischen auch einen kleinen Beispielcode.
Es gibt eine Setter-Methode, die einen String entgegen nimmt und nach strengen Vorschriften konvertiert.
Dabei sind die Konvertierungen nicht weiter schlimm, sollen aber dem Anwender wenigstens mitgeteilt werden:
Delphi-Quellcode:
procedure TDtausDataType.SetValue(v: String);
var i: Integer;
begin
  // convert to upper case
  fValue := UpperCase(v);

  // lower case characters detected
  if StrComp(PAnsiChar(v), PAnsiChar(fValue)) <> 0 then
    ShowMessage('Klein- zu Großbuchstaben konvertiert!');

  // check each character
  for i:=1 to Length(v) do
  begin
    { Hier folgt eine weitere Überprüfung jedes einzelnen Zeichens,
      ob es im "DTAUS-Zeichensatz" erlaubt ist.
      Nicht erlaubte Zeichen sollen dabei mit Leerzeichen ersetzt werden.
      Bei bestimmten Daten (wie z. B. Kontonummer) ist das ein Fehler,
      bei anderen (wie z. B. Verwendungszweck) lediglich eine Warnung.
    }

  end;
end;
Wie teile ich nun der aufrufenden Klasse diese Warnungen mit. (Fehler werden über Exceptions behandelt.)

Meine Idee wäre folgende:
Es gibt einen Container für Warnungen, der entsprechend gefüllt wird.
Bei Auftreten einer Warnung trägt die Setter-Methode diese ein und teilt der aufrufenden Instanz über eine Event mit, dass Warnungen aufgetreten sind.

Anmerkungen oder Bedenken?


Danke für eure Anregungen.
  Mit Zitat antworten Zitat
Benutzerbild von Ralf Kaiser
Ralf Kaiser

Registriert seit: 21. Mär 2005
Ort: Wuppertal
932 Beiträge
 
Delphi 10.3 Rio
 
#10

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 09:47
Zitat von Xong:
Meine Idee wäre folgende:
Es gibt einen Container für Warnungen, der entsprechend gefüllt wird.
Bei Auftreten einer Warnung trägt die Setter-Methode diese ein und teilt der aufrufenden Instanz über eine Event mit, dass Warnungen aufgetreten sind.

Anmerkungen oder Bedenken?
Genau das hatte ich im vorherigen Beitrag vorgeschlagen. Als "Container" hatte ich eine TStringList vorgeschlagen aber da kann man eventuell auch etwas "intelligenteres" nehmen. So könnte man den "TwarnungsContainer" so implementieren, dass er immer wenn eine Warnung hinzugefügt wird ein Event triggert und so selbst das Hauptprogramm benachrichtigt. Dann muss sich deine Klasse nicht mehr um dieses Detail kümmern.
Ralf Kaiser
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:26 Uhr.
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