* dump_setup.cc (dump_setup): Check for the existence of the package list file.
Rework slightly to use static buffer for popen commands.
This commit is contained in:
		| @@ -1,3 +1,9 @@ | |||||||
|  | 2003-08-09  Igor Pechtchanski  <pechtcha@cs.nyu.edu> | ||||||
|  | 	    Christopher Faylor  <cgf@redhat.com> | ||||||
|  |  | ||||||
|  | 	* dump_setup.cc (dump_setup): Check for the existence of the package | ||||||
|  | 	list file.  Rework slightly to use static buffer for popen commands. | ||||||
|  |  | ||||||
| 2003-08-07  Igor Pechtchanski  <pechtcha@cs.nyu.edu> | 2003-08-07  Igor Pechtchanski  <pechtcha@cs.nyu.edu> | ||||||
| 	    Christopher Faylor  <cgf@redhat.com> | 	    Christopher Faylor  <cgf@redhat.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -237,36 +237,52 @@ file_exists (int verbose, char *filename, const char *alt, char *package) | |||||||
| static bool | static bool | ||||||
| check_package_files (int verbose, char *package) | check_package_files (int verbose, char *package) | ||||||
| { | { | ||||||
|   bool result = true; |   char filelist[MAX_PATH + 1] = "/etc/setup/"; | ||||||
|   char filelist[4096] = " -dc /etc/setup/"; |   strcat (strcat (filelist, package), ".lst.gz"); | ||||||
|   strcat(strcat(filelist, package), ".lst.gz"); |   if (!file_exists (false, filelist, NULL, NULL)) | ||||||
|   char *zcat = cygpath("/bin/gzip.exe", NULL); |     { | ||||||
|   char command[4096]; |       if (verbose) | ||||||
|  | 	printf ("Missing file list /%s for package %s\n", filelist, package); | ||||||
|  |       return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |   static char *zcat; | ||||||
|  |   static char *zcat_end; | ||||||
|  |   if (!zcat) | ||||||
|  |     { | ||||||
|  |       zcat = cygpath ("/bin/gzip.exe", NULL); | ||||||
|       while (char *p = strchr (zcat, '/')) |       while (char *p = strchr (zcat, '/')) | ||||||
| 	*p = '\\'; | 	*p = '\\'; | ||||||
|   strcat(strcpy(command, zcat), filelist); |       zcat = (char *) realloc (zcat, strlen (zcat) + sizeof (" -dc ") + 4096); | ||||||
|   FILE *fp = popen (command, "rt"); |       zcat_end = strchr (strcat (zcat, " -dc "), '\0'); | ||||||
|   char buf[4096]; |     } | ||||||
|  |  | ||||||
|  |   strcpy (zcat_end, filelist); | ||||||
|  |   FILE *fp = popen (zcat, "rt"); | ||||||
|  |  | ||||||
|  |   bool result = true; | ||||||
|  |   char buf[MAX_PATH + 1]; | ||||||
|   while (fgets (buf, 4096, fp)) |   while (fgets (buf, 4096, fp)) | ||||||
|     { |     { | ||||||
|       char *filename = strtok(buf, "\n"); |       char *filename = strtok(buf, "\n"); | ||||||
|       if (filename[strlen(filename)-1] == '/') |       if (filename[strlen (filename) - 1] == '/') | ||||||
|         { |         { | ||||||
|           if (!directory_exists(verbose, filename, package)) |           if (!directory_exists (verbose, filename, package)) | ||||||
|             result = false; |             result = false; | ||||||
|         } |         } | ||||||
|       else if (!strncmp(filename, "etc/postinstall/", 16)) |       else if (!strncmp (filename, "etc/postinstall/", 16)) | ||||||
|         { |         { | ||||||
|           if (!file_exists(verbose, filename, ".done", package)) |           if (!file_exists (verbose, filename, ".done", package)) | ||||||
|             result = false; |             result = false; | ||||||
|         } |         } | ||||||
|       else |       else | ||||||
|         { |         { | ||||||
|           if (!file_exists(verbose, filename, ".lnk", package)) |           if (!file_exists (verbose, filename, ".lnk", package)) | ||||||
|             result = false; |             result = false; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   fclose(fp); |  | ||||||
|  |   fclose (fp); | ||||||
|   return result; |   return result; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user