X-Git-Url: http://gitweb.hugovil.com/?a=blobdiff_plain;f=src%2Fcommon%2Foptions.c;h=c3d91d17e41e7d23b2396ea5f637b82b0616951e;hb=121bcb38f29409f10de63a68d86620c4beb75c97;hp=420cc85e5880ef6fedbe9ef76c347690f1b8a234;hpb=1eb382f72510d50b3636fb88c4bfaf17183672b6;p=emu8051.git diff --git a/src/common/options.c b/src/common/options.c index 420cc85..c3d91d1 100644 --- a/src/common/options.c +++ b/src/common/options.c @@ -3,17 +3,13 @@ * * Copyright (C) 2011 Hugo Villeneuve * - * 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 file is released under the GPLv2 */ #if HAVE_CONFIG_H # include "config.h" #endif -#include #include #include #include @@ -31,41 +27,39 @@ const char *argp_program_version = PACKAGE_VERSION; const char *argp_program_bug_address = PACKAGE_BUGREPORT; -#define PACKAGE_DOC_LENGTH 128 - -/* Program documentation. */ -static char str_doc[PACKAGE_DOC_LENGTH]; +/* + * Program documentation. + * Adjacent string constants are concatenated as one string constant. + */ +static const char str_doc[] = PACKAGE_NAME " -- " PACKAGE_DESCRIPTION; -/* How many arguments we accept. */ +/* How many non-option arguments we accept. */ #define ARGS_COUNT 1 -/* A description of the arguments we accept. */ +/* A description of the non-option arguments we accept. */ static const char args_doc[] = "[FILENAME]"; /* The options we understand. */ static struct argp_option argp_options[] = { - {"debug", 'd', "level", 0, "Produce debugging output" }, - {"pram", 'p', "size", 0, "Set program memory size" }, - {"xram", 'x', "size", 0, "Set external ram size (default is 1024)" }, - {"stop", 's', "addr", 0, "Automatically run program and stop at address" }, - { 0 } + {"debug", 'd', "level", 0, "Produce debugging output", 0}, + {"geometry", 'g', "pos", 0, "Set geometry", 0}, + {"pram", 'p', "size", 0, "Set program memory size", 0}, + {"xram", 'x', "size", 0, + "Set external ram size (default is 1024)", 0}, + {"stop", 's', "addr", 0, + "Automatically run program and stop at address", 0}, + {NULL, 0, NULL, 0, NULL, 0} }; struct options_t options; -const char * -get_package_description(void) -{ - return "Emulator for 8051 family microcontrollers"; -} - static void decode_debug_option(char *arg, struct argp_state *state) { char *endptr; int log_level; - log_level = strtol(arg, &endptr, 0); + log_level = (int) strtol(arg, &endptr, 0); if (*endptr != '\0') { log_err("Invalid log level"); @@ -93,13 +87,13 @@ decode_memory_size(char *arg, struct argp_state *state, int memid) else if (memid == EXT_MEM_ID) dest = &options.xram_size; else - exit(1); /* Programming error. */ + exit(EXIT_FAILURE); /* Programming error. */ /* * Sizes versus max memory sizes will be checked when calling * memory_init(). */ - *dest = strtol(arg, &endptr, 0); + *dest = (int) strtol(arg, &endptr, 0); if (*endptr != '\0') { log_err("Invalid memory size"); @@ -112,7 +106,7 @@ decode_address(char *arg, struct argp_state *state, uint16_t *dest) { char *endptr; - *dest = strtol(arg, &endptr, 0); + *dest = (uint16_t) strtol(arg, &endptr, 0); if (*endptr != '\0') { log_err("Invalid address"); @@ -128,6 +122,9 @@ parse_opt(int key, char *arg, struct argp_state *state) case 'd': decode_debug_option(arg, state); break; + case 'g': + options.g = arg; + break; case 'i': decode_memory_size(arg, state, INT_MEM_ID); break; @@ -162,17 +159,18 @@ parse_opt(int key, char *arg, struct argp_state *state) } /* Our argp parser. */ -static struct argp argp = { argp_options, parse_opt, args_doc, str_doc }; +static struct argp argp = {argp_options, parse_opt, args_doc, str_doc, + NULL, NULL, NULL}; /* Initializes the different options passed as arguments on the command line. */ void parse_command_line_options(int argc, char *argv[]) { - snprintf(str_doc, PACKAGE_DOC_LENGTH, "%s -- %s", PACKAGE_NAME, - get_package_description()); + error_t rc; /* Setting default values. */ options.filename = NULL; + options.g = NULL; options.pram_size = PGM_MEM_DEFAULT_SIZE; options.iram_size = INT_MEM_MAX_SIZE; options.xram_size = EXT_MEM_DEFAULT_SIZE; @@ -180,5 +178,7 @@ parse_command_line_options(int argc, char *argv[]) options.stop_address = 0; /* 0 means stop address is disabled. */ /* Parse our arguments. */ - argp_parse(&argp, argc, argv, 0, 0, NULL); + rc = argp_parse(&argp, argc, argv, 0, 0, NULL); + if (rc != 0) + log_fail("Failure to parse command line arguments"); }