Fix compilation warnings

This commit is contained in:
Danny Robson 2013-02-27 15:11:05 +11:00
parent d17f55cba8
commit a64df2677c
2 changed files with 20 additions and 17 deletions

View File

@ -55,8 +55,8 @@ AS_CXX_COMPILER_FLAG([-Wsign-conversion], [WARNING_FLAGS="$WARNING_FLAGS -Wsig
AS_CXX_COMPILER_FLAG([-Wtype-limits], [WARNING_FLAGS="$WARNING_FLAGS -Wtype-limits"])
AS_CXX_COMPILER_FLAG([-Wfloat-equal], [WARNING_FLAGS="$WARNING_FLAGS -Wfloat-equal"])
#AS_CXX_COMPILER_FLAG([-Wswitch-default], [COMMON_CFLAGS="$COMMON_CFLAGS -Wswitch-default"])
AS_CXX_COMPILER_FLAG([-Wswitch-enum], [COMMON_CFLAGS="$COMMON_CFLAGS -Wswitch-enum"])
AS_CXX_COMPILER_FLAG([-Wswitch-default], [COMMON_CFLAGS="$COMMON_CFLAGS -Wswitch-default"])
#AS_CXX_COMPILER_FLAG([-Wswitch-enum], [COMMON_CFLAGS="$COMMON_CFLAGS -Wswitch-enum"])
#AS_CXX_COMPILER_FLAG([-Wzero-as-null-pointer-constant], [WARNING_FLAGS="$WARNING_FLAGS -Wzero-as-null-pointer-constant"])

View File

@ -137,7 +137,7 @@ bytesoption::bytesoption (char _letter,
bytestype _type,
bytesmodifier _modifier,
bool _required):
valueoption<size_t> (_letter, _name, _desc, _data),
valueoption<size_t> (_letter, _name, _desc, _data, _required),
m_type (_type),
m_modifier (_modifier)
{ ; }
@ -169,10 +169,11 @@ bytesoption::type_from_character (char c) {
case 'k':
case 'K':
return BYTES_KILO;
}
default:
throw domain_error("Invalid magnitude specifier");
}
}
void
@ -185,19 +186,21 @@ bytesoption::execute (const std::string& data) {
try {
bytesmodifier modifier = m_modifier;
off_t cursor = data.size () - 1;
size_t cursor = data.size () - 1;
// Consume an optional trailing `byte' type
if (data[cursor] == 'B' || data[cursor] == 'b') {
if (--cursor < 0)
if (cursor == 0)
throw invalid_argument ("Size is too short");
--cursor;
}
// Check if we explicitly request base2
if (data[cursor] == 'i') {
modifier = BYTES_BASE2;
if (--cursor < 0)
if (cursor == 0)
throw invalid_argument("Size is too short");
--cursor;
}
// Determine what constant factor is needed for the raw size
@ -213,7 +216,7 @@ bytesoption::execute (const std::string& data) {
break;
default:
abort ();
unreachable ();
}
// Find the difference in magnitude between what is desired, and what
@ -234,7 +237,6 @@ bytesoption::execute (const std::string& data) {
// ... so that we can easily decrement the cursor without special logic
// after reading the specifiers.
--cursor;
assert (cursor >= 0);
multiplier = std::pow (modifier_factor, (int)specified);
get_arg (data.substr(0, cursor + 1), m_data);
@ -401,8 +403,9 @@ processor::parse_long (int pos, int argc, const char ** argv) {
// If there's an equals it's has a value to extract
const char *data = strchr (arg, '=');
if (data) {
arg = strndup (arg, data - arg); // Copy just the arg name
data++; // Skip the '='
arg = strndup (arg, sign_cast<size_t> (data - arg));
//arg = strndup (arg, data - arg); // Copy just the arg name
++data; // Skip the '='
}
option *o = m_longopt[arg];
@ -445,7 +448,7 @@ processor::parse_args (int argc, const char ** argv) {
const unsigned int FIRST_ARGUMENT = 1;
try {
for (int i = FIRST_ARGUMENT; i < argc; ++i) {
for (size_t i = FIRST_ARGUMENT; i < sign_cast<unsigned> (argc); ++i) {
// An argument must begin with a dash, if not we've reached the
// end of the argument lists or we have a parsing error.
if (argv[i][0] != '-')
@ -548,7 +551,7 @@ processor::remove_option (const char *name) {
/* Parse args from a stream, one arg per line
*/
void parse_stream (std::istream & is) {
unique_ptr<char[]> buffer (new char [MAX_CHUNK_LENGTH + 1]);
}
//void parse_stream (std::istream & is) {
// unique_ptr<char[]> buffer (new char [MAX_CHUNK_LENGTH + 1]);
//}