summaryrefslogtreecommitdiff
path: root/src/file.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/file.c')
-rw-r--r--src/file.c114
1 files changed, 104 insertions, 10 deletions
diff --git a/src/file.c b/src/file.c
index 84a4a8a..de17004 100644
--- a/src/file.c
+++ b/src/file.c
@@ -1,4 +1,5 @@
/*
+ * $Id$
*
* Copyright © 2002 Keith Packard
*
@@ -46,7 +47,8 @@ XcursorImageCreate (int width, int height)
void
XcursorImageDestroy (XcursorImage *image)
{
- free (image);
+ if (image)
+ free (image);
}
XcursorImages *
@@ -69,6 +71,9 @@ XcursorImagesDestroy (XcursorImages *images)
{
int n;
+ if (!images)
+ return;
+
for (n = 0; n < images->nimage; n++)
XcursorImageDestroy (images->images[n]);
if (images->name)
@@ -79,10 +84,16 @@ XcursorImagesDestroy (XcursorImages *images)
void
XcursorImagesSetName (XcursorImages *images, const char *name)
{
- char *new = malloc (strlen (name) + 1);
+ char *new;
+
+ if (!images || !name)
+ return;
+
+ new = malloc (strlen (name) + 1);
if (!new)
return;
+
strcpy (new, name);
if (images->name)
free (images->name);
@@ -110,7 +121,8 @@ XcursorCommentCreate (XcursorUInt comment_type, int length)
void
XcursorCommentDestroy (XcursorComment *comment)
{
- free (comment);
+ if (!comment)
+ free (comment);
}
XcursorComments *
@@ -132,6 +144,9 @@ XcursorCommentsDestroy (XcursorComments *comments)
{
int n;
+ if (!comments)
+ return;
+
for (n = 0; n < comments->ncomment; n++)
XcursorCommentDestroy (comments->comments[n]);
free (comments);
@@ -142,6 +157,9 @@ _XcursorReadUInt (XcursorFile *file, XcursorUInt *u)
{
unsigned char bytes[4];
+ if (!file || !u)
+ return XcursorFalse;
+
if ((*file->read) (file, bytes, 4) != 4)
return XcursorFalse;
*u = ((bytes[0] << 0) |
@@ -154,7 +172,7 @@ _XcursorReadUInt (XcursorFile *file, XcursorUInt *u)
static XcursorBool
_XcursorReadBytes (XcursorFile *file, char *bytes, int length)
{
- if ((*file->read) (file, (unsigned char *) bytes, length) != length)
+ if (!file || !bytes || (*file->read) (file, (unsigned char *) bytes, length) != length)
return XcursorFalse;
return XcursorTrue;
}
@@ -164,6 +182,9 @@ _XcursorWriteUInt (XcursorFile *file, XcursorUInt u)
{
unsigned char bytes[4];
+ if (!file)
+ return XcursorFalse;
+
bytes[0] = u;
bytes[1] = u >> 8;
bytes[2] = u >> 16;
@@ -176,7 +197,7 @@ _XcursorWriteUInt (XcursorFile *file, XcursorUInt u)
static XcursorBool
_XcursorWriteBytes (XcursorFile *file, char *bytes, int length)
{
- if ((*file->write) (file, (unsigned char *) bytes, length) != length)
+ if (!file || !bytes || (*file->write) (file, (unsigned char *) bytes, length) != length)
return XcursorFalse;
return XcursorTrue;
}
@@ -184,7 +205,8 @@ _XcursorWriteBytes (XcursorFile *file, char *bytes, int length)
static void
_XcursorFileHeaderDestroy (XcursorFileHeader *fileHeader)
{
- free (fileHeader);
+ if (!fileHeader)
+ free (fileHeader);
}
static XcursorFileHeader *
@@ -212,6 +234,9 @@ _XcursorReadFileHeader (XcursorFile *file)
XcursorFileHeader head, *fileHeader;
XcursorUInt skip;
int n;
+
+ if (!file)
+ return NULL;
if (!_XcursorReadUInt (file, &head.magic))
return 0;
@@ -262,6 +287,9 @@ static XcursorBool
_XcursorWriteFileHeader (XcursorFile *file, XcursorFileHeader *fileHeader)
{
int toc;
+
+ if (!file || !fileHeader)
+ return XcursorFalse;
if (!_XcursorWriteUInt (file, fileHeader->magic))
return XcursorFalse;
@@ -288,7 +316,8 @@ _XcursorSeekToToc (XcursorFile *file,
XcursorFileHeader *fileHeader,
int toc)
{
- if ((*file->seek) (file, fileHeader->tocs[toc].position, SEEK_SET) == EOF)
+ if (!file || !fileHeader || \
+ (*file->seek) (file, fileHeader->tocs[toc].position, SEEK_SET) == EOF)
return XcursorFalse;
return XcursorTrue;
}
@@ -299,6 +328,8 @@ _XcursorFileReadChunkHeader (XcursorFile *file,
int toc,
XcursorChunkHeader *chunkHeader)
{
+ if (!file || !fileHeader || !chunkHeader)
+ return XcursorFalse;
if (!_XcursorSeekToToc (file, fileHeader, toc))
return XcursorFalse;
if (!_XcursorReadUInt (file, &chunkHeader->header))
@@ -322,6 +353,8 @@ _XcursorFileWriteChunkHeader (XcursorFile *file,
int toc,
XcursorChunkHeader *chunkHeader)
{
+ if (!file || !fileHeader || !chunkHeader)
+ return XcursorFalse;
if (!_XcursorSeekToToc (file, fileHeader, toc))
return XcursorFalse;
if (!_XcursorWriteUInt (file, chunkHeader->header))
@@ -347,6 +380,9 @@ _XcursorFindBestSize (XcursorFileHeader *fileHeader,
XcursorDim bestSize = 0;
XcursorDim thisSize;
+ if (!fileHeader || !nsizesp)
+ return 0;
+
for (n = 0; n < fileHeader->ntoc; n++)
{
if (fileHeader->tocs[n].type != XCURSOR_IMAGE_TYPE)
@@ -372,6 +408,9 @@ _XcursorFindImageToc (XcursorFileHeader *fileHeader,
int toc;
XcursorDim thisSize;
+ if (!fileHeader)
+ return 0;
+
for (toc = 0; toc < fileHeader->ntoc; toc++)
{
if (fileHeader->tocs[toc].type != XCURSOR_IMAGE_TYPE)
@@ -399,6 +438,9 @@ _XcursorReadImage (XcursorFile *file,
int n;
XcursorPixel *p;
+ if (!file || !fileHeader)
+ return NULL;
+
if (!_XcursorFileReadChunkHeader (file, fileHeader, toc, &chunkHeader))
return 0;
if (!_XcursorReadUInt (file, &head.width))
@@ -444,6 +486,9 @@ _XcursorReadImage (XcursorFile *file,
static XcursorUInt
_XcursorImageLength (XcursorImage *image)
{
+ if (!image)
+ return 0;
+
return XCURSOR_IMAGE_HEADER_LEN + (image->width * image->height) * 4;
}
@@ -457,6 +502,9 @@ _XcursorWriteImage (XcursorFile *file,
int n;
XcursorPixel *p;
+ if (!file || !fileHeader || !image)
+ return XcursorFalse;
+
/* sanity check data */
if (image->width > XCURSOR_IMAGE_MAX_SIZE ||
image->height > XCURSOR_IMAGE_MAX_SIZE)
@@ -508,6 +556,9 @@ _XcursorReadComment (XcursorFile *file,
XcursorUInt length;
XcursorComment *comment;
+ if (!file || !fileHeader)
+ return NULL;
+
/* read chunk header */
if (!_XcursorFileReadChunkHeader (file, fileHeader, toc, &chunkHeader))
return 0;
@@ -541,6 +592,9 @@ _XcursorWriteComment (XcursorFile *file,
XcursorChunkHeader chunkHeader;
XcursorUInt length;
+ if (!file || !fileHeader || !comment || !comment->comment)
+ return XcursorFalse;
+
length = strlen (comment->comment);
/* sanity check data */
@@ -600,7 +654,7 @@ XcursorXcFileLoadImages (XcursorFile *file, int size)
int n;
int toc;
- if (size < 0)
+ if (!file || size < 0)
return 0;
fileHeader = _XcursorReadFileHeader (file);
if (!fileHeader)
@@ -641,6 +695,9 @@ XcursorXcFileLoadAllImages (XcursorFile *file)
int n;
int toc;
+ if (!file)
+ return 0;
+
fileHeader = _XcursorReadFileHeader (file);
if (!fileHeader)
return 0;
@@ -692,6 +749,8 @@ XcursorXcFileLoad (XcursorFile *file,
XcursorComments *comments;
int toc;
+ if (!file)
+ return 0;
fileHeader = _XcursorReadFileHeader (file);
if (!fileHeader)
return 0;
@@ -762,6 +821,9 @@ XcursorXcFileSave (XcursorFile *file,
int n;
int toc;
+ if (!file || !comments || !images)
+ return XcursorFalse;
+
fileHeader = _XcursorFileHeaderCreate (comments->ncomment + images->nimage);
if (!fileHeader)
return XcursorFalse;
@@ -861,6 +923,9 @@ XcursorFileLoadImage (FILE *file, int size)
{
XcursorFile f;
+ if (!file)
+ return NULL;
+
_XcursorStdioFileInitialize (file, &f);
return XcursorXcFileLoadImage (&f, size);
}
@@ -870,6 +935,9 @@ XcursorFileLoadImages (FILE *file, int size)
{
XcursorFile f;
+ if (!file)
+ return NULL;
+
_XcursorStdioFileInitialize (file, &f);
return XcursorXcFileLoadImages (&f, size);
}
@@ -879,6 +947,9 @@ XcursorFileLoadAllImages (FILE *file)
{
XcursorFile f;
+ if (!file)
+ return NULL;
+
_XcursorStdioFileInitialize (file, &f);
return XcursorXcFileLoadAllImages (&f);
}
@@ -890,6 +961,9 @@ XcursorFileLoad (FILE *file,
{
XcursorFile f;
+ if (!file || !commentsp || !imagesp)
+ return XcursorFalse;
+
_XcursorStdioFileInitialize (file, &f);
return XcursorXcFileLoad (&f, commentsp, imagesp);
}
@@ -900,7 +974,7 @@ XcursorFileSaveImages (FILE *file, const XcursorImages *images)
XcursorComments *comments = XcursorCommentsCreate (0);
XcursorFile f;
XcursorBool ret;
- if (!comments)
+ if (!comments || !file || !images)
return 0;
_XcursorStdioFileInitialize (file, &f);
ret = XcursorXcFileSave (&f, comments, images) && fflush (file) != EOF;
@@ -914,6 +988,9 @@ XcursorFileSave (FILE * file,
const XcursorImages *images)
{
XcursorFile f;
+
+ if (!file || !comments || !images)
+ return XcursorFalse;
_XcursorStdioFileInitialize (file, &f);
return XcursorXcFileSave (&f, comments, images) && fflush (file) != EOF;
@@ -925,6 +1002,9 @@ XcursorFilenameLoadImage (const char *file, int size)
FILE *f;
XcursorImage *image;
+ if (!file || size < 0)
+ return NULL;
+
f = fopen (file, "r");
if (!f)
return 0;
@@ -939,6 +1019,9 @@ XcursorFilenameLoadImages (const char *file, int size)
FILE *f;
XcursorImages *images;
+ if (!file || size < 0)
+ return NULL;
+
f = fopen (file, "r");
if (!f)
return 0;
@@ -953,6 +1036,9 @@ XcursorFilenameLoadAllImages (const char *file)
FILE *f;
XcursorImages *images;
+ if (!file)
+ return NULL;
+
f = fopen (file, "r");
if (!f)
return 0;
@@ -969,6 +1055,9 @@ XcursorFilenameLoad (const char *file,
FILE *f;
XcursorBool ret;
+ if (!file)
+ return XcursorFalse;
+
f = fopen (file, "r");
if (!f)
return 0;
@@ -983,6 +1072,9 @@ XcursorFilenameSaveImages (const char *file, const XcursorImages *images)
FILE *f;
XcursorBool ret;
+ if (!file || !images)
+ return XcursorFalse;
+
f = fopen (file, "w");
if (!f)
return 0;
@@ -998,10 +1090,12 @@ XcursorFilenameSave (const char *file,
FILE *f;
XcursorBool ret;
+ if (!file || !comments || !images)
+ return XcursorFalse;
+
f = fopen (file, "w");
if (!f)
return 0;
ret = XcursorFileSave (f, comments, images);
return fclose (f) != EOF && ret;
}
-