aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Peach <mrpeach@users.sourceforge.net>2013-02-20 20:57:27 +0000
committerMartin Peach <mrpeach@users.sourceforge.net>2013-02-20 20:57:27 +0000
commit25401a89dfc004b2587ce3f993748718510ee83f (patch)
tree8905d43cb5e841d4d4b482fe1f6256ba19036161
parent1c9a4ba3de27ba1c65334e4820c89df5db846270 (diff)
fopen and fclose -> sys_fopen and sys_fclose for recent pd
svn path=/trunk/externals/mrpeach/; revision=17043
-rw-r--r--binfile/binfile.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/binfile/binfile.c b/binfile/binfile.c
index c32c9af..d50a5d4 100644
--- a/binfile/binfile.c
+++ b/binfile/binfile.c
@@ -30,6 +30,13 @@ static t_class *binfile_class;
#define ALLOC_BLOCK_SIZE 65536 /* number of bytes to add when resizing buffer */
#define PATH_BUF_SIZE 1024 /* maximumn length of a file path */
+/* support older Pd versions without sys_open(), sys_fopen(), sys_fclose() */
+#if PD_MAJOR_VERSION == 0 && PD_MINOR_VERSION < 44
+#define sys_open open
+#define sys_fopen fopen
+#define sys_fclose fclose
+#endif
+
typedef struct t_binfile
{
t_object x_obj;
@@ -154,7 +161,7 @@ static FILE *binfile_open_path(t_binfile *x, char *path, char *mode)
strncpy(tryPath, path, PATH_BUF_SIZE-1); /* copy path into a length-limited buffer */
/* ...if it doesn't work we won't mess up x->fPath */
tryPath[PATH_BUF_SIZE-1] = '\0'; /* just make sure there is a null termination */
- fP = fopen(tryPath, mode);
+ fP = sys_fopen(tryPath, mode);
}
if (fP == NULL)
{
@@ -164,7 +171,7 @@ static FILE *binfile_open_path(t_binfile *x, char *path, char *mode)
strncat(tryPath, path, PATH_BUF_SIZE-1); /* append path to a length-limited buffer */
/* ...if it doesn't work we won't mess up x->fPath */
tryPath[PATH_BUF_SIZE-1] = '\0'; /* make sure there is a null termination */
- fP = fopen(tryPath, mode);
+ fP = sys_fopen(tryPath, mode);
}
if (fP != NULL)
strncpy(x->x_fPath, tryPath, PATH_BUF_SIZE);
@@ -183,7 +190,7 @@ static void binfile_write(t_binfile *x, t_symbol *path)
bytes_written = fwrite(x->x_buf, 1L, x->x_length, x->x_fP);
if (bytes_written != x->x_length) post("binfile: %ld bytes written != %ld", bytes_written, x->x_length);
else post("binfile: wrote %ld bytes to %s", bytes_written, path->s_name);
- fclose(x->x_fP);
+ sys_fclose(x->x_fP);
x->x_fP = NULL;
}
@@ -219,7 +226,7 @@ static void binfile_read(t_binfile *x, t_symbol *path)
x->x_wr_offset = x->x_buf_length; /* write new data at end of file */
x->x_length = x->x_buf_length; /* file length is same as buffer size 7*/
x->x_rd_offset = 0L; /* read from start of file */
- fclose (x->x_fP);
+ sys_fclose (x->x_fP);
x->x_fP = NULL;
if (bytes_read != file_length) post("binfile length %ld not equal to bytes read (%ld)", file_length, bytes_read);
else post("binfle: read %ld bytes from %s", bytes_read, path->s_name);