Hypercell ein ] Hypercell aus ] Zeige Navigation ] Verstecke Navigation ]
c++.de  
   

Die mobilen Seiten von c++.de:
http://m.c-plusplus.de
Infos hier [BETA]

  
c++.de :: C++ (auch C++0x und C++11) ::  IF DEBUG     Zeige alle Beiträge auf einer Seite Auf Beitrag antworten
Autor Nachricht
logloglog
Unregistrierter




Beitrag logloglog Unregistrierter 22:20:15 12.04.2012   Titel:   IF DEBUG            Zitieren

Hey, ich habe eine kleine Log Klasse geschrieben. Ich wollte fragen ob es eine möglichkeit gibt System & Compiler unabhängig herauszufinden, ob der Compiler im Debug | Release Modus ist. Im Debugmodus soll er schreiben und im Release schweigen :)

Hier der Code(freue mich auch über jeden Tipp und Verbesserungsvorschlag ):

.H:

C++:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#ifndef DEBUGLOG_H_INCLUDED
#define DEBUGLOG_H_INCLUDED

#include <string>

#include <fstream>
#include <stdexcept>
 
class DebugLog
{
public:
    explicit DebugLog(const std::string& filePath);
 
    ~DebugLog();
 
    void entry(const std::string& what);
 
private:
    std::ofstream logFile;
};

#endif // DEBUGLOG_H_INCLUDED


.CPP

C++:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include "debuglog.h"
 
DebugLog::DebugLog(const std::string& filePath)
    : logFile(filePath.c_str())
{
    if(!logFile)
        throw std::runtime_error("can`t open log file!");
    else
        logFile << "START" << std::endl << std::endl;
}
 
DebugLog::~DebugLog()
{
    logFile << "END" << std::endl;
}
 
void DebugLog::entry(const std::string& what)
{
    if(!logFile)
        throw std::runtime_error("can`t write in log file!");
    else
        logFile << "\t" << what << std::endl << std::endl;
}
cooky451
Mitglied

Benutzerprofil
Anmeldungsdatum: 16.10.2010
Beiträge: 6869
Beitrag cooky451 Mitglied 22:25:45 12.04.2012   Titel:              Zitieren

Ehm.. na ja, abgesehen davon, dass ich einen ostream nutzen und die Klasse insgesamt völlig anders aufziehen würde.. guck dir mal das NDEBUG Makro an.

_________________
Sie sind nicht berechtigt unrechtmäßige Kopien dieses Datenträgers zu erstellen.™
Keksverteilungsbeauftragter
314159265358979
Mitglied

Benutzerprofil
Anmeldungsdatum: 09.03.2010
Beiträge: 4658
Beitrag 314159265358979 Mitglied 12:41:32 13.04.2012   Titel:              Zitieren

Wozu überhaupt eine Klasse? :p
c++.de :: C++ (auch C++0x und C++11) ::  IF DEBUG   Auf Beitrag antworten

Zeige alle Beiträge auf einer Seite




Nächstes Thema anzeigen
Vorheriges Thema anzeigen
Sie können Beiträge in dieses Forum schreiben.
Sie können auf Beiträge in diesem Forum antworten.
Sie können Ihre Beiträge in diesem Forum nicht bearbeiten.
Sie können Ihre Beiträge in diesem Forum nicht löschen.
Sie können an Umfragen in diesem Forum nicht mitmachen.

Powered by phpBB © 2001, 2002 phpBB Group :: FI Theme

c++.de ist Teilnehmer des Partnerprogramms von Amazon Europe S.à.r.l. und Partner des Werbeprogramms, das zur Bereitstellung eines Mediums für Websites konzipiert wurde, mittels dessen durch die Platzierung von Werbeanzeigen und Links zu amazon.de Werbekostenerstattung verdient werden kann.

Die Vervielfältigung der auf den Seiten www.c-plusplus.de, www.c-plusplus.info und www.c-plusplus.net enthaltenen Informationen ohne eine schriftliche Genehmigung des Seitenbetreibers ist untersagt (vgl. §4 Urheberrechtsgesetz). Die Nutzung und Änderung der vorgestellten Strukturen und Verfahren in privaten und kommerziellen Softwareanwendungen ist ausdrücklich erlaubt, soweit keine Rechte Dritter verletzt werden. Der Seitenbetreiber übernimmt keine Gewähr für die Funktion einzelner Beiträge oder Programmfragmente, insbesondere übernimmt er keine Haftung für eventuelle aus dem Gebrauch entstehenden Folgeschäden.