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 2 von 2     12   
Benutzerbild von himitsu
himitsu

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

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 11:06
Eine StringList hat doch ein OnChange?

Da kann also ein Event angegeben werden .. eventuell ein Porperty in der Basisklasse, welches das dann bei der internen StringListe einträgt.
Oder die StringListe meldet Änderungen an die Basisklasse und diese wiederum leidet das Event weiter.
Oder man baus in seine Klasse eine interne SetzeWarnung-Prozedur, welche die Warnung in die StringList einträgt und das Event auslöst.
...
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Benutzerbild von Xong
Xong

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

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 11:09
Zitat von Alfi001:
Genau das hatte ich im vorherigen Beitrag vorgeschlagen.
Ich wollte nicht unterschlagen, dass du mir sehr bei der Suche nach einem passenden Konzept geholfen hast.

Also ein dickes Dankeschön!
  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
 
#13

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 11:15
Zitat von himitsu:
Eine StringList hat doch ein OnChange?
Stimmt! Ist mir auch jetzt gerade erst aufgefallen. Wann wurde das denn eingeführt? Eventuell sollte ich mir von Delphi-Version zu Delphi-Version mal die Neuerungen (genauer) ansehen...

Damit wäre die TStringList auch schon "intelligent" genug als Container für die Warnungen.
Ralf Kaiser
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#14

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 11:16
Hallo,

mal so aus dem Bauch:

Die Klasse TDtausDataType bekommt eine Stringliste, in die sie die Warnungen reinschreibt.
Wenn sie mit ihrem Job fertig ist und es sind Warnungen vorhanden, schmeißt sie eine Ausnahme vom Type EWarnungenGefunden (oder so). Das aufrufende Programm muss diese Ausnahme abfangen und die Liste (wie auch immer) ausgeben.

Wird das Abfangen dieser Ausnahme vom Programmierer "vergessen", ärgert sich der Anwender und der Programmierer muss nachsitzen.

Bei einem Event muss sichergestellt sein, dass die "Nichtzuordnung" einer entsprechenden OnEvent-Methode zu einem Fehler führt.
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#15

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 11:46
Zitat von nahpets:
Hallo,

mal so aus dem Bauch:

Die Klasse TDtausDataType bekommt eine Stringliste, in die sie die Warnungen reinschreibt.
Wenn sie mit ihrem Job fertig ist und es sind Warnungen vorhanden, schmeißt sie eine Ausnahme vom Type EWarnungenGefunden (oder so). Das aufrufende Programm muss diese Ausnahme abfangen und die Liste (wie auch immer) ausgeben.

Wird das Abfangen dieser Ausnahme vom Programmierer "vergessen", ärgert sich der Anwender und der Programmierer muss nachsitzen.

Bei einem Event muss sichergestellt sein, dass die "Nichtzuordnung" einer entsprechenden OnEvent-Methode zu einem Fehler führt.
genau das hätte ich auch auch vorgeschlagen. schreib doch einfach ein interface für deine klasse, die die entsprechenden methoden und internen variablen schon integriert hat. dann kannst du das system auch bei anderen klassen verwenden. kurz und knapp brauchst du halt das folgende:
  • container für die warnungen (was da am besten ist, sei mal dahin gestellt!)
  • push-methode
  • pop-methode
  • clear-methode
  • eine methode, die du am ende einer entsprechenden methode aufrufst, die prüft, ob mind. ein eintrag in der warnungs-liste vorhanden ist, und dann eine exception wirft.
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.464 Beiträge
 
Delphi 12 Athens
 
#16

Re: Konzept: Eigene Warnungen erzeugen

  Alt 11. Sep 2009, 13:25
Ich bin der Meinung, daß die Anwendung die Möglichkeit haben sollte, auf jedes Ereignis noch im laufenden Prozess zu reagieren. Dafür muss diese über das Ereignis benachrichtigt werden, wenn es stattfindet und nicht erst wenn der gesamte Prozess beendet wurde. Damit die Anwendung differenzieren kann, sollte neben dem Meldungstext auch ein Code mitgeliefert werden. Damit hat die Anwendung auch die Möglichkeit mit einer eigenen Exception zu reagieren.
Delphi-Quellcode:
type
  TDtausOnError = procedure (Sender: TObject; ACode: TErrorCode; const AMsg: string) of Object;
  TDtausOnNotify = procedure (Sender: TObject; ACode: TErrorCode; const AMsg: string; var AExcept: Boolean) of Object;

  TDtausDataType = class()
  private
    FOnError: TDtausOnError;
    FOnNotify: TDtausOnNotify;
  protected
    procedure DoOnError(ACode: TErrorCode; const AMsg: string); virtual;
    procedure DoOnNotify(ACode: TErrorCode; const AMsg: string; AExcept: Boolean = False); virtual;
  public
    property OnError: TDtausOnError read FOnError write FOnError;
    property OnNotify: TDtausOnNotify read FOnNotify write FOnNotify;
  end;

procedure TDtausDataType.DoOnError(ACode: TErrorCode; AMsg: string);
begin
  if Assigned(FOnError) then
    FOnError(Self, ACode, AMsg);

  raise TDtausExcetpion.Create(ACode, AMsg);
end;

procedure TDtausDataType.DoOnNotify(ACode: TErrorCode; AMsg: string; AExcept: Boolean = False);
begin
  if Assigned(FOnNotify) then
    FOnNotify(Self, ACode, AMsg, AExcept);

  if AExcept then
    raise TDtausExcetpion.Create(ACode, AMsg);
end;


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
    DoOnNotify(1, '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.
    }
 
    {immer Exception auslösen}
    DoOnError(2, 'Ungültige Zeichen im Feld xxx');

    {oder normalerweise Exception auslösen, es sei den die Anwendung sagt das ist ok}
    DoOnNotify(3, 'Ungültige Zeichen im Feld yyy', True);

    {oder normalerweise keine Exception auslösen, es sei den die Anwendung sagt das ist nicht ok}
    DoOnNotify(4, 'Ungültige Zeichen im Feld zzz', False);

  end;
end;
ErrorCode und Meldungstext sollten natürlich vordefinierte Konstanten sein, wobei der Text mit Format z.B. um den Feldnamen ergänzt werden könnte.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 00:38 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