wok-current diff busybox/stuff/busybox-1.10.3-patch.u @ rev 2953
Fix: Mitter (category)
author | Claudinei Pereira <claudinei@slitaz.org> |
---|---|
date | Fri May 08 11:59:03 2009 +0000 (2009-05-08) |
parents | |
children |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/busybox/stuff/busybox-1.10.3-patch.u Fri May 08 11:59:03 2009 +0000 1.3 @@ -0,0 +1,412 @@ 1.4 +--- busybox-1.10.3/editors/patch.c 2008-03-24 15:46:20.000000000 +0100 1.5 ++++ busybox-1.10.3/editors/patch.c 2008-03-24 15:46:20.000000000 +0100 1.6 +@@ -19,15 +19,11 @@ 1.7 + * - Reject file isnt saved 1.8 + */ 1.9 + 1.10 +-#include <getopt.h> 1.11 +- 1.12 + #include "libbb.h" 1.13 + 1.14 +-static unsigned int copy_lines(FILE *src_stream, FILE *dest_stream, const unsigned int lines_count) 1.15 ++static unsigned copy_lines(FILE *src_stream, FILE *dest_stream, unsigned lines_count) 1.16 + { 1.17 +- unsigned int i = 0; 1.18 +- 1.19 +- while (src_stream && (i < lines_count)) { 1.20 ++ while (src_stream && lines_count) { 1.21 + char *line; 1.22 + line = xmalloc_fgets(src_stream); 1.23 + if (line == NULL) { 1.24 +@@ -37,60 +33,70 @@ 1.25 + bb_perror_msg_and_die("error writing to new file"); 1.26 + } 1.27 + free(line); 1.28 +- 1.29 +- i++; 1.30 ++ lines_count--; 1.31 + } 1.32 +- return i; 1.33 ++ return lines_count; 1.34 + } 1.35 + 1.36 + /* If patch_level is -1 it will remove all directory names 1.37 + * char *line must be greater than 4 chars 1.38 + * returns NULL if the file doesnt exist or error 1.39 + * returns malloc'ed filename 1.40 ++ * NB: frees 1st argument! 1.41 + */ 1.42 + 1.43 +-static char *extract_filename(char *line, int patch_level) 1.44 ++static char *extract_filename(char *line, unsigned patch_level, const char *pat) 1.45 + { 1.46 +- char *temp, *filename_start_ptr = line + 4; 1.47 +- int i; 1.48 ++ char *temp = NULL, *filename_start_ptr = line + 4; 1.49 + 1.50 +- /* Terminate string at end of source filename */ 1.51 +- temp = strchrnul(filename_start_ptr, '\t'); 1.52 +- *temp = '\0'; 1.53 +- 1.54 +- /* Skip over (patch_level) number of leading directories */ 1.55 +- if (patch_level == -1) 1.56 +- patch_level = INT_MAX; 1.57 +- for (i = 0; i < patch_level; i++) { 1.58 +- temp = strchr(filename_start_ptr, '/'); 1.59 +- if (!temp) 1.60 +- break; 1.61 +- filename_start_ptr = temp + 1; 1.62 ++ if (strncmp(line, pat, 4) == 0) { 1.63 ++ /* Terminate string at end of source filename */ 1.64 ++ line[strcspn(line,"\t\n\r")] = '\0'; 1.65 ++ 1.66 ++ /* Skip over (patch_level) number of leading directories */ 1.67 ++ while (patch_level--) { 1.68 ++ temp = strchr(filename_start_ptr, '/'); 1.69 ++ if (!temp) 1.70 ++ break; 1.71 ++ filename_start_ptr = temp + 1; 1.72 ++ } 1.73 ++ temp = xstrdup(filename_start_ptr); 1.74 + } 1.75 +- 1.76 +- return xstrdup(filename_start_ptr); 1.77 ++ free(line); 1.78 ++ return temp; 1.79 + } 1.80 + 1.81 + int patch_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; 1.82 + int patch_main(int argc ATTRIBUTE_UNUSED, char **argv) 1.83 + { 1.84 +- int patch_level = -1; 1.85 +- char *patch_line; 1.86 +- int ret; 1.87 +- FILE *patch_file = NULL; 1.88 + struct stat saved_stat; 1.89 +- 1.90 ++ char *patch_line; 1.91 ++ FILE *patch_file; 1.92 ++ int patch_level; 1.93 ++ int ret = 0; 1.94 ++#define ENABLE_FEATURE_PATCH_REVERSE 1 1.95 ++#if ENABLE_FEATURE_PATCH_REVERSE 1.96 ++ char minus = '-'; 1.97 ++ char plus = '+'; 1.98 ++#else 1.99 ++ const char minus = '-'; 1.100 ++ const char plus = '+'; 1.101 ++#endif 1.102 ++ 1.103 ++ xfunc_error_retval = 2; 1.104 + { 1.105 +- char *p, *i; 1.106 +- ret = getopt32(argv, "p:i:", &p, &i); 1.107 +- if (ret & 1) 1.108 +- patch_level = xatol_range(p, -1, USHRT_MAX); 1.109 +- if (ret & 2) { 1.110 +- patch_file = xfopen(i, "r"); 1.111 +- } else { 1.112 +- patch_file = stdin; 1.113 +- } 1.114 +- ret = 0; 1.115 ++ const char *p = "-1"; 1.116 ++ const char *i = "-"; /* compat */ 1.117 ++#if ENABLE_FEATURE_PATCH_REVERSE 1.118 ++ if (getopt32(argv, "p:i:R", &p, &i) & 4) { 1.119 ++ minus = '+'; 1.120 ++ plus = '-'; 1.121 ++ } 1.122 ++#else 1.123 ++ getopt32(argv, "p:i:", &p, &i); 1.124 ++#endif 1.125 ++ patch_level = xatoi(p); /* can be negative! */ 1.126 ++ patch_file = xfopen_stdin(i); 1.127 + } 1.128 + 1.129 + patch_line = xmalloc_getline(patch_file); 1.130 +@@ -100,38 +106,38 @@ 1.131 + char *original_filename; 1.132 + char *new_filename; 1.133 + char *backup_filename; 1.134 +- unsigned int src_cur_line = 1; 1.135 +- unsigned int dest_cur_line = 0; 1.136 +- unsigned int dest_beg_line; 1.137 +- unsigned int bad_hunk_count = 0; 1.138 +- unsigned int hunk_count = 0; 1.139 +- char copy_trailing_lines_flag = 0; 1.140 ++ unsigned src_cur_line = 1; 1.141 ++ unsigned dest_cur_line = 0; 1.142 ++ unsigned dest_beg_line; 1.143 ++ unsigned bad_hunk_count = 0; 1.144 ++ unsigned hunk_count = 0; 1.145 ++ smallint copy_trailing_lines_flag = 0; 1.146 + 1.147 + /* Skip everything upto the "---" marker 1.148 + * No need to parse the lines "Only in <dir>", and "diff <args>" 1.149 + */ 1.150 +- while (patch_line && strncmp(patch_line, "--- ", 4) != 0) { 1.151 +- free(patch_line); 1.152 ++ do { 1.153 ++ /* Extract the filename used before the patch was generated */ 1.154 ++ original_filename = extract_filename(patch_line, patch_level, "--- "); 1.155 + patch_line = xmalloc_getline(patch_file); 1.156 +- } 1.157 +- /* FIXME: patch_line NULL check?? */ 1.158 ++ if (!patch_line) goto quit; 1.159 ++ } while (!original_filename); 1.160 + 1.161 +- /* Extract the filename used before the patch was generated */ 1.162 +- original_filename = extract_filename(patch_line, patch_level); 1.163 +- free(patch_line); 1.164 +- 1.165 +- patch_line = xmalloc_getline(patch_file); 1.166 +- /* FIXME: NULL check?? */ 1.167 +- if (strncmp(patch_line, "+++ ", 4) != 0) { 1.168 +- ret = 2; 1.169 +- bb_error_msg("invalid patch"); 1.170 +- continue; 1.171 ++ new_filename = extract_filename(patch_line, patch_level, "+++ "); 1.172 ++ if (!new_filename) { 1.173 ++ bb_error_msg_and_die("invalid patch"); 1.174 ++ } 1.175 ++#if ENABLE_FEATURE_PATCH_REVERSE 1.176 ++ if (plus != '+') { 1.177 ++ /* reverse patch */ 1.178 ++ char *tmp = original_filename; 1.179 ++ original_filename = new_filename; 1.180 ++ new_filename = tmp; 1.181 + } 1.182 +- new_filename = extract_filename(patch_line, patch_level); 1.183 +- free(patch_line); 1.184 ++#endif 1.185 + 1.186 + /* Get access rights from the file to be patched, -1 file does not exist */ 1.187 +- if (stat(new_filename, &saved_stat)) { 1.188 ++ if (stat(new_filename, &saved_stat) != 0) { 1.189 + char *line_ptr; 1.190 + /* Create leading directories */ 1.191 + line_ptr = strrchr(new_filename, '/'); 1.192 +@@ -140,132 +146,137 @@ 1.193 + bb_make_directory(new_filename, -1, FILEUTILS_RECUR); 1.194 + *line_ptr = '/'; 1.195 + } 1.196 +- dst_stream = xfopen(new_filename, "w+"); 1.197 + backup_filename = NULL; 1.198 ++ saved_stat.st_mode = 0644; 1.199 + } else { 1.200 +- backup_filename = xmalloc(strlen(new_filename) + 6); 1.201 +- strcpy(backup_filename, new_filename); 1.202 +- strcat(backup_filename, ".orig"); 1.203 ++ backup_filename = xasprintf("%s.orig", new_filename); 1.204 + xrename(new_filename, backup_filename); 1.205 +- dst_stream = xfopen(new_filename, "w"); 1.206 +- fchmod(fileno(dst_stream), saved_stat.st_mode); 1.207 + } 1.208 +- 1.209 +- if ((backup_filename == NULL) || stat(original_filename, &saved_stat)) { 1.210 +- src_stream = NULL; 1.211 +- } else { 1.212 +- if (strcmp(original_filename, new_filename) == 0) { 1.213 +- src_stream = xfopen(backup_filename, "r"); 1.214 +- } else { 1.215 +- src_stream = xfopen(original_filename, "r"); 1.216 +- } 1.217 ++ dst_stream = xfopen(new_filename, "w"); 1.218 ++ fchmod(fileno(dst_stream), saved_stat.st_mode); 1.219 ++ src_stream = NULL; 1.220 ++ 1.221 ++ if (backup_filename && !stat(original_filename, &saved_stat)) { 1.222 ++ src_stream = xfopen((strcmp(original_filename, new_filename)) ? 1.223 ++ original_filename : backup_filename, "r"); 1.224 + } 1.225 + 1.226 + printf("patching file %s\n", new_filename); 1.227 + 1.228 +- /* Handle each hunk */ 1.229 ++ /* Handle all hunks for this file */ 1.230 + patch_line = xmalloc_fgets(patch_file); 1.231 + while (patch_line) { 1.232 +- unsigned int count; 1.233 +- unsigned int src_beg_line; 1.234 +- unsigned int unused; 1.235 +- unsigned int hunk_offset_start = 0; 1.236 +- int hunk_error = 0; 1.237 +- 1.238 +- /* This bit should be improved */ 1.239 +- if ((sscanf(patch_line, "@@ -%d,%d +%d,%d @@", &src_beg_line, &unused, &dest_beg_line, &unused) != 4) && 1.240 +- (sscanf(patch_line, "@@ -%d,%d +%d @@", &src_beg_line, &unused, &dest_beg_line) != 3) && 1.241 +- (sscanf(patch_line, "@@ -%d +%d,%d @@", &src_beg_line, &dest_beg_line, &unused) != 3)) { 1.242 ++ unsigned count; 1.243 ++ unsigned src_beg_line; 1.244 ++ unsigned hunk_offset_start; 1.245 ++ unsigned src_last_line = 1; 1.246 ++#if ENABLE_FEATURE_PATCH_REVERSE 1.247 ++ unsigned dst_last_line = 1; 1.248 ++ 1.249 ++ if ((sscanf(patch_line, "@@ -%d,%d +%d,%d", &src_beg_line, &src_last_line, &dest_beg_line, &dst_last_line) < 3) && 1.250 ++ (sscanf(patch_line, "@@ -%d +%d,%d", &src_beg_line, &dest_beg_line, &dst_last_line) < 2)) { 1.251 + /* No more hunks for this file */ 1.252 + break; 1.253 + } 1.254 +- free(patch_line); 1.255 ++ if (plus != '+') { 1.256 ++ /* reverse patch */ 1.257 ++ unsigned tmp = src_last_line; 1.258 ++ src_last_line = dst_last_line; 1.259 ++ dst_last_line = tmp; 1.260 ++ tmp = src_beg_line; 1.261 ++ src_beg_line = dest_beg_line; 1.262 ++ dest_beg_line = tmp; 1.263 ++ } 1.264 ++#else 1.265 ++ 1.266 ++ if ((sscanf(patch_line, "@@ -%d,%d +%d", &src_beg_line, &src_last_line, &dest_beg_line) != 3) && 1.267 ++ (sscanf(patch_line, "@@ -%d +%d", &src_beg_line, &dest_beg_line) != 2)) { 1.268 ++ /* No more hunks for this file */ 1.269 ++ break; 1.270 ++ } 1.271 ++#endif 1.272 + hunk_count++; 1.273 + 1.274 + if (src_beg_line && dest_beg_line) { 1.275 + /* Copy unmodified lines upto start of hunk */ 1.276 +- /* src_beg_line will be 0 if its a new file */ 1.277 ++ /* src_beg_line will be 0 if it's a new file */ 1.278 + count = src_beg_line - src_cur_line; 1.279 +- if (copy_lines(src_stream, dst_stream, count) != count) { 1.280 ++ if (copy_lines(src_stream, dst_stream, count)) { 1.281 + bb_error_msg_and_die("bad src file"); 1.282 + } 1.283 + src_cur_line += count; 1.284 + dest_cur_line += count; 1.285 + copy_trailing_lines_flag = 1; 1.286 + } 1.287 +- hunk_offset_start = src_cur_line; 1.288 +- 1.289 +- while ((patch_line = xmalloc_fgets(patch_file)) != NULL) { 1.290 +- if ((*patch_line == '-') || (*patch_line == ' ')) { 1.291 ++ src_last_line += hunk_offset_start = src_cur_line; 1.292 ++#if ENABLE_FEATURE_PATCH_REVERSE 1.293 ++ dst_last_line += dest_cur_line; 1.294 ++#endif 1.295 ++ while (1) { 1.296 ++ free(patch_line); 1.297 ++ patch_line = xmalloc_fgets(patch_file); 1.298 ++ if (patch_line == NULL) break; 1.299 ++ if ((*patch_line == minus) || (*patch_line == ' ')) { 1.300 + char *src_line = NULL; 1.301 ++ if (src_cur_line == src_last_line) break; 1.302 + if (src_stream) { 1.303 + src_line = xmalloc_fgets(src_stream); 1.304 +- if (!src_line) { 1.305 +- hunk_error++; 1.306 +- break; 1.307 +- } else { 1.308 ++ if (src_line) { 1.309 ++ int diff = strcmp(src_line, patch_line + 1); 1.310 + src_cur_line++; 1.311 ++ free(src_line); 1.312 ++ if (diff) src_line = NULL; 1.313 + } 1.314 +- if (strcmp(src_line, patch_line + 1) != 0) { 1.315 +- bb_error_msg("hunk #%d FAILED at %d", hunk_count, hunk_offset_start); 1.316 +- hunk_error++; 1.317 +- free(patch_line); 1.318 +- /* Probably need to find next hunk, etc... */ 1.319 +- /* but for now we just bail out */ 1.320 +- patch_line = NULL; 1.321 +- break; 1.322 +- } 1.323 +- free(src_line); 1.324 + } 1.325 +- if (*patch_line == ' ') { 1.326 +- fputs(patch_line + 1, dst_stream); 1.327 +- dest_cur_line++; 1.328 ++ if (!src_line) { 1.329 ++ bb_error_msg("hunk #%u FAILED at %u", hunk_count, hunk_offset_start); 1.330 ++ bad_hunk_count++; 1.331 ++ break; 1.332 + } 1.333 +- } else if (*patch_line == '+') { 1.334 +- fputs(patch_line + 1, dst_stream); 1.335 +- dest_cur_line++; 1.336 +- } else { 1.337 ++ if (*patch_line != ' ') { 1.338 ++ continue; 1.339 ++ } 1.340 ++ } else if (*patch_line != plus) { 1.341 + break; 1.342 + } 1.343 +- free(patch_line); 1.344 +- } 1.345 +- if (hunk_error) { 1.346 +- bad_hunk_count++; 1.347 +- } 1.348 +- } 1.349 ++#if ENABLE_FEATURE_PATCH_REVERSE 1.350 ++ if (dest_cur_line == dst_last_line) break; 1.351 ++#endif 1.352 ++ fputs(patch_line + 1, dst_stream); 1.353 ++ dest_cur_line++; 1.354 ++ } /* end of while loop handling one hunk */ 1.355 ++ } /* end of while loop handling one file */ 1.356 + 1.357 + /* Cleanup last patched file */ 1.358 + if (copy_trailing_lines_flag) { 1.359 +- copy_lines(src_stream, dst_stream, -1); 1.360 ++ copy_lines(src_stream, dst_stream, (unsigned)(-1)); 1.361 + } 1.362 + if (src_stream) { 1.363 + fclose(src_stream); 1.364 + } 1.365 +- if (dst_stream) { 1.366 +- fclose(dst_stream); 1.367 +- } 1.368 ++ fclose(dst_stream); 1.369 + if (bad_hunk_count) { 1.370 +- if (!ret) { 1.371 +- ret = 1; 1.372 +- } 1.373 +- bb_error_msg("%d out of %d hunk FAILED", bad_hunk_count, hunk_count); 1.374 ++ ret = 1; 1.375 ++ bb_error_msg("%u out of %u hunk FAILED", bad_hunk_count, hunk_count); 1.376 + } else { 1.377 + /* It worked, we can remove the backup */ 1.378 + if (backup_filename) { 1.379 + unlink(backup_filename); 1.380 ++ free(backup_filename); 1.381 + } 1.382 + if ((dest_cur_line == 0) || (dest_beg_line == 0)) { 1.383 + /* The new patched file is empty, remove it */ 1.384 + xunlink(new_filename); 1.385 +- if (strcmp(new_filename, original_filename) != 0) 1.386 +- xunlink(original_filename); 1.387 ++ /* original_filename and new_filename may be the same file */ 1.388 ++ unlink(original_filename); 1.389 + } 1.390 + } 1.391 +- } 1.392 ++ } /* end of "while there are patch lines" */ 1.393 ++quit: 1.394 + 1.395 + /* 0 = SUCCESS 1.396 + * 1 = Some hunks failed 1.397 +- * 2 = More serious problems 1.398 ++ * 2 = More serious problems (exited earlier) 1.399 + */ 1.400 + return ret; 1.401 + } 1.402 + 1.403 +--- busybox-1.10.3/include/usage.h 2008-03-24 16:20:43.000000000 +0100 1.404 ++++ busybox-1.10.3/include/usage.h 2008-03-24 16:22:06.000000000 +0100 1.405 +@@ -2837,8 +2837,9 @@ 1.406 + ) 1.407 + 1.408 + #define patch_trivial_usage \ 1.409 +- "[-p NUM] [-i DIFF]" 1.410 ++ "[-R] [-p NUM] [-i DIFF]" 1.411 + #define patch_full_usage \ 1.412 ++ " -R Reverse patch\n" \ 1.413 + " -p NUM Strip NUM leading components from file names" \ 1.414 + "\n -i DIFF Read DIFF instead of stdin" \ 1.415 +