Skip to content

Commit

Permalink
2006-12-01 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com>
Browse files Browse the repository at this point in the history
	To know root cause of exception:
	
	* src/Exception.h
	(cause): New variable.
	(Exception): Added a parameter.
	(getMsg): Return const reference to msg.
	(getCause): New function.
	* src/DlRetryEx.h
	(DlRetryEx): Added a parameter 'cause'.
	Added an overloaded constructor.
	(DlAbortEx): Added a parameter 'cause'.
	Added an overloaded constructor.
	* src/SimpleLogger.cc
	(writeLog): Log nested exception messages recursively.
  • Loading branch information
tatsuhiro-t committed Dec 1, 2006
1 parent ff3ab41 commit 458cc27
Show file tree
Hide file tree
Showing 6 changed files with 46 additions and 6 deletions.
17 changes: 17 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,20 @@
2006-12-01 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com>

To know root cause of exception:

* src/Exception.h
(cause): New variable.
(Exception): Added a parameter.
(getMsg): Return const reference to msg.
(getCause): New function.
* src/DlRetryEx.h
(DlRetryEx): Added a parameter 'cause'.
Added an overloaded constructor.
(DlAbortEx): Added a parameter 'cause'.
Added an overloaded constructor.
* src/SimpleLogger.cc
(writeLog): Log nested exception messages recursively.

2006-11-20 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com>

* src/DefaultBtProgressInfoFile.cc
Expand Down
1 change: 1 addition & 0 deletions TODO
Original file line number Diff line number Diff line change
Expand Up @@ -20,3 +20,4 @@
* Add Turkish translation.
* Add the message like "you can resume the transfer by invoking aria2 again" when the download stops.
* Add --bt-timeout command line option.
* Fix DefaultBtProgressInfoFile.cc: save(), load()
10 changes: 9 additions & 1 deletion src/DlAbortEx.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,13 +38,21 @@

class DlAbortEx:public Exception {
public:
DlAbortEx():Exception() {}
DlAbortEx(Exception* cause = 0):Exception(cause) {}

DlAbortEx(const char* msg, ...):Exception() {
va_list ap;
va_start(ap, msg);
setMsg(string(msg), ap);
va_end(ap);
}

DlAbortEx(Exception* cause, const char* msg, ...):Exception(cause) {
va_list ap;
va_start(ap, msg);
setMsg(string(msg), ap);
va_end(ap);
}
};

#endif // _D_DL_ABORT_EX_H_
10 changes: 9 additions & 1 deletion src/DlRetryEx.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,13 +38,21 @@

class DlRetryEx:public Exception {
public:
DlRetryEx():Exception() {}
DlRetryEx(Exception* cause = 0):Exception(cause) {}

DlRetryEx(const char* msg, ...):Exception() {
va_list ap;
va_start(ap, msg);
setMsg(msg, ap);
va_end(ap);
}

DlRetryEx(Exception* cause, const char* msg, ...):Exception(cause) {
va_list ap;
va_start(ap, msg);
setMsg(msg, ap);
va_end(ap);
}
};

#endif // _D_DL_RETRY_EX_H_
10 changes: 8 additions & 2 deletions src/Exception.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,15 +46,21 @@ class Exception {
private:
string msg;
protected:
Exception* cause;

void setMsg(const string& msgsrc, va_list ap) {
char buf[256];
vsnprintf(buf, sizeof(buf), msgsrc.c_str(), ap);
msg = buf;
}
public:
Exception() {}
Exception(Exception* cause = 0):cause(cause) {}

virtual ~Exception() {}
string getMsg() { return msg; }

const string& getMsg() const { return msg; }

Exception* getCause() const { return cause; }
};

#endif // _D_EXCEPTION_H_
4 changes: 2 additions & 2 deletions src/SimpleLogger.cc
Original file line number Diff line number Diff line change
Expand Up @@ -110,9 +110,9 @@ void SimpleLogger::writeLog(FILE* file, int level, const char* msg, va_list ap,
datestr[strlen(datestr)-1] = '\0';
writeHeader(file, datestr, levelStr);
vfprintf(file, string(Util::replace(msg, "\r", "")+"\n").c_str(), ap);
if(e != NULL) {
for(Exception* nestedEx = e; nestedEx; nestedEx = nestedEx->getCause()) {
writeHeader(file, datestr, levelStr);
fprintf(file, "exception: %s\n", Util::replace(e->getMsg(), "\r", "").c_str());
fprintf(file, "exception: %s\n", Util::replace(nestedEx->getMsg(), "\r", "").c_str());
}
fflush(file);
}
Expand Down

0 comments on commit 458cc27

Please sign in to comment.