summaryrefslogtreecommitdiff
path: root/demos/testpixbuf.c
diff options
context:
space:
mode:
authorElliot Lee <sopwith@src.gnome.org>1999-11-02 22:01:43 +0000
committerElliot Lee <sopwith@src.gnome.org>1999-11-02 22:01:43 +0000
commitd611593ffdb064262ecbe85cdf16c5f6345f5858 (patch)
tree3c4ac6f165b01fd36d1162494fac339e7e8a90b9 /demos/testpixbuf.c
parentb953e64bc651ce3df4e9401f92ee61bb78e253da (diff)
downloadgtk+-d611593ffdb064262ecbe85cdf16c5f6345f5858.tar.gz
Allow using $TBF_READLEN to specify the size of the chunks that are read
* src/testpixbuf.c: Allow using $TBF_READLEN to specify the size of the chunks that are read from the input file.
Diffstat (limited to 'demos/testpixbuf.c')
-rw-r--r--demos/testpixbuf.c29
1 files changed, 17 insertions, 12 deletions
diff --git a/demos/testpixbuf.c b/demos/testpixbuf.c
index 7309a41a92..350b4cba1e 100644
--- a/demos/testpixbuf.c
+++ b/demos/testpixbuf.c
@@ -439,11 +439,13 @@ progressive_prepared_callback(GdkPixbufLoader* loader, gpointer data)
return;
}
+static int readlen = 1;
+
int
main (int argc, char **argv)
{
int i;
- int found_valid = FALSE;
+ int found_valid = FALSE;
GdkPixbuf *pixbuf;
GdkPixbufLoader *pixbuf_loader;
@@ -460,6 +462,11 @@ main (int argc, char **argv)
gtk_widget_set_default_colormap (gdk_rgb_get_cmap ());
gtk_widget_set_default_visual (gdk_rgb_get_visual ());
+ {
+ char *tbf_readlen = getenv("TBF_READLEN");
+ if(tbf_readlen) readlen = atoi(tbf_readlen);
+ }
+
i = 1;
if (argc == 1) {
const gchar*** xpmp;
@@ -494,6 +501,7 @@ main (int argc, char **argv)
{
GtkWidget* rgb_window = NULL;
guint timeout;
+ char *buf;
pixbuf_loader = gdk_pixbuf_loader_new ();
@@ -506,25 +514,22 @@ main (int argc, char **argv)
file = fopen (argv[1], "r");
g_assert (file != NULL);
+ buf = g_malloc(readlen);
- while (TRUE) {
- val = fgetc (file);
- if (val == EOF)
- break;
- buf = (guint) val;
-
- fflush(stdout);
+ while (!feof(file)) {
+ int nbytes;
+ nbytes = fread(buf, 1, readlen, file);
printf(".");
fflush(stdout);
- if (gdk_pixbuf_loader_write (GDK_PIXBUF_LOADER (pixbuf_loader), &buf, 1) == FALSE)
+ if (gdk_pixbuf_loader_write (GDK_PIXBUF_LOADER (pixbuf_loader), buf, nbytes) == FALSE)
break;
- while (gtk_events_pending())
- gtk_main_iteration();
-
+ while (gtk_events_pending())
+ gtk_main_iteration();
}
+ printf("\n");
gtk_timeout_remove (timeout);
gdk_pixbuf_loader_close (GDK_PIXBUF_LOADER (pixbuf_loader));
gtk_object_destroy (GTK_OBJECT(pixbuf_loader));