aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJohn Hawthorn <jhawthor@uvic.ca>2008-05-19 20:10:06 -0700
committerJohn Hawthorn <jhawthor@uvic.ca>2008-05-19 20:10:06 -0700
commit8736618f8890638c8aedca43fa7bfa2f59e88c48 (patch)
treed2fb0d614c357b956cdfb91447251da20487f373 /src
parentbfbeab9e9a7446ed6b40c0ad557d631c0d738c6c (diff)
downloadmirror-meh-8736618f8890638c8aedca43fa7bfa2f59e88c48.tar.gz
mirror-meh-8736618f8890638c8aedca43fa7bfa2f59e88c48.tar.bz2
mirror-meh-8736618f8890638c8aedca43fa7bfa2f59e88c48.zip
more preparations
Diffstat (limited to 'src')
-rw-r--r--src/main.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/src/main.c b/src/main.c
index 5955293..6f020f9 100644
--- a/src/main.c
+++ b/src/main.c
@@ -112,27 +112,31 @@ XImage *create_image_from_buffer(unsigned char *buf, int width, int height, int
}
unsigned char *loadbuf(const char *filename, int *bufwidth, int *bufheight){
- unsigned char buf[4];
FILE *f;
+ unsigned char head[4];
+ unsigned char *buf;
if((f = fopen(filename, "rb")) == NULL){
fprintf(stderr, "Cannot open '%s'\n", filename);
return NULL;
}
- fread(buf, 1, 4, f);
+ memset(head, 0, 4);
+ fread(head, 1, 4, f);
rewind(f);
- if(buf[0] == 0xff && buf[1] == 0xd8){
- return loadjpeg(f, bufwidth, bufheight);
- }else if(!memcmp("\x89PNG", buf, 4)){
+ if(head[0] == 0xff && head[1] == 0xd8){
+ buf = loadjpeg(f, bufwidth, bufheight);
+ }else if(!memcmp("\x89PNG", head, 4)){
printf("IT'S A PNG!!!\n");
- return NULL;
- }else if(!memcmp("GIF", buf, 3)){
+ buf = NULL;
+ }else if(!memcmp("GIF", head, 3)){
printf("IT'S A GIF!!!\n");
- return NULL;
+ buf = NULL;
}else{
fprintf(stderr, "Unknown file type: '%s'\n", filename);
- return NULL;
+ buf = NULL;
}
+ fclose(f);
+ return buf;
}
void init(){