commit - b79428b4aec5e99d9c0f1dcc07fe677c2679cf4a
commit + 66390331e836daad55adb33b41b8eecee0a4fd6b
blob - 2ab6b9e65216392e7300fb04a6f2f76a3c4d1ba2
blob + ca6ddb5d3b7b497dbbb5dc1ca18cb8fa9fc19d81
--- rene.c
+++ rene.c
+#include <errno.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
-int interactive = 0;
-int noact = 0;
-int nooverride = 0;
-int replaceall = 0;
-int replacelast = 0;
-int verbose = 0;
+#define O_INTERACTIVE 1
+#define O_NOACT (1<<1)
+#define O_NOOVERRIDE (1<<2)
+#define O_REPLACEALL (1<<3)
+#define O_REPLACELAST (1<<4)
+#define O_VERBOSE (1<<5)
-void
-usage(void)
-{
- fprintf(stderr, "usage: rene [-ailnov] from to file ...\n");
- exit(EXIT_FAILURE);
-}
+uint8_t opts;
-char *rene;
-
void
-err(const char *fmt, ...)
+warn(const char *fmt, ...)
{
- fprintf(stderr, "%s: ", rene);
+ char *w = strerror(errno);
+ fputs("rene: ", stderr);
if (fmt != NULL) {
va_list argp;
va_start(argp, fmt);
vfprintf(stderr, fmt, argp);
va_end(argp);
}
- fprintf(stderr, "\n");
+ fprintf(stderr, ": %s\n", w);
}
int
return 0;
int fromlen = strlen(from);
int count = 1;
- if (replacelast || replaceall) {
+ if (opts & O_REPLACELAST || opts & O_REPLACEALL) {
char *temp = p;
while (temp) {
temp = strstr(temp+fromlen, from);
- count = (replaceall && temp) ? count + 1 : count;
- p = (replacelast && temp) ? temp : p;
+ count = (opts & O_REPLACEALL && temp) ? count + 1 :
+ count;
+ p = (opts & O_REPLACELAST && temp) ? temp : p;
}
}
- if (!(*new = malloc(strlen(s) + strlen(to)*count - fromlen*count + 1))) {
- err("%s: couldn't allocate memory", s);
+ if (!(*new =
+ malloc(strlen(s) + strlen(to)*count - fromlen*count + 1))) {
+ warn("malloc");
return 0;
}
for (; *top != '\0'; *newp++ = *top++)
;
s += fromlen;
- p = replaceall ? strstr(s, from) : strchr(s, '\0');
+ p = opts & O_REPLACEALL ? strstr(s, from) : strchr(s, '\0');
p = p ? p : strchr(s, '\0');
for (; s != p; *newp++ = *s++)
;
char *new = NULL;
if (!strrep(from, to, f, &new))
return;
- if ((nooverride || interactive) && access(new, F_OK) == 0)
- yes = nooverride ? 0 : ask(f, new);
- if (yes && !noact)
- yes -= rename(f, new);
- if (verbose && yes)
+ if ((opts & O_NOOVERRIDE || opts & O_INTERACTIVE) &&
+ access(new, F_OK) == 0)
+ yes = opts & O_NOOVERRIDE ? 0 : ask(f, new);
+ if (yes && !(opts & O_NOACT) && !(yes += rename(f, new)))
+ warn("rename");
+ if (opts & O_VERBOSE && yes)
printf("%s -> %s\n", f, new);
- free(new);
}
+void
+usage(void)
+{
+ fputs("usage: rene [-ailnov] from to file ...\n", stderr);
+ exit(EXIT_FAILURE);
+}
+
int
main(int argc, char *argv[])
{
char *from, *to;
- rene = argv[0];
int c;
while ((c = getopt(argc, argv, "ailnov")) != -1) {
switch (c) {
case 'a':
- replaceall = 1;
+ opts |= O_REPLACEALL;
break;
case 'i':
- interactive = 1;
+ opts |= O_INTERACTIVE;
break;
case 'l':
- replacelast = 1;
+ opts |= O_REPLACELAST;
break;
case 'n':
- noact = 1;
+ opts |= O_NOACT;
break;
case 'o':
- nooverride = 1;
+ opts |= O_NOOVERRIDE;
break;
case 'v':
- verbose = 1;
+ opts |= O_VERBOSE;
break;
default:
usage();