Package: rman / 3.2-7

debian-changes-before-3.2.5-gzip Patch series | download
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
Description: patch summarizes all "diffs" which have been done by previous maintainer. GZip stuff.

--- a/contrib/gzip.patch
+++ b/contrib/gzip.patch
@@ -1,3 +1,5 @@
+**** NOTE: This patch is already applied in the Debian Distribution ****
+
 --- rman.c.~1~	Wed Nov 20 13:33:52 1996
 +++ rman.c	Fri Oct 24 00:10:56 1997
 @@ -3583,6 +3583,43 @@
--- a/rman.c
+++ b/rman.c
@@ -3963,6 +3963,43 @@
 			}
 			free(sobuf);
 		}
+	} else {
+#define GZIP "/bin/gzip"
+		char * gz = malloc(strlen(p)+3+1);
+		sprintf(gz, "%s.gz", p);
+		if (stat(gz, &fileinfo)==0) {
+			/* first, figure out how big */
+			char * cmd = malloc(strlen(gz) + strlen(GZIP) + 7 + 1);
+			char buffer[512];
+			unsigned long compr, uncomp;
+			FILE * proc;
+			sprintf(cmd, "%s -l \"%s\"", GZIP, gz);
+			proc = popen(cmd, "r");
+			fgets(buffer, sizeof buffer, proc); /* label line */
+			fgets(buffer, sizeof buffer, proc); /* length line */
+			sscanf(buffer, "%lu %lu", &compr, &uncomp);
+			fclose(proc);
+			/* Boy, don't you wish stat would do that? */
+			sobuf = malloc(uncomp + 1);
+			if (sobuf!=NULL) {
+				/* suck in entire file, as above */
+				sprintf(cmd, "%s -dc \"%s\"", GZIP, gz);
+				proc = popen(cmd, "r");
+				if (proc!=NULL) {
+					if(fread(sobuf, 1, uncomp, proc)) {
+						sobuf[uncomp]='\0';
+						for (q=sobuf; (q=strstr(q," \\}"))!=NULL; q+=3) *q='\n';
+						source_subfile(sobuf);
+						err = 0;
+					}
+					fclose(proc);
+				}
+				free(sobuf);
+			}
+			free(cmd);
+		}
+		free(gz);
+
 	}
 
 	if (err) {