migrate to new arg.h

This commit is contained in:
Markus Teich 2017-09-02 01:24:47 +02:00
parent 6df3d039a0
commit 278b8da820

98
arg.h
View File

@ -1,63 +1,49 @@
/* /*
* Copy me if you can. * ISC-License
* by 20h *
* Copyright 2017 Laslo Hunhold <dev@frign.de>
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/ */
#ifndef ARG_H
#ifndef ARG_H__ #define ARG_H
#define ARG_H__
extern char *argv0; extern char *argv0;
/* use main(int argc, char *argv[]) */ /* int main(int argc, char *argv[]) */
#define ARGBEGIN for (argv0 = *argv, argv++, argc--;\ #define ARGBEGIN for (argv0 = *argv, *argv ? (argc--, argv++) : ((void *)0); \
argv[0] && argv[0][0] == '-'\ *argv && (*argv)[0] == '-' && (*argv)[1]; argc--, argv++) { \
&& argv[0][1];\ int i_, argused_; \
argc--, argv++) {\ if ((*argv)[1] == '-' && !(*argv)[2]) { \
char argc_;\ argc--, argv++; \
char **argv_;\ break; \
int brk_;\ } \
if (argv[0][1] == '-' && argv[0][2] == '\0') {\ for (i_ = 1, argused_ = 0; (*argv)[i_]; i_++) { \
argv++;\ switch((*argv)[i_])
argc--;\ #define ARGEND if (argused_) { \
break;\ if ((*argv)[i_ + 1]) { \
}\ break; \
for (brk_ = 0, argv[0]++, argv_ = argv;\ } else { \
argv[0][0] && !brk_;\ argc--, argv++; \
argv[0]++) {\ break; \
if (argv_ != argv)\ } \
break;\ } \
argc_ = argv[0][0];\ } \
switch (argc_) }
#define ARGC() ((*argv)[i_])
/* Handles obsolete -NUM syntax */ #define ARGF_(x) (((*argv)[i_ + 1]) ? (argused_ = 1, &((*argv)[i_ + 1])) : \
#define ARGNUM case '0':\ (*(argv + 1)) ? (argused_ = 1, *(argv + 1)) : (x))
case '1':\ #define EARGF(x) ARGF_(((x), exit(1), (char *)0))
case '2':\ #define ARGF() ARGF_((char *)0)
case '3':\
case '4':\
case '5':\
case '6':\
case '7':\
case '8':\
case '9'
#define ARGEND }\
}
#define ARGC() argc_
#define ARGNUMF(base) (brk_ = 1, estrtol(argv[0], (base)))
#define EARGF(x) ((argv[0][1] == '\0' && argv[1] == NULL)?\
((x), abort(), (char *)0) :\
(brk_ = 1, (argv[0][1] != '\0')?\
(&argv[0][1]) :\
(argc--, argv++, argv[0])))
#define ARGF() ((argv[0][1] == '\0' && argv[1] == NULL)?\
(char *)0 :\
(brk_ = 1, (argv[0][1] != '\0')?\
(&argv[0][1]) :\
(argc--, argv++, argv[0])))
#endif #endif