2008-09-27 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com>

When error occurs while aria2 is parsing an command-line option, 
print
	the usage of the option.
	* src/Makefile.am
	* src/NameMatchOptionHandler.h
	* src/OptionHandlerException.h
	* src/option_processing.cc
pull/1/head
Tatsuhiro Tsujikawa 2008-09-26 16:05:45 +00:00
parent 87a5bb50c2
commit 54bb630077
6 changed files with 104 additions and 16 deletions

View File

@ -1,3 +1,12 @@
2008-09-27 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com>
When error occurs while aria2 is parsing an command-line option, print
the usage of the option.
* src/Makefile.am
* src/NameMatchOptionHandler.h
* src/OptionHandlerException.h
* src/option_processing.cc
2008-09-26 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com> 2008-09-26 Tatsuhiro Tsujikawa <tujikawa at rednoah dot com>
Reverted previous change. Reverted previous change.

View File

@ -191,7 +191,8 @@ SRCS = Socket.h\
ServerStatURISelector.cc ServerStatURISelector.h\ ServerStatURISelector.cc ServerStatURISelector.h\
NsCookieParser.cc NsCookieParser.h\ NsCookieParser.cc NsCookieParser.h\
CookieStorage.cc CookieStorage.h\ CookieStorage.cc CookieStorage.h\
SocketBuffer.cc SocketBuffer.h SocketBuffer.cc SocketBuffer.h\
OptionHandlerException.h
if HAVE_LIBZ if HAVE_LIBZ
SRCS += GZipDecoder.cc GZipDecoder.h SRCS += GZipDecoder.cc GZipDecoder.h

View File

@ -413,10 +413,10 @@ am__libaria2c_a_SOURCES_DIST = Socket.h SocketCore.cc SocketCore.h \
InOrderURISelector.h ServerStatURISelector.cc \ InOrderURISelector.h ServerStatURISelector.cc \
ServerStatURISelector.h NsCookieParser.cc NsCookieParser.h \ ServerStatURISelector.h NsCookieParser.cc NsCookieParser.h \
CookieStorage.cc CookieStorage.h SocketBuffer.cc \ CookieStorage.cc CookieStorage.h SocketBuffer.cc \
SocketBuffer.h GZipDecoder.cc GZipDecoder.h \ SocketBuffer.h OptionHandlerException.h GZipDecoder.cc \
Sqlite3MozCookieParser.cc Sqlite3MozCookieParser.h \ GZipDecoder.h Sqlite3MozCookieParser.cc \
AsyncNameResolver.cc AsyncNameResolver.h \ Sqlite3MozCookieParser.h AsyncNameResolver.cc \
IteratableChunkChecksumValidator.cc \ AsyncNameResolver.h IteratableChunkChecksumValidator.cc \
IteratableChunkChecksumValidator.h \ IteratableChunkChecksumValidator.h \
IteratableChecksumValidator.cc IteratableChecksumValidator.h \ IteratableChecksumValidator.cc IteratableChecksumValidator.h \
CheckIntegrityCommand.cc CheckIntegrityCommand.h \ CheckIntegrityCommand.cc CheckIntegrityCommand.h \
@ -1135,12 +1135,13 @@ SRCS = Socket.h SocketCore.cc SocketCore.h BinaryStream.h Command.cc \
InOrderURISelector.h ServerStatURISelector.cc \ InOrderURISelector.h ServerStatURISelector.cc \
ServerStatURISelector.h NsCookieParser.cc NsCookieParser.h \ ServerStatURISelector.h NsCookieParser.cc NsCookieParser.h \
CookieStorage.cc CookieStorage.h SocketBuffer.cc \ CookieStorage.cc CookieStorage.h SocketBuffer.cc \
SocketBuffer.h $(am__append_1) $(am__append_2) $(am__append_3) \ SocketBuffer.h OptionHandlerException.h $(am__append_1) \
$(am__append_4) $(am__append_5) $(am__append_6) \ $(am__append_2) $(am__append_3) $(am__append_4) \
$(am__append_7) $(am__append_8) $(am__append_9) \ $(am__append_5) $(am__append_6) $(am__append_7) \
$(am__append_10) $(am__append_11) $(am__append_12) \ $(am__append_8) $(am__append_9) $(am__append_10) \
$(am__append_13) $(am__append_14) $(am__append_15) \ $(am__append_11) $(am__append_12) $(am__append_13) \
$(am__append_16) $(am__append_17) $(am__append_14) $(am__append_15) $(am__append_16) \
$(am__append_17)
noinst_LIBRARIES = libaria2c.a noinst_LIBRARIES = libaria2c.a
libaria2c_a_SOURCES = $(SRCS) libaria2c_a_SOURCES = $(SRCS)
aria2c_LDADD = libaria2c.a @LIBINTL@ @ALLOCA@ @LIBGNUTLS_LIBS@\ aria2c_LDADD = libaria2c.a @LIBINTL@ @ALLOCA@ @LIBGNUTLS_LIBS@\

