summaryrefslogtreecommitdiff
path: root/st-0.8.5/arg.h
diff options
context:
space:
mode:
authorstkhan <personal@slickd.xyz>2022-05-19 19:43:34 +0000
committerstkhan <personal@slickd.xyz>2022-05-19 19:43:34 +0000
commitda4f635d6b7f6befd07942ca1d34bcb976dff66f (patch)
treec68ba19caba3fe902f3155a2738ba77280e342d9 /st-0.8.5/arg.h
parent1b1e0830abbf11284e5eca032b4111466be8ad0d (diff)
Added st 0.8.5, added part to makefile
Diffstat (limited to 'st-0.8.5/arg.h')
-rw-r--r--st-0.8.5/arg.h50
1 files changed, 50 insertions, 0 deletions
diff --git a/st-0.8.5/arg.h b/st-0.8.5/arg.h
new file mode 100644
index 0000000..a22e019
--- /dev/null
+++ b/st-0.8.5/arg.h
@@ -0,0 +1,50 @@
+/*
+ * Copy me if you can.
+ * by 20h
+ */
+
+#ifndef ARG_H__
+#define ARG_H__
+
+extern char *argv0;
+
+/* use main(int argc, char *argv[]) */
+#define ARGBEGIN for (argv0 = *argv, argv++, argc--;\
+ argv[0] && argv[0][0] == '-'\
+ && argv[0][1];\
+ argc--, argv++) {\
+ char argc_;\
+ char **argv_;\
+ int brk_;\
+ if (argv[0][1] == '-' && argv[0][2] == '\0') {\
+ argv++;\
+ argc--;\
+ break;\
+ }\
+ int i_;\
+ for (i_ = 1, brk_ = 0, argv_ = argv;\
+ argv[0][i_] && !brk_;\
+ i_++) {\
+ if (argv_ != argv)\
+ break;\
+ argc_ = argv[0][i_];\
+ switch (argc_)
+
+#define ARGEND }\
+ }
+
+#define ARGC() argc_
+
+#define EARGF(x) ((argv[0][i_+1] == '\0' && argv[1] == NULL)?\
+ ((x), abort(), (char *)0) :\
+ (brk_ = 1, (argv[0][i_+1] != '\0')?\
+ (&argv[0][i_+1]) :\
+ (argc--, argv++, argv[0])))
+
+#define ARGF() ((argv[0][i_+1] == '\0' && argv[1] == NULL)?\
+ (char *)0 :\
+ (brk_ = 1, (argv[0][i_+1] != '\0')?\
+ (&argv[0][i_+1]) :\
+ (argc--, argv++, argv[0])))
+
+#endif