Snapshot. Functionally complete, but doesn't like missing message
catalog on RedHat 5.2.
This commit is contained in:
parent
5c8816c0b9
commit
bc6bf4ec9b
|
@ -0,0 +1,16 @@
|
||||||
|
include GNUmakevars
|
||||||
|
include GNUmakerules
|
||||||
|
|
||||||
|
all: scat
|
||||||
|
|
||||||
|
scat: scat.o
|
||||||
|
scat.o: scat.c scat.h
|
||||||
|
scat.h: scat.en.msg
|
||||||
|
gencat -H scat.h scat.en.cat scat.en.msg
|
||||||
|
|
||||||
|
%.cat: %.msg
|
||||||
|
gencat $@ $^
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f *.cat *.o scat core
|
||||||
|
install: $(BINDIR)/time_t
|
|
@ -0,0 +1,86 @@
|
||||||
|
#include <ctype.h>
|
||||||
|
#include <locale.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include <features.h>
|
||||||
|
#include <nl_types.h>
|
||||||
|
|
||||||
|
#include "scat.h"
|
||||||
|
|
||||||
|
char *cmnd;
|
||||||
|
nl_catd catalog;
|
||||||
|
|
||||||
|
void usage(void) {
|
||||||
|
fprintf(stderr,
|
||||||
|
catgets(catalog, MSG_Set, MSG_USAGE,
|
||||||
|
"Usage: %s [file ...]\n"),
|
||||||
|
cmnd);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void do_safecat(const char *filename) {
|
||||||
|
FILE *fp;
|
||||||
|
int c;
|
||||||
|
|
||||||
|
|
||||||
|
if (strcmp(filename, "-") == 0) {
|
||||||
|
fp = stdin;
|
||||||
|
} else {
|
||||||
|
if ((fp = fopen(filename, "r")) == NULL) {
|
||||||
|
fprintf(stderr,
|
||||||
|
catgets(catalog, MSG_Set, MSG_OPEN,
|
||||||
|
"%s: cannot open `%s' for reading: %s\n"),
|
||||||
|
cmnd, filename);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while ((c = getc(fp)) != EOF) {
|
||||||
|
if (isprint(c) || isspace(c)) {
|
||||||
|
if (putchar(c) == EOF) {
|
||||||
|
fprintf(stderr,
|
||||||
|
catgets(catalog, MSG_Set, MSG_WRITE,
|
||||||
|
"%s: cannot write stdout: %s\n"),
|
||||||
|
cmnd, filename);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (printf("\\x%02X", c) == EOF) {
|
||||||
|
fprintf(stderr,
|
||||||
|
catgets(catalog, MSG_Set, MSG_WRITE,
|
||||||
|
"%s: cannot write stdout: %s\n"),
|
||||||
|
cmnd, filename);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (ferror(fp)) {
|
||||||
|
fprintf(stderr,
|
||||||
|
catgets(catalog, MSG_Set, MSG_READ,
|
||||||
|
"%s: cannot read from `%s': %s\n"),
|
||||||
|
cmnd, filename);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
if (strcmp(filename, "-") == 0) {
|
||||||
|
} else {
|
||||||
|
fclose(fp);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main(int argc, char **argv) {
|
||||||
|
setlocale(LC_ALL, "");
|
||||||
|
|
||||||
|
catalog = catopen("scat", 0);
|
||||||
|
if (argc == 1) {
|
||||||
|
do_safecat("-");
|
||||||
|
} else {
|
||||||
|
int i;
|
||||||
|
for (i = 1; i < argc; i++) {
|
||||||
|
do_safecat(argv[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
$set MSG_
|
||||||
|
USAGE Usage: %s [files]\n
|
||||||
|
OPEN %s: cannot open `%s' for reading: %s\n
|
||||||
|
WRITE %s: cannot write to stdout: %s\n
|
||||||
|
READ %s: cannot read from `%s': %s\n
|
Loading…
Reference in New Issue