View File

@ -36,10 +36,10 @@
#define _D_NAME_MATCH_OPTION_HANDLER_H_ #define _D_NAME_MATCH_OPTION_HANDLER_H_
#include "OptionHandler.h" #include "OptionHandler.h"
#include "DlAbortEx.h"
#include "StringFormat.h" #include "StringFormat.h"
#include "A2STR.h" #include "A2STR.h"
#include "Util.h" #include "Util.h"
#include "OptionHandlerException.h"
#include <strings.h> #include <strings.h>
#include <algorithm> #include <algorithm>
#include <sstream> #include <sstream>
@ -87,10 +87,11 @@ public:
try { try {
parseArg(option, arg); parseArg(option, arg);
} catch(Exception& e) { } catch(Exception& e) {
throw DlAbortEx throw OptionHandlerException
(StringFormat("Exception occurred while processing option %s", (StringFormat("Exception occurred while processing option %s:",
_optName.c_str()).str(), e); _optName.c_str()).str(),
} _optName, e);
}
} }
virtual bool hasTag(const std::string& tag) const virtual bool hasTag(const std::string& tag) const

View File

@ -0,0 +1,69 @@
/* <!-- copyright */
/*
* aria2 - The high speed download utility
*
* Copyright (C) 2006 Tatsuhiro Tsujikawa
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of portions of this program with the
* OpenSSL library under certain conditions as described in each
* individual source file, and distribute linked combinations
* including the two.
* You must obey the GNU General Public License in all respects
* for all of the code used other than OpenSSL. If you modify
* file(s) with this exception, you may extend this exception to your
* version of the file(s), but you are not obligated to do so. If you
* do not wish to do so, delete this exception statement from your
* version. If you delete this exception statement from all source
* files in the program, then also delete it here.
*/
/* copyright --> */
#ifndef _D_OPTION_HANDLER_EXCEPTION_H_
#define _D_OPTION_HANDLER_EXCEPTION_H_
#include "FatalException.h"
namespace aria2 {
class OptionHandlerException:public FatalException {
private:
std::string _optName;
protected:
virtual SharedHandle<Exception> copy() const
{
SharedHandle<Exception> e(new OptionHandlerException(*this));
return e;
}
public:
OptionHandlerException(const std::string& msg, const std::string& optName):
FatalException(msg), _optName(optName) {}
OptionHandlerException(const std::string& msg, const std::string& optName,
const Exception& cause):
FatalException(msg, cause), _optName(optName) {}
OptionHandlerException(const OptionHandlerException& e):
FatalException(e),
_optName(e._optName) {}
virtual ~OptionHandlerException() throw() {}
const std::string& getOptionName() const throw() { return _optName; }
};
} // namespace aria2
#endif // _D_OPTION_HANDLER_EXCEPTION_EX_H_

View File

@ -45,6 +45,7 @@
#include "help_tags.h" #include "help_tags.h"
#include "File.h" #include "File.h"
#include "StringFormat.h" #include "StringFormat.h"
#include "OptionHandlerException.h"
#include <cstdlib> #include <cstdlib>
#include <cstring> #include <cstring>
#include <fstream> #include <fstream>
@ -518,6 +519,12 @@ Option* option_processing(int argc, char* const argv[])
} }
try { try {
oparser.parse(op, cmdstream); oparser.parse(op, cmdstream);
} catch(OptionHandlerException& e) {
std::cerr << e.stackTrace() << "\n"
<< "Usage:\n"
<< oparser.findByName(e.getOptionName())->getDescription()
<< std::endl;
exit(EXIT_FAILURE);
} catch(Exception& e) { } catch(Exception& e) {
std::cerr << e.stackTrace() << std::endl; std::cerr << e.stackTrace() << std::endl;
showUsage(TAG_HELP, oparser); showUsage(TAG_HELP, oparser);