X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fargs.h;h=f8cda88b6d51aa79b861f9a0e9a20e5f8126eac8;hb=5c59d829bdc0d6a15bfc28a664c6d309a7e80edb;hp=cc9a58d3f300142bbb7f738126de510171f77b61;hpb=9d85e6224fa9ac5b4c54e7af8ea3b7c9271c2680;p=swftools.git diff --git a/lib/args.h b/lib/args.h index cc9a58d..f8cda88 100644 --- a/lib/args.h +++ b/lib/args.h @@ -15,48 +15,69 @@ extern int args_callback_longoption(char*,char*); extern int args_callback_command(char*,char*); extern void args_callback_usage(char*name); -int argn; -char**argv; +//int argn; +//char**argv; void processargs(int argn2,char**argv2) { int t; if(argn2==1) { - args_callback_usage(argv2[0]); - exit(1); + args_callback_usage(argv2[0]); + exit(1); } for(t=1;tshortoption) { if(!strcmp(options->longoption, name)) { - char*tmp = (char*)malloc(strlen(options->shortoption) - +(equal?strlen(equal)+2:2)); - strcpy(tmp, options->shortoption); - if(equal) { - //strcpy(&tmp[strlen(tmp)], equal); - int ret = args_callback_option(tmp, equal); - return 0; - } - return args_callback_option(tmp,val); - } - options++; + char*tmp = (char*)malloc(strlen(options->shortoption) + +(equal?strlen(equal)+2:2)); + strcpy(tmp, options->shortoption); + if(equal) { + //strcpy(&tmp[strlen(tmp)], equal); + int ret = args_callback_option(tmp, equal); + if(!ret) { + fprintf(stderr, "Warning: Option --%s takes no parameter.\n", name); + } + return 0; + } + return args_callback_option(tmp,val); + } + options++; } fprintf(stderr, "Unknown option: --%s\n", name); exit(1); } +/* check whether the value t is in a given range. + examples: 3 is in range 1-10: true + 7 is in range 2-4,6,8-10: false + 9 is in range 1,2,3-12: true +*/ +char is_in_range(int t, char*irange) +{ + char*pos = irange; + char*digits; + int num; + char range = 0; + int last=0; + char tmp; + + if(!irange) // no range resembles (-OO,OO) + return 1; + + while(*pos) + { + while(*pos == ' ' || *pos == '\r' || *pos == '\n' || *pos == '\t') + pos++; + + digits = pos; + while(*digits>='0' && *digits<='9') + digits++; + if(digits == pos) { + fprintf(stderr, "Error: \"%s\" is not a valid format (digit expected)\n",irange); + exit(1); + } + + tmp=*digits;*digits=0; + num = atoi(pos); + *digits=tmp; + pos = digits; + + while(*pos == ' ' || *pos == '\r' || *pos == '\n' || *pos == '\t') + pos++; + + if(range && last<=t && num>=t) + return 1; + if(range) { + range = 0; + if(*pos) + pos ++; + continue; + } + + if(*pos=='-') + { + if(range) { + fprintf(stderr, "Error: \"%s\" is not a valid format (too many '-'s)\n",irange); + exit(1); + } + last = num; + range = 1; + if(*pos) + pos ++; + continue; + } + else + { + /* if it isn't a '-', we assume it is a seperator like + ',', ';', ':', whatever. */ + if(t == num) + return 1; + if(*pos) + pos ++; + continue; + } + } + if(range && last<=t) + return 1; + return 0; +} + #endif //__args_h__