Einzelnen Beitrag anzeigen
  #1 (permalink)  
Alt 30.12.16
Kronenchakra Kronenchakra ist offline
Gesperrter Benutzer
 
Registriert seit: Feb 2016
Ort: 2100 Österreich
Beiträge: 313
Kronenchakra befindet sich auf einem aufstrebenden Ast
Standard MyAlert, bequeme und einfache Fehlerbehandlung

Fehler abzufangen ist wichtig, Informationen über den Fehler auszugeben hilfreich.
Das wird aber oft als mühsam empfunden und deshalb oft weggelassen.
Mir geht es jedenfalls so.
Weiters sind mehrere Programmzeilen notwendig, der Code wird auch nicht kompakter dadurch, der Fehler sollte ja auch noch zurückgesetzt werden.
Also habe ich MyAlert.mqh implementiert.
Der nächste Codeschnipsel wird diese Funktion verwenden, gleich als Anwendungsbeispiel.
Ist nicht getestet, sollte aber auch unter MQL4 laufen.

Code:
//+------------------------------------------------------------------+
//|                                                      MyAlert.mqh |
//|                                Copyright © 2016 Ing. Otto Pauser |
//+------------------------------------------------------------------+
//| Bequeme und sichere Fehlerbehandlung. 3 überladene Funktionen    |
//| 1. MyAlert(max 6 Parameter Typ String)                           |
//| 2. MyAlert(int AnyRetval, max 6 Parameter Typ String)            |
//| 3. MyAlert(ENUM_INIT_RETCODE Retval, max 6 Parameter Typ String) |
//|                                                                  |
//| Das Macro StdErrMsg kann nur von der aufrufenden Funktion        |
//| verwendet werden, da ja hier sinnlos und vom Compiler abgelehnt  |
//+------------------------------------------------------------------+

#include <ErrorDescription.mqh>        // falls nicht vorhanden, hier ist der downloadlink:  https://www.mql5.com/en/code/79
                                       // ist nicht ganz aktuell, aber der Service-Desk ist informiert und wird das demnächst aktualisieren
static bool AlertPrintOnly = false;    // Steuerung des Verhaltens bei Fehler. Nur Print, oder Print + Alert

#define StdErrMsg ", Function: "+__FUNCTION__+"(), Line:"+(string)__LINE__    // nur in der aufrufenden Funktion verwendbar
                                                                              // hier wird der ganze Text zusammengebastelt
string StringMake(string str1="", string str2="", string str3="", string str4="", string str5="", string str6="")
{
   string       ErrMsg = str1;
   if(str2=="") return(ErrMsg); else ErrMsg = ErrMsg+" "+str2;
   if(str3=="") return(ErrMsg); ErrMsg = ErrMsg+" "+str3;
   if(str4=="") return(ErrMsg); ErrMsg = ErrMsg+" "+str4;
   if(str5=="") return(ErrMsg); ErrMsg = ErrMsg+" "+str5;
   if(str6=="") return(ErrMsg); ErrMsg = ErrMsg+" "+str6;
   return(ErrMsg);
}
                           // in OnInit() gut plaatziert oder auch allgemeine Verwendung
int MyAlert(string str1="", string str2="", string str3="", string str4="", string str5="", string str6="")
{
   string ErrMsg="*ERROR* "+IntegerToString(GetLastError())+" - "+ErrorDescription(GetLastError())+" ";
   ErrMsg = ErrMsg + StringMake(str1, str2, str3, str4, str5, str6);
   
   Print(ErrMsg);          // print the errormessage
   
   if(AlertPrintOnly)
      PlaySound("Alert");
   else   
      Alert(ErrMsg);       // do the alert if requested
      
   ResetLastError();       // reset lasterror
   return(INIT_FAILED);
}
                           // ist diversn Einsatz vorgesehen der Rückgabe benütigt
int MyAlert(int aRetVal, string str1="", string str2="", string str3="", string str4="", string str5="", string str6="")
{
   MyAlert(str1, str2, str3, str4, str5, str6);
   return(aRetVal);
}
                           // ist für die OnInit() vorgesehen
int MyAlert(ENUM_INIT_RETCODE aRetVal, string str1="", string str2="", string str3="", string str4="", string str5="", string str6="")
{
   MyAlert(str1, str2, str3, str4, str5, str6);
   return(aRetVal);
}
Viel Erfolg damit.

PS: Falls jemand Verbesserungmöglichkeiten sieht, nur her damit.
PPS: Wollte noch die Datei im nachhinein anhängen, geht aber nicht bei Änderung. Ich versuche es nochmals nach dem nächsten Post der schon draussen ist

Geändert von Kronenchakra (30.12.16 um 22:00 Uhr) Grund: Anhang hinzugefügt