diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-12-02 07:57:17 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-12-02 07:57:17 +0000 |
commit | 4d6d2ae1b417133546c56b3150ef51fa7647e2dc (patch) | |
tree | 4198e3ccd0a5bab17db2a0f82ee7b6c643115c69 /wince/direct.c | |
parent | 1668ec3e5ce555161454e9b2657c89dc27fa1364 (diff) | |
download | ruby-4d6d2ae1b417133546c56b3150ef51fa7647e2dc.tar.gz ruby-4d6d2ae1b417133546c56b3150ef51fa7647e2dc.tar.xz ruby-4d6d2ae1b417133546c56b3150ef51fa7647e2dc.zip |
WinCE patch merged
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@3106 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'wince/direct.c')
-rw-r--r-- | wince/direct.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/wince/direct.c b/wince/direct.c new file mode 100644 index 000000000..6cffc40e3 --- /dev/null +++ b/wince/direct.c @@ -0,0 +1,54 @@ +/*************************************************************** + direct.c +***************************************************************/ + +#include <windows.h> +#include <tchar.h> +#include <direct.h> +#include "wince.h" /* for wce_mbtowc */ + +/* global for chdir, getcwd */ +static char _currentdir[MAX_PATH+1]; + + +char *_getcwd(char* buffer, int maxlen) +{ + strcpy( buffer, _currentdir ); + return buffer; +} + +int _chdir(const char * dirname) +{ + if( MAX_PATH < strlen(dirname) ) + return -1; + + strcpy( _currentdir, dirname ); + return 0; +} + +int _rmdir(const char * dir) +{ + wchar_t *wdir; + BOOL rc; + + /* replace with RemoveDirectory. */ + wdir = wce_mbtowc(dir); + rc = RemoveDirectoryW(wdir); + free(wdir); + + return rc==TRUE ? 0 : -1; +} + +int _mkdir(const char * dir) +{ + wchar_t* wdir; + BOOL rc; + + /* replace with CreateDirectory. */ + wdir = wce_mbtowc(dir); + rc = CreateDirectoryW(wdir, NULL); + free(wdir); + + return rc==TRUE ? 0 : -1; +} + |