提交 e39022f3 编写于 作者: I iamyhw@gmail.com

dfs: add format flag O_BINARY

lzo: change to use posix interface.

git-svn-id: https://rt-thread.googlecode.com/svn/trunk@2283 bbd45198-f89e-11dd-88c7-29a3b14d5316
上级 c6c2a504
...@@ -183,6 +183,7 @@ ...@@ -183,6 +183,7 @@
#define DFS_O_EXCL 0x0000200 #define DFS_O_EXCL 0x0000200
#define DFS_O_TRUNC 0x0001000 #define DFS_O_TRUNC 0x0001000
#define DFS_O_APPEND 0x0002000 #define DFS_O_APPEND 0x0002000
#define DFS_O_BINARY 0x0008000
#define DFS_O_DIRECTORY 0x0200000 #define DFS_O_DIRECTORY 0x0200000
/* File flags */ /* File flags */
......
...@@ -29,6 +29,7 @@ ...@@ -29,6 +29,7 @@
#define O_EXCL DFS_O_EXCL #define O_EXCL DFS_O_EXCL
#define O_TRUNC DFS_O_TRUNC #define O_TRUNC DFS_O_TRUNC
#define O_APPEND DFS_O_APPEND #define O_APPEND DFS_O_APPEND
#define O_BINARY DFS_O_BINARY
#define O_DIRECTORY DFS_O_DIRECTORY #define O_DIRECTORY DFS_O_DIRECTORY
#define S_IFMT DFS_S_IFMT #define S_IFMT DFS_S_IFMT
......
...@@ -10,13 +10,22 @@ ...@@ -10,13 +10,22 @@
*/ */
#include <rtthread.h> #include <rtthread.h>
#include "minilzo.h" #include "minilzo.h"
#include <rtgui/rtgui_config.h>
#include <rtgui/filerw.h>
#ifdef RT_USING_FINSH #ifdef RT_USING_FINSH
#include <finsh.h> #include <finsh.h>
#endif #endif
#define RT_USING_LZO #define RT_USING_LZO
#if defined(RT_USING_LZO) && defined(RTGUI_USING_DFS_FILERW) #if defined(RT_USING_LZO) && defined(RT_USING_DFS)
#ifdef _WIN32
#pragma warning(disable: 4996)
#include <fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <io.h>
#else
#include <dfs_posix.h>
#endif
/* the worst of allocation */ /* the worst of allocation */
#define LZO1X_WORST(x) ( (x) + ((x)/16) + 64 + 3 ) #define LZO1X_WORST(x) ( (x) + ((x)/16) + 64 + 3 )
...@@ -47,7 +56,7 @@ char* parse_lzo_error_code(int error_code) ...@@ -47,7 +56,7 @@ char* parse_lzo_error_code(int error_code)
int lzo(char *srcfile, char *destfile) int lzo(char *srcfile, char *destfile)
{ {
int result; int result;
struct rtgui_filerw *file; int fd;
struct stat s; struct stat s;
lzo_bytep in; lzo_bytep in;
lzo_bytep out; lzo_bytep out;
...@@ -62,14 +71,14 @@ int lzo(char *srcfile, char *destfile) ...@@ -62,14 +71,14 @@ int lzo(char *srcfile, char *destfile)
out = rt_malloc(LZO1X_WORST(in_len)); out = rt_malloc(LZO1X_WORST(in_len));
if (out == RT_NULL) return -1; if (out == RT_NULL) return -1;
file = rtgui_filerw_create_file(srcfile, "rb"); fd = open(srcfile, O_RDONLY, 0);
if(file == RT_NULL) if(fd < 0)
{ {
result = -1; result = -1;
goto _exit; goto _exit;
} }
rtgui_filerw_read(file, in, in_len, 1); read(fd, in, in_len);
rtgui_filerw_close(file); close(fd);
result = lzo1x_1_compress(in, in_len, out, &out_len, wrkmem); result = lzo1x_1_compress(in, in_len, out, &out_len, wrkmem);
if(result != LZO_E_OK) if(result != LZO_E_OK)
...@@ -79,16 +88,16 @@ int lzo(char *srcfile, char *destfile) ...@@ -79,16 +88,16 @@ int lzo(char *srcfile, char *destfile)
goto _exit; goto _exit;
} }
file = rtgui_filerw_create_file(destfile, "wb"); fd = open(destfile, O_WRONLY | O_BINARY | O_CREAT, 0);
if(file == RT_NULL) if(fd < 0)
{ {
result = -1; result = -1;
goto _exit; goto _exit;
} }
rtgui_filerw_write(file, &in_len, sizeof(lzo_uint), 1); /* source file len */ write(fd, &in_len, sizeof(lzo_uint)); /* source file len */
rtgui_filerw_write(file, out, out_len, 1); write(fd, out, out_len);
rtgui_filerw_close(file); close(fd);
rt_kprintf("compress lzo ok!\n"); rt_kprintf("compress lzo ok!\n");
result = 0; result = 0;
...@@ -104,7 +113,7 @@ FINSH_FUNCTION_EXPORT(lzo, compress a file. usage:lzo(src, dest)); ...@@ -104,7 +113,7 @@ FINSH_FUNCTION_EXPORT(lzo, compress a file. usage:lzo(src, dest));
int lzode(char *srcfile, char *destfile) int lzode(char *srcfile, char *destfile)
{ {
int result; int result;
struct rtgui_filerw *file; int fd;
struct stat s; struct stat s;
lzo_bytep in=RT_NULL; lzo_bytep in=RT_NULL;
lzo_bytep out=RT_NULL; lzo_bytep out=RT_NULL;
...@@ -114,18 +123,18 @@ int lzode(char *srcfile, char *destfile) ...@@ -114,18 +123,18 @@ int lzode(char *srcfile, char *destfile)
stat(srcfile, &s); stat(srcfile, &s);
in_len = s.st_size; in_len = s.st_size;
file = rtgui_filerw_create_file(srcfile, "rb"); fd = open(srcfile, O_RDONLY, 0);
if(file == RT_NULL) return 0; if(fd < 0) return 0;
rtgui_filerw_read(file, &out_len, sizeof(lzo_uint), 1); /* source file len */ read(fd, &out_len, sizeof(lzo_uint)); /* source file len */
in_len -= sizeof(lzo_uint); in_len -= sizeof(lzo_uint);
in = rt_malloc(in_len); in = rt_malloc(in_len);
if (in == RT_NULL) return -1; if (in == RT_NULL) return -1;
out = rt_malloc(out_len); out = rt_malloc(out_len);
if (out == RT_NULL) return -1; if (out == RT_NULL) return -1;
rtgui_filerw_read(file, in, in_len, 1); read(fd, in, in_len);
rtgui_filerw_close(file); close(fd);
result = lzo1x_decompress(in, in_len, out, &out_len, RT_NULL); result = lzo1x_decompress(in, in_len, out, &out_len, RT_NULL);
if(result != LZO_E_OK) if(result != LZO_E_OK)
...@@ -135,14 +144,14 @@ int lzode(char *srcfile, char *destfile) ...@@ -135,14 +144,14 @@ int lzode(char *srcfile, char *destfile)
goto _exit; goto _exit;
} }
file = rtgui_filerw_create_file(destfile, "wb"); fd = open(destfile, O_WRONLY | O_BINARY | O_CREAT, 0);
if(file == RT_NULL) if(fd < 0)
{ {
result = -1; result = -1;
goto _exit; goto _exit;
} }
rtgui_filerw_write(file, out, out_len, 1); write(fd, out, out_len);
rtgui_filerw_close(file); close(fd);
rt_kprintf("decompress lzo ok!\n"); rt_kprintf("decompress lzo ok!\n");
result = 0; result = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册