a file and a memory area into a libcucul buffer. * Changed the cucul_import_canvas() prototype so that it uses libcucul buffers instead of simple memory areas.tags/v0.99.beta14
@@ -27,6 +27,78 @@ | |||||
#include "cucul.h" | #include "cucul.h" | ||||
#include "cucul_internals.h" | #include "cucul_internals.h" | ||||
/** \brief Load a memory area into a buffer. | |||||
* | |||||
* This function creates a \e libcucul buffer that points to the given | |||||
* memory area. The data is not duplicated and any changes made to the | |||||
* original memory area appear in the buffer. | |||||
* | |||||
* \param data The memory area to load. | |||||
* \param size The size of the memory area. | |||||
* \return A \e libcucul buffer pointing to the memory area, or NULL | |||||
* if an error occurred. | |||||
*/ | |||||
cucul_buffer_t *cucul_load_memory(void *data, unsigned long int size) | |||||
{ | |||||
cucul_buffer_t *buf; | |||||
buf = malloc(sizeof(cucul_buffer_t)); | |||||
if(!buf) | |||||
return NULL; | |||||
buf->data = data; | |||||
buf->size = size; | |||||
buf->user_data = 1; | |||||
return buf; | |||||
} | |||||
/** \brief Load a file into a buffer. | |||||
* | |||||
* This function loads a file into memory and returns a \e libcucul buffer | |||||
* for use with other functions. | |||||
* | |||||
* \param file The filename | |||||
* \return A \e libcucul buffer containing the file's contents, or NULL | |||||
* if an error occurred. | |||||
*/ | |||||
cucul_buffer_t *cucul_load_file(char const *file) | |||||
{ | |||||
cucul_buffer_t *buf; | |||||
FILE *fp; | |||||
long int size; | |||||
fp = fopen(file, "rb"); | |||||
if(!fp) | |||||
return NULL; | |||||
buf = malloc(sizeof(cucul_buffer_t)); | |||||
if(!buf) | |||||
{ | |||||
fclose(fp); | |||||
return NULL; | |||||
} | |||||
fseek(fp, 0, SEEK_END); | |||||
size = ftell(fp); | |||||
buf->data = malloc(size); | |||||
if(!buf->data) | |||||
{ | |||||
free(buf); | |||||
fclose(fp); | |||||
return NULL; | |||||
} | |||||
buf->size = size; | |||||
buf->user_data = 0; | |||||
fseek(fp, 0, SEEK_SET); | |||||
fread(buf->data, buf->size, 1, fp); | |||||
fclose(fp); | |||||
return buf; | |||||
} | |||||
/** \brief Get the buffer size. | /** \brief Get the buffer size. | ||||
* | * | ||||
* This function returns the length (in bytes) of the memory area stored | * This function returns the length (in bytes) of the memory area stored | ||||
@@ -69,7 +141,9 @@ void * cucul_get_buffer_data(cucul_buffer_t *buf) | |||||
*/ | */ | ||||
int cucul_free_buffer(cucul_buffer_t *buf) | int cucul_free_buffer(cucul_buffer_t *buf) | ||||
{ | { | ||||
free(buf->data); | |||||
if(!buf->user_data) | |||||
free(buf->data); | |||||
free(buf); | free(buf); | ||||
return 0; | return 0; | ||||
@@ -84,6 +84,8 @@ int cucul_rand(int, int); | |||||
* These functions provide methods to handle libcucul buffers. | * These functions provide methods to handle libcucul buffers. | ||||
* | * | ||||
* @{ */ | * @{ */ | ||||
cucul_buffer_t *cucul_load_memory(void *, unsigned long int); | |||||
cucul_buffer_t *cucul_load_file(char const *); | |||||
unsigned long int cucul_get_buffer_size(cucul_buffer_t *); | unsigned long int cucul_get_buffer_size(cucul_buffer_t *); | ||||
void * cucul_get_buffer_data(cucul_buffer_t *); | void * cucul_get_buffer_data(cucul_buffer_t *); | ||||
int cucul_free_buffer(cucul_buffer_t *); | int cucul_free_buffer(cucul_buffer_t *); | ||||
@@ -206,7 +208,7 @@ void cucul_free_font(cucul_font_t *); | |||||
* @{ */ | * @{ */ | ||||
cucul_buffer_t * cucul_export_canvas(cucul_canvas_t *, char const *); | cucul_buffer_t * cucul_export_canvas(cucul_canvas_t *, char const *); | ||||
char const * const * cucul_get_export_list(void); | char const * const * cucul_get_export_list(void); | ||||
cucul_canvas_t * cucul_import_canvas(void const *, unsigned int, char const *); | |||||
cucul_canvas_t * cucul_import_canvas(cucul_buffer_t *, char const *); | |||||
char const * const * cucul_get_import_list(void); | char const * const * cucul_get_import_list(void); | ||||
/* @} */ | /* @} */ | ||||
@@ -43,6 +43,7 @@ struct cucul_buffer | |||||
{ | { | ||||
unsigned long int size; | unsigned long int size; | ||||
char *data; | char *data; | ||||
int user_data; | |||||
}; | }; | ||||
/* Bitmap functions */ | /* Bitmap functions */ | ||||
@@ -73,6 +73,7 @@ cucul_buffer_t * cucul_export_canvas(cucul_canvas_t *cv, char const *format) | |||||
ex = malloc(sizeof(cucul_buffer_t)); | ex = malloc(sizeof(cucul_buffer_t)); | ||||
ex->size = 0; | ex->size = 0; | ||||
ex->data = NULL; | ex->data = NULL; | ||||
ex->user_data = 0; | |||||
if(!strcasecmp("caca", format)) | if(!strcasecmp("caca", format)) | ||||
export_caca(cv, ex); | export_caca(cv, ex); | ||||
@@ -43,45 +43,45 @@ static cucul_canvas_t *import_ansi(void const *, unsigned int); | |||||
* | * | ||||
* \li \c "caca": import native libcaca files. | * \li \c "caca": import native libcaca files. | ||||
* | * | ||||
* \param data The memory area to be loaded into a canvas. | |||||
* \param buffer A \e libcucul buffer containing the data to be loaded | |||||
* into a canvas. | |||||
* \param size The length of the memory area. | * \param size The length of the memory area. | ||||
* \param format A string describing the input format. | * \param format A string describing the input format. | ||||
* \return A libcucul canvas, or NULL in case of error. | * \return A libcucul canvas, or NULL in case of error. | ||||
*/ | */ | ||||
cucul_canvas_t * cucul_import_canvas(void const *data, unsigned int size, | |||||
char const *format) | |||||
cucul_canvas_t * cucul_import_canvas(cucul_buffer_t *b, char const *format) | |||||
{ | { | ||||
char const *buf = (char const*) data; | |||||
char const *buf = (char const*)b->data; | |||||
if(size==0 || data==NULL) | |||||
if(b->size == 0 || b->data == NULL) | |||||
return NULL; | return NULL; | ||||
if(!strcasecmp("caca", format)) | if(!strcasecmp("caca", format)) | ||||
return import_caca(data, size); | |||||
return import_caca(b->data, b->size); | |||||
if(!strcasecmp("text", format)) | if(!strcasecmp("text", format)) | ||||
return import_text(data, size); | |||||
return import_text(b->data, b->size); | |||||
if(!strcasecmp("ansi", format)) | if(!strcasecmp("ansi", format)) | ||||
return import_ansi(data, size); | |||||
return import_ansi(b->data, b->size); | |||||
/* Autodetection */ | /* Autodetection */ | ||||
if(!strcasecmp("", format)) | if(!strcasecmp("", format)) | ||||
{ | { | ||||
unsigned int i=0; | unsigned int i=0; | ||||
/* if 4 first letters are CACA */ | /* if 4 first letters are CACA */ | ||||
if(size >= 4 && | |||||
if(b->size >= 4 && | |||||
buf[0] == 'C' && buf[1] == 'A' && buf[2] == 'C' && buf[3] != 'A') | buf[0] == 'C' && buf[1] == 'A' && buf[2] == 'C' && buf[3] != 'A') | ||||
return import_caca(data, size); | |||||
return import_caca(b->data, b->size); | |||||
/* If we find ESC[ argv, we guess it's an ANSI file */ | /* If we find ESC[ argv, we guess it's an ANSI file */ | ||||
while(i<size-1) | |||||
while(i < b->size - 1) | |||||
{ | { | ||||
if((buf[i] == 0x1b) && (buf[i+1] == '[')) | if((buf[i] == 0x1b) && (buf[i+1] == '[')) | ||||
return import_ansi(data, size); | |||||
return import_ansi(b->data, b->size); | |||||
i++; | i++; | ||||
} | } | ||||
/* Otherwise, import it as text */ | /* Otherwise, import it as text */ | ||||
return import_text(data, size); | |||||
return import_text(b->data, b->size); | |||||
} | } | ||||
return NULL; | return NULL; | ||||
} | } | ||||
@@ -15,10 +15,6 @@ | |||||
#include "common.h" | #include "common.h" | ||||
#include <stdio.h> | #include <stdio.h> | ||||
#include <sys/types.h> | |||||
#include <sys/stat.h> | |||||
#include <fcntl.h> | |||||
#include <unistd.h> | |||||
#include <stdlib.h> | #include <stdlib.h> | ||||
#include "cucul.h" | #include "cucul.h" | ||||
@@ -26,12 +22,10 @@ | |||||
int main(int argc, char **argv) | int main(int argc, char **argv) | ||||
{ | { | ||||
struct stat statbuf; | |||||
caca_event_t ev; | caca_event_t ev; | ||||
cucul_buffer_t *b; | |||||
cucul_canvas_t *cv; | cucul_canvas_t *cv; | ||||
caca_display_t *dp; | caca_display_t *dp; | ||||
void *buffer; | |||||
int fd; | |||||
if(argc < 2) | if(argc < 2) | ||||
{ | { | ||||
@@ -39,30 +33,23 @@ int main(int argc, char **argv) | |||||
return 1; | return 1; | ||||
} | } | ||||
fd = open(argv[1], O_RDONLY); | |||||
if(!fd) | |||||
b = cucul_load_file(argv[1]); | |||||
if(!b) | |||||
{ | { | ||||
fprintf(stderr, "%s: could not open %s.\n", argv[0], argv[1]); | fprintf(stderr, "%s: could not open %s.\n", argv[0], argv[1]); | ||||
return 1; | return 1; | ||||
} | } | ||||
if(fstat(fd, &statbuf)) | |||||
{ | |||||
fprintf(stderr, "%s: could not stat %s.\n", argv[0], argv[1]); | |||||
return 1; | |||||
} | |||||
buffer = malloc(statbuf.st_size); | |||||
read(fd, buffer, statbuf.st_size); | |||||
cv = cucul_import_canvas(buffer, statbuf.st_size, "caca"); | |||||
free(buffer); | |||||
cv = cucul_import_canvas(b, "caca"); | |||||
if(!cv) | if(!cv) | ||||
{ | { | ||||
fprintf(stderr, "%s: invalid caca file %s.\n", argv[0], argv[1]); | fprintf(stderr, "%s: invalid caca file %s.\n", argv[0], argv[1]); | ||||
cucul_free_buffer(b); | |||||
return 1; | return 1; | ||||
} | } | ||||
cucul_free_buffer(b); | |||||
dp = caca_create_display(cv); | dp = caca_create_display(cv); | ||||
caca_refresh_display(dp); | caca_refresh_display(dp); | ||||
@@ -204,6 +204,7 @@ int main(void) | |||||
/* Main loop */ | /* Main loop */ | ||||
for(;;) | for(;;) | ||||
{ | { | ||||
cucul_buffer_t *b; | |||||
uint8_t *buf = server->input; | uint8_t *buf = server->input; | ||||
uint32_t width, height; | uint32_t width, height; | ||||
unsigned int size; | unsigned int size; | ||||
@@ -234,7 +235,9 @@ int main(void) | |||||
if(server->canvas) | if(server->canvas) | ||||
cucul_free_canvas(server->canvas); | cucul_free_canvas(server->canvas); | ||||
server->canvas = cucul_import_canvas(buf, size, "caca"); | |||||
b = cucul_load_memory(buf, size); | |||||
server->canvas = cucul_import_canvas(b, "caca"); | |||||
cucul_free_buffer(b); | |||||
if(!server->canvas) | if(!server->canvas) | ||||
continue; /* Load error */ | continue; /* Load error */ | ||||
@@ -27,10 +27,8 @@ | |||||
int main(int argc, char *argv[]) | int main(int argc, char *argv[]) | ||||
{ | { | ||||
cucul_canvas_t *cv; | cucul_canvas_t *cv; | ||||
cucul_buffer_t *b; | |||||
caca_display_t *dp; | caca_display_t *dp; | ||||
FILE *fp; | |||||
unsigned char *buffer; | |||||
int size=0; | |||||
if(argc < 2) | if(argc < 2) | ||||
{ | { | ||||
@@ -38,37 +36,22 @@ int main(int argc, char *argv[]) | |||||
return 1; | return 1; | ||||
} | } | ||||
fp = fopen(argv[1], "rb"); | |||||
if(!fp) | |||||
b = cucul_load_file(argv[1]); | |||||
if(!b) | |||||
{ | { | ||||
fprintf(stderr, "%s: could not open `%s'.\n", argv[0], argv[1]); | fprintf(stderr, "%s: could not open `%s'.\n", argv[0], argv[1]); | ||||
return 1; | return 1; | ||||
} | } | ||||
fseek(fp, 0, SEEK_END); | |||||
size = ftell(fp); | |||||
fseek(fp, 0, SEEK_SET); | |||||
buffer = malloc(sizeof(unsigned char) * size); | |||||
if(!buffer) | |||||
{ | |||||
fprintf(stderr, "%s: Can't allocate memory (%d bytes)\n", argv[0], size); | |||||
return 1; | |||||
} | |||||
if(!fread(buffer, size, 1, fp)) | |||||
{ | |||||
fprintf(stderr, "%s: Can't read %s\n", argv[0], argv[1]); | |||||
return 1; | |||||
} | |||||
cv = cucul_import_canvas(buffer, size, ""); | |||||
if(cv == NULL) | |||||
cv = cucul_import_canvas(b, ""); | |||||
if(!cv) | |||||
{ | { | ||||
fprintf(stderr, "%s: Can't load %s, unknow reason.\n", argv[0], argv[1]); | fprintf(stderr, "%s: Can't load %s, unknow reason.\n", argv[0], argv[1]); | ||||
return 1; | return 1; | ||||
} | } | ||||
cucul_free_buffer(b); | |||||
dp = caca_create_display(cv); | dp = caca_create_display(cv); | ||||
caca_refresh_display(dp); | caca_refresh_display(dp); | ||||
@@ -36,7 +36,9 @@ int main(void) | |||||
cucul_canvas_t *cv; | cucul_canvas_t *cv; | ||||
cucul_buffer_t *buffer; | cucul_buffer_t *buffer; | ||||
cv = cucul_import_canvas(STRING, strlen(STRING), "text"); | |||||
buffer = cucul_load_memory(STRING, strlen(STRING)); | |||||
cv = cucul_import_canvas(buffer, "text"); | |||||
cucul_free_buffer(buffer); | |||||
buffer = cucul_export_canvas(cv, "ansi"); | buffer = cucul_export_canvas(cv, "ansi"); | ||||
fwrite(cucul_get_buffer_data(buffer), | fwrite(cucul_get_buffer_data(buffer), | ||||