aboutsummaryrefslogtreecommitdiff
path: root/news
diff options
context:
space:
mode:
authorMikhail Teterin <mi@FreeBSD.org>2001-07-13 17:23:57 +0000
committerMikhail Teterin <mi@FreeBSD.org>2001-07-13 17:23:57 +0000
commit6bcb0919aa3c7a549f306e6e590bb7d68b955529 (patch)
tree0fefc0239f2ba5ddcec4f9a856a3d7909d64d505 /news
parent1db38b3dd7721529263024388073d2f066491239 (diff)
Re-do the patch-png.c "by the book" -- following the examples in
libpng(3) to be able to use the new libpng, which disabled some deprecated interfaces. Modify file.c to use mkstemp instead of tmpnam. Fix an old bug -- when the new server's configuration is created from scratch, we write a file and then read it -- use O_RDWR instead of O_WRONLY. I could not reproduce Andreas' complaint regarding compface related crashes and plan to re-enable them in the Makefile. Too bad this program is no longer in development :(
Notes
Notes: svn path=/head/; revision=45109
Diffstat (limited to 'news')
-rw-r--r--news/knews/files/patch-file.c28
-rw-r--r--news/knews/files/patch-png.c141
-rw-r--r--news/knews/files/patch-resource.c11
3 files changed, 160 insertions, 20 deletions
diff --git a/news/knews/files/patch-file.c b/news/knews/files/patch-file.c
new file mode 100644
index 000000000000..7a3409474641
--- /dev/null
+++ b/news/knews/files/patch-file.c
@@ -0,0 +1,28 @@
+Use mkstemp instead of tmpnam. Copied from the tmpnam implementation :)
+
+ -mi
+
+--- src/file.c Fri Jan 9 12:16:19 1998
++++ src/file.c Fri Jul 13 10:41:01 2001
+@@ -187,13 +187,12 @@
+ int fd;
++ static unsigned long tmpcount;
++ static char buf[L_tmpnam];
+
+- *name = tmpnam(NULL);
+- if (!*name)
+- fd = -1;
+- else {
++ (void)snprintf(buf, L_tmpnam, "%stmp.%lu.XXXXXX", P_tmpdir, tmpcount++);
++ *name = buf;
++ fd = mkstemp(buf);
++ if (fd < 0)
++ *name = NULL;
++ else
+ unlink(*name);
+- fd = open(*name, O_RDWR|O_CREAT|O_EXCL, S_IRUSR|S_IWUSR);
+- if (fd < 0)
+- *name = NULL;
+- }
+-
+ return fd;
diff --git a/news/knews/files/patch-png.c b/news/knews/files/patch-png.c
index 5b876caa70ee..b4b21ccb858b 100644
--- a/news/knews/files/patch-png.c
+++ b/news/knews/files/patch-png.c
@@ -1,29 +1,130 @@
---- src/png.c.orig Sat Nov 21 15:55:13 1998
-+++ src/png.c Sun Jun 17 19:58:21 2001
-@@ -80,6 +80,7 @@
+--- src/png.c Sat Nov 21 09:55:13 1998
++++ src/png.c Fri Jul 13 11:29:00 2001
+@@ -78,6 +78,12 @@
+
++static Pixmap rep_fail(const char *e) {
++ ArtTextAddLine(main_widgets.text, e, ascii_font->body_font,
++ global.alert_pixel);
++ return None;
++}
++
+ Pixmap do_png(char *data, long len, long *wp, long *hp)
{
- png_struct p_str;
- png_info p_info;
-+ png_info * p_info_ptr;
+- png_struct p_str;
+- png_info p_info;
++ png_structp png_ptr;
++ png_infop info_ptr;
Pixmap pixmap;
- FILE *volatile vol_fp = NULL;
- void *volatile vol_pic = NULL;
-@@ -109,7 +110,8 @@
- unsigned int i, j, pass;
+@@ -94,9 +100,6 @@
+
+- if (!(vol_fp = dump_for_png(data, len))) {
+- ArtTextAddLine(main_widgets.text, "[knews: temp file error.]",
+- ascii_font->body_font, global.alert_pixel);
+- return None;
+- }
++ if (!(vol_fp = dump_for_png(data, len)))
++ return rep_fail("[knews: temp file error.]");
+
+- if (setjmp(p_str.jmpbuf))
++ if (setjmp(png_jmpbuf(png_ptr)))
+ ArtTextAddLine(main_widgets.text, "[knews: png error.]",
+@@ -110,18 +113,26 @@
- png_read_init(&p_str);
+- png_read_init(&p_str);
- png_info_init(&p_info);
-+ p_info_ptr = &p_info;
-+ png_info_init_3(&p_info_ptr, sizeof(png_info));
++ png_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING,
++ NULL, NULL, NULL);
++ if (!png_ptr)
++ return rep_fail("[knews: can't allocate PNG structure.]");
++ info_ptr = png_create_info_struct(png_ptr);
++ if (!info_ptr) {
++ png_destroy_read_struct(&png_ptr,
++ (png_infopp)NULL, (png_infopp)NULL);
++ return rep_fail("[knews: can't PNG info structure.]");
++ }
+
+- png_init_io(&p_str, vol_fp);
+- png_read_info(&p_str, &p_info);
++ png_init_io(png_ptr, vol_fp);
++ png_read_info(png_ptr, info_ptr);
+
+- vol_w = w = p_info.width;
+- vol_h = h = p_info.height;
++ vol_w = w = info_ptr->width;
++ vol_h = h = info_ptr->height;
+
+- if (p_info.bit_depth == 16)
+- png_set_strip_16(&p_str);
+- else if (p_info.bit_depth < 8)
+- png_set_packing(&p_str);
++ if (info_ptr->bit_depth == 16)
++ png_set_strip_16(png_ptr);
++ else if (info_ptr->bit_depth < 8)
++ png_set_packing(png_ptr);
+
+- if (p_info.valid & PNG_INFO_bKGD)
+- png_set_background(&p_str, &p_info.background,
++ if (info_ptr->valid & PNG_INFO_bKGD)
++ png_set_background(png_ptr, &info_ptr->background,
+ PNG_BACKGROUND_GAMMA_FILE, True, 1.0);
+@@ -129,3 +140,3 @@
+ static png_color_16 bg = {0, };
+- png_set_background(&p_str, &bg,
++ png_set_background(png_ptr, &bg,
+ PNG_BACKGROUND_GAMMA_SCREEN, False, 1.0);
+@@ -135,10 +146,10 @@
+
+- if (!(p_info.color_type & PNG_COLOR_MASK_COLOR)) { /* grey image */
++ if (!(info_ptr->color_type & PNG_COLOR_MASK_COLOR)) { /* grey image */
+ grey = True;
+- png_set_expand(&p_str);
++ png_set_expand(png_ptr);
+ } else if (!p_cmap) { /* true color visual */
+- if (p_info.color_type == PNG_COLOR_TYPE_PALETTE)
+- png_set_expand(&p_str);
++ if (info_ptr->color_type == PNG_COLOR_TYPE_PALETTE)
++ png_set_expand(png_ptr);
+ per_line *= 3;
+- } else if (p_info.color_type & PNG_COLOR_MASK_PALETTE) {
++ } else if (info_ptr->color_type & PNG_COLOR_MASK_PALETTE) {
+ CMAP_ENTRY *pal;
+@@ -146,8 +157,8 @@
+
+- pn = p_info.num_palette;
++ pn = info_ptr->num_palette;
+ pal = (CMAP_ENTRY *)XtMalloc(pn * sizeof *pal);
+ for (i = 0 ; i < pn ; i++) {
+- pal[i].r = p_info.palette[i].red;
+- pal[i].g = p_info.palette[i].green;
+- pal[i].b = p_info.palette[i].blue;
++ pal[i].r = info_ptr->palette[i].red;
++ pal[i].g = info_ptr->palette[i].green;
++ pal[i].b = info_ptr->palette[i].blue;
+ }
+@@ -156,3 +167,3 @@
+ } else {
+- png_set_dither(&p_str, p_cmap, cmap_size,
++ png_set_dither(png_ptr, p_cmap, cmap_size,
+ cmap_size, NULL, True);
+@@ -160,4 +171,4 @@
+
+- pass = png_set_interlace_handling(&p_str);
+- png_start_read_image(&p_str);
++ pass = png_set_interlace_handling(png_ptr);
++ png_start_read_image(png_ptr);
+
+@@ -169,3 +180,3 @@
+ for (j = 0 ; j < h ; j++) {
+- png_read_row(&p_str, NULL, row);
++ png_read_row(png_ptr, NULL, row);
+ if (!did)
+@@ -176,3 +187,3 @@
- png_init_io(&p_str, vol_fp);
- png_read_info(&p_str, &p_info);
-@@ -204,7 +206,7 @@
- }
+- png_read_end(&p_str, NULL);
++ png_read_end(png_ptr, NULL);
}
+@@ -206,3 +217,3 @@
- png_read_destroy(&p_str, &p_info, NULL);
-+ png_read_destroy(&p_str, &p_info_ptr, NULL);
++ png_read_destroy(png_ptr, info_ptr, NULL);
fclose((FILE *)vol_fp);
- XtFree((char *)vol_pic);
- XtFree((char *)vol_pal);
diff --git a/news/knews/files/patch-resource.c b/news/knews/files/patch-resource.c
new file mode 100644
index 000000000000..5a59d16882ac
--- /dev/null
+++ b/news/knews/files/patch-resource.c
@@ -0,0 +1,11 @@
+Do not use O_WRONLY, if we plan on reading from this file again!
+
+ -mi
+
+--- src/resource.c Fri Jan 9 12:16:21 1998
++++ src/resource.c Fri Jul 13 12:21:46 2001
+@@ -556,3 +556,3 @@
+ fprintf(stderr, "Knews: creating config file %s\n", path);
+- fd = open_mkdir(path, O_WRONLY|O_TRUNC|O_EXCL|O_CREAT, True);
++ fd = open_mkdir(path, O_RDWR|O_TRUNC|O_EXCL|O_CREAT, True);
+ if (fd < 0) {