1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
--- mmv.c.orig 2017-10-24 14:25:26 UTC
+++ mmv.c
@@ -73,7 +73,8 @@ Use -- as the end of options.\n";
%s [-m|x|r|c|o|a|l%s] [-h] [-d|p] [-g|t] [-v|n] [from to]\n\
\n\
Use #[l|u]N in the ``to'' pattern to get the [lowercase|uppercase of the]\n\
-string matched by the N'th ``from'' pattern wildcard.\n\
+string matched by the N'th ``from'' pattern wildcard. = can be used\n\
+instead of #.\n\
\n\
A ``from'' pattern containing wildcards should be quoted when given\n\
on the command line. Also you may need to quote ``to'' pattern.\n\
@@ -977,6 +978,9 @@ static int parsepat()
lastname = p + 1;
break;
case '#':
+ case '=':
+ {
+ char index_char=c;
c = *(++p);
if (c == 'l' || c == 'u') {
#ifdef IS_MSDOS
@@ -987,8 +991,8 @@ static int parsepat()
#endif
}
if (!isdigit(c)) {
- printf("%s -> %s : expected digit (not '%c') after #.\n",
- from, to, c);
+ printf("%s -> %s : expected digit (not '%c') after %c.\n",
+ from, to, c, index_char);
return(-1);
}
for(x = 0; ;x *= 10) {
@@ -999,8 +1003,8 @@ static int parsepat()
p++;
}
if (x < 1 || x > totwilds) {
- printf("%s -> %s : wildcard #%d does not exist.\n",
- from, to, x);
+ printf("%s -> %s : wildcard %c%d does not exist.\n",
+ from, to, index_char, x);
return(-1);
}
#ifdef IS_MSDOS
@@ -1008,6 +1012,7 @@ static int parsepat()
havedot = 1;
#endif
break;
+ }
case ESC:
if ((c = *(++p)) == '\0') {
printf(TRAILESC, from, to, ESC);
@@ -1215,7 +1220,11 @@ static int keepmatch(ffrom, pathend, pk, needslash, di
getstat(pathbuf, ffrom);
if ((ffrom->fi_stflags & FI_ISDIR) ? !dirs : !fils)
#endif
+ {
+ if (verbose)
+ printf("ignoring directory %s\n", ffrom->fi_name);
return(0);
+ }
if (needslash) {
strcpy(pathend + *pk, SLASHSTR);
@@ -2030,7 +2039,7 @@ static void makerep()
repbad = 0;
p = fullrep;
for (pat = to, l = 0; (c = *pat) != '\0'; pat++, l++) {
- if (c == '#') {
+ if (c == '#' || c == '=') {
c = *(++pat);
#ifndef IS_MSDOS
if (c == 'l') {
@@ -2828,7 +2837,7 @@ static int getreply(m, failact)
static FILE *tty = NULL;
int c, r;
- fprintf(stderr, m);
+ fprintf(stderr, "%s", m);
if (tty == NULL && (tty = fopen(TTY, "r")) == NULL) {
fprintf(stderr, "Can not open %s to get reply.\n", TTY);
if (failact == -1)
|