Move to getopt
- everything is single-letter now
This commit is contained in:
parent
efd1d76428
commit
b7b16197f9
@ -13,6 +13,7 @@ struct config {
|
||||
int force_binary;
|
||||
bool literal;
|
||||
bool pager;
|
||||
char *name;
|
||||
bool has_read_stdin;
|
||||
};
|
||||
|
||||
|
141
src/lib/arg.c
141
src/lib/arg.c
@ -1,30 +1,34 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "arg.h"
|
||||
#include "util.h"
|
||||
|
||||
#define LAT_USAGE "usage: lat [-cntblpVh] [file...]"
|
||||
#define LAT_SHORT_ARGS "cltbrpn:Vh"
|
||||
#define LAT_USAGE "usage: lat [-cltbrpnVh] [file...]"
|
||||
|
||||
struct config conf;
|
||||
|
||||
void help(void) {
|
||||
printf("lat | lazy cat - a cat clone with some quality-of-life "
|
||||
"embellishments\n\n");
|
||||
|
||||
printf("%s\n\n", LAT_USAGE);
|
||||
printf("options:\n"
|
||||
"\t-c, --color\t toggle color\n"
|
||||
"\t-n, --lines\t toggle line numbers\n"
|
||||
"\t-t, --headers\t toggle file info headers\n"
|
||||
"\t-b, --binary\t toggle binary mode, -b forces binary and -bb forces "
|
||||
"NOT binary\n"
|
||||
"\t-l, --literal\t print everything to stdout (or equivalent)\n"
|
||||
"\t-p, --pager\t print file with the pager (uses less)\n"
|
||||
"\t-V, --version\t show program version\n"
|
||||
"\t-h, --help\t display this help text (--help shows additional "
|
||||
"info)\n\n");
|
||||
printf(
|
||||
"options:\n"
|
||||
"\t-c\t toggle color\n"
|
||||
"\t-l\t toggle line numbers\n"
|
||||
"\t-t\t toggle file info headers\n"
|
||||
"\t-b\t toggle binary mode, -b forces binary and -bb forces NOT binary\n"
|
||||
"\t-r\t print everything to stdout (or equivalent)\n"
|
||||
"\t-p\t print file with the pager (uses less)\n"
|
||||
"\t-n\t set the name of the file in the title\n"
|
||||
"\t-V\t show program version\n"
|
||||
"\t-h\t display this help text\n\n");
|
||||
printf("environment:\n"
|
||||
"\tNO_COLOR, see https://no-color.org/\n\n");
|
||||
"\tNO_COLOR, see https://no-color.org/\n");
|
||||
}
|
||||
|
||||
void examples(void) {
|
||||
@ -44,82 +48,27 @@ void examples(void) {
|
||||
"as a binary file and print it in the pager\n"
|
||||
"\tcurl example.com | lat\n\t\t pipe the results of 'curl example.com' "
|
||||
"into lat\n"
|
||||
"\tfzf --preview 'lat -l {}'\n\t\t use lat as the file viewer in fzf\n"
|
||||
);
|
||||
"\tfzf --preview 'lat -l {}'\n\t\t use lat as the file viewer in fzf\n");
|
||||
}
|
||||
|
||||
void version(void) {
|
||||
printf("lat - v%s built %s at %s\n", LAT_VERSION, __DATE__, __TIME__);
|
||||
}
|
||||
|
||||
struct config conf;
|
||||
void argerr(char *r, char *arg) {
|
||||
printf("lat: %s '%s'\n\n", r, arg);
|
||||
|
||||
printf("%s\n", LAT_USAGE);
|
||||
void argerr(void) {
|
||||
printf("\n%s\n", LAT_USAGE);
|
||||
printf("run '--help' for more information\n");
|
||||
exit(EXIT_FAILURE);
|
||||
}
|
||||
|
||||
void parselongarg(char *arg) {
|
||||
if (strcmp(arg, "--color") == 0) {
|
||||
conf.color = !conf.color;
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--lines") == 0) {
|
||||
conf.lines = !conf.lines;
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--headers") == 0) {
|
||||
conf.headers = !conf.headers;
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--binary") == 0) {
|
||||
if (conf.force_binary < 0)
|
||||
conf.force_binary = 1;
|
||||
else
|
||||
conf.force_binary = !conf.force_binary;
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--literal") == 0) {
|
||||
conf.literal = !conf.literal;
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--pager") == 0) {
|
||||
conf.pager = !conf.pager;
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--help") == 0) {
|
||||
help();
|
||||
examples();
|
||||
exit(EXIT_SUCCESS);
|
||||
return;
|
||||
}
|
||||
|
||||
if (strcmp(arg, "--version") == 0) {
|
||||
version();
|
||||
exit(EXIT_SUCCESS);
|
||||
return;
|
||||
}
|
||||
|
||||
argerr("unrecognized arg", arg);
|
||||
}
|
||||
|
||||
void parseshortarg(char *arg) {
|
||||
size_t i = 1;
|
||||
while (arg[i] != '\0') {
|
||||
char c = arg[i];
|
||||
switch (c) {
|
||||
int parseargs(int argc, char *argv[]) {
|
||||
char opt;
|
||||
while ((opt = getopt(argc, argv, LAT_SHORT_ARGS)) != -1) {
|
||||
switch (opt) {
|
||||
case 'c':
|
||||
conf.color = !conf.color;
|
||||
break;
|
||||
case 'n':
|
||||
case 'l':
|
||||
conf.lines = !conf.lines;
|
||||
break;
|
||||
case 't':
|
||||
@ -131,12 +80,15 @@ void parseshortarg(char *arg) {
|
||||
else
|
||||
conf.force_binary = !conf.force_binary;
|
||||
break;
|
||||
case 'l':
|
||||
case 'r':
|
||||
conf.literal = !conf.literal;
|
||||
break;
|
||||
case 'p':
|
||||
conf.pager = !conf.pager;
|
||||
break;
|
||||
case 'n':
|
||||
conf.name = optarg;
|
||||
break;
|
||||
case 'V':
|
||||
version();
|
||||
exit(EXIT_SUCCESS);
|
||||
@ -145,39 +97,10 @@ void parseshortarg(char *arg) {
|
||||
help();
|
||||
exit(EXIT_SUCCESS);
|
||||
break;
|
||||
default: {
|
||||
char *str = malloc(2);
|
||||
str[0] = c;
|
||||
str[1] = '\0';
|
||||
argerr("unrecognized flag", str);
|
||||
free(str);
|
||||
default:
|
||||
argerr();
|
||||
break;
|
||||
}
|
||||
}
|
||||
i++;
|
||||
}
|
||||
}
|
||||
|
||||
int parseargs(int argc, char *argv[]) {
|
||||
int i;
|
||||
for (i = 1; i < argc; i++) { // offset for argv[0]
|
||||
char *arg = argv[i];
|
||||
|
||||
if (arg[0] == '-' && arg[1] == '\0') {
|
||||
return i;
|
||||
}
|
||||
|
||||
if (arg[0] == '-') {
|
||||
if (arg[1] == '-') {
|
||||
parselongarg(arg);
|
||||
continue;
|
||||
}
|
||||
|
||||
parseshortarg(arg);
|
||||
} else {
|
||||
return i;
|
||||
}
|
||||
}
|
||||
|
||||
return i;
|
||||
return optind;
|
||||
}
|
||||
|
16
src/main.c
16
src/main.c
@ -1,7 +1,5 @@
|
||||
#include <libgen.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
#include "arg.h"
|
||||
@ -44,13 +42,13 @@ void run(FILE *fp, char *filename, bool tty) {
|
||||
f.binary = false;
|
||||
}
|
||||
|
||||
char *name = conf.name == NULL ? filename : conf.name;
|
||||
if (conf.headers) {
|
||||
char *addon = f.binary ? "<binary>" : "";
|
||||
if (conf.stdin && !conf.pager)
|
||||
fprintf(err, "\x1b[2K\r%s%s%s%s\n", invert_t, basename(filename), addon,
|
||||
reset);
|
||||
fprintf(err, "\x1b[2K\r%s%s%s%s\n", invert_t, name, addon, reset);
|
||||
else
|
||||
fprintf(err, "%s%s%s%s\n", invert_t, basename(filename), addon, reset);
|
||||
fprintf(err, "%s%s%s%s\n", invert_t, name, addon, reset);
|
||||
}
|
||||
|
||||
conf.process = (tty && !f.binary);
|
||||
@ -101,10 +99,13 @@ void initconf(void) {
|
||||
conf.has_read_stdin = false;
|
||||
conf.pager = false;
|
||||
conf.literal = false;
|
||||
|
||||
conf.process = true;
|
||||
conf.headers = true;
|
||||
conf.color = true;
|
||||
conf.lines = true;
|
||||
|
||||
conf.name = NULL;
|
||||
}
|
||||
|
||||
void clearstdin(void) {
|
||||
@ -141,6 +142,10 @@ int main(int argc, char *argv[]) {
|
||||
conf.has_read_stdin = true;
|
||||
conf.stdin = true;
|
||||
run(stdin, "stdin", tty);
|
||||
if (tty && (i + 1 != argc)) {
|
||||
fprintf(err, "\n"); // separate concurrent files in tty
|
||||
}
|
||||
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -151,7 +156,6 @@ int main(int argc, char *argv[]) {
|
||||
run(fp, argv[i], tty);
|
||||
fclose(fp);
|
||||
if (tty && (i + 1 != argc)) {
|
||||
printf("offset: %d argc: %d\n", i, argc);
|
||||
fprintf(err, "\n"); // separate concurrent files in tty
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user