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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
--- src/id3tag.c
+++ src/id3tag.c
@@ -389,12 +389,20 @@
return(1);
}
+static void id3tag_sanitize (char *string)
+{
+ while ((string = strchr (string, '/')))
+ {
+ *string = '_';
+ }
+}
+
/* This function renames a file based on its tag in the given format */
int id3tag_rename( char *filename, char *format )
{
struct id3tag tag;
struct stat stbuf;
- char target_filename[80]="";
+ char target_filename[PATH_MAX]="";
char buffer[10]="";
char *tmp;
int i;
@@ -425,36 +433,42 @@
{
case 't':
strcat( target_filename, tag.title);
+ id3tag_sanitize (target_filename+i2);
i2=i2+strlen(tag.title);
i++;
break;
case 'a':
strcat( target_filename, tag.artist);
+ id3tag_sanitize (target_filename+i2);
i2=i2+strlen(tag.artist);
i++;
break;
case 'b':
strcat( target_filename, tag.album);
+ id3tag_sanitize (target_filename+i2);
i2=i2+strlen(tag.album);
i++;
break;
case 'c':
strcat( target_filename, tag.comment);
+ id3tag_sanitize (target_filename+i2);
i2=i2+strlen(tag.comment);
i++;
break;
case 'y':
strcat( target_filename, tag.year);
+ id3tag_sanitize (target_filename+i2);
i2=i2+strlen(tag.year);
i++;
break;
case 'g':
strcat( target_filename, id3tag_get_genre(tag.genre));
+ id3tag_sanitize (target_filename+i2);
i2=i2+strlen(id3tag_get_genre(tag.genre));
i++;
break;
@@ -521,9 +535,9 @@
int id3tag_sort( char *filename, char *rootdir, char *format_level1, char *format_level2 )
{
struct id3tag tag;
- char *dir_level1=NULL;
- char *dir_level2=NULL;
- char target_filename[80];
+ char *dir_level1=NULL, *dir_level1_sanitized;
+ char *dir_level2=NULL, *dir_level2_sanitized;
+ char source_filename[PATH_MAX], target_filename[PATH_MAX];
char dir_cur[80];
@@ -554,8 +568,10 @@
chdir(rootdir);
if( dir_level1[0] == '\0' )
dir_level1 = "Unknown";
- yamtlog("%s %s", "New directory: ", dir_level1);
- mkdir( dir_level1, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
+ dir_level1_sanitized = strdup (dir_level1);
+ id3tag_sanitize (dir_level1_sanitized);
+ yamtlog("%s %s", "New directory: ", dir_level1_sanitized);
+ mkdir( dir_level1_sanitized, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
/* Level 2 */
if( strcmp( format_level2, "Album") == 0 )
@@ -573,18 +589,24 @@
if( dir_level2[0] == '\0' )
dir_level2 = "Unknown";
- yamtlog("%s %s", "New directory: ", dir_level2);
+ dir_level2_sanitized = strdup (dir_level2);
+ id3tag_sanitize (dir_level2_sanitized);
+ yamtlog("%s %s", "New directory: ", dir_level2_sanitized);
/* Go into the previously created directory */
- chdir( dir_level1 );
- mkdir( dir_level2, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
+ chdir( dir_level1_sanitized );
+ mkdir( dir_level2_sanitized, S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH );
/* Move the file into the new (?) directory */
- sprintf( target_filename, "mv \"%s/%s\" \"%s%s/%s/%s\"", dir_cur, filename, rootdir, dir_level1, dir_level2, filename );
+ snprintf( source_filename, PATH_MAX, "%s/%s", dir_cur, filename );
+ snprintf( target_filename, PATH_MAX, "%s%s/%s/%s", rootdir, dir_level1_sanitized, dir_level2_sanitized, filename );
+
+ free (dir_level1_sanitized);
+ free (dir_level2_sanitized);
yamtlog("%s %s", "Sorted ", filename );
- system( target_filename );
+ rename( source_filename, target_filename );
/* if( (rename( filename, target_filename )) ) */
/* { */
|