summaryrefslogtreecommitdiff
path: root/misc/mmv/files/patch-mmv.c
blob: 025411be6a9637d466d80f1896a9cfac4a16be35 (plain) (blame)
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)