Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/keplerproject/luafilesystem.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPeter Melnichenko <mpeterval@gmail.com>2017-09-14 12:15:58 +0300
committerPeter Melnichenko <mpeterval@gmail.com>2017-09-14 12:15:58 +0300
commitd399961536eee59f891a395271bf12d6a0c70c64 (patch)
tree8f3094937cb09b9e46e00248ccf606922fb69fac /src
parent8a7796ec170923267a823566424f818037bca82c (diff)
parenta332bde584756b14298f51e913bdc309f87e7ff8 (diff)
Merge branch '1.7'
Diffstat (limited to 'src')
-rw-r--r--src/lfs.c108
1 files changed, 48 insertions, 60 deletions
diff --git a/src/lfs.c b/src/lfs.c
index be6977e..dc799a4 100644
--- a/src/lfs.c
+++ b/src/lfs.c
@@ -123,6 +123,13 @@ typedef struct dir_data {
#define LSTAT_FUNC lstat
#endif
+#ifdef _WIN32
+ #define lfs_mkdir _mkdir
+#else
+ #define lfs_mkdir(path) (mkdir((path), \
+ S_IRUSR | S_IWUSR | S_IXUSR | S_IRGRP | S_IWGRP | S_IXGRP | S_IROTH | S_IXOTH))
+#endif
+
/*
** Utility functions
*/
@@ -137,12 +144,13 @@ static int pusherror(lua_State *L, const char *info)
return 3;
}
-static int pushresult(lua_State *L, int i, const char *info)
-{
- if (i==-1)
- return pusherror(L, info);
- lua_pushinteger(L, i);
- return 1;
+static int pushresult(lua_State *L, int res, const char *info) {
+ if (res == -1) {
+ return pusherror(L, info);
+ } else {
+ lua_pushboolean(L, 1);
+ return 1;
+ }
}
@@ -424,16 +432,20 @@ static int file_unlock (lua_State *L) {
** @param #2 Name of link.
** @param #3 True if link is symbolic (optional).
*/
-static int make_link(lua_State *L)
-{
+static int make_link (lua_State *L) {
#ifndef _WIN32
- const char *oldpath = luaL_checkstring(L, 1);
- const char *newpath = luaL_checkstring(L, 2);
- return pushresult(L,
- (lua_toboolean(L,3) ? symlink : link)(oldpath, newpath), NULL);
+ const char *oldpath = luaL_checkstring(L, 1);
+ const char *newpath = luaL_checkstring(L, 2);
+ int res = (lua_toboolean(L,3) ? symlink : link)(oldpath, newpath);
+ if (res == -1) {
+ return pusherror(L, NULL);
+ } else {
+ lua_pushinteger(L, 0);
+ return 1;
+ }
#else
- errno = ENOSYS; /* = "Function not implemented" */
- return pushresult(L, -1, "make_link is not supported on Windows");
+ errno = ENOSYS; /* = "Function not implemented" */
+ return pushresult(L, -1, "make_link is not supported on Windows");
#endif
}
@@ -443,21 +455,8 @@ static int make_link(lua_State *L)
** @param #1 Directory path.
*/
static int make_dir (lua_State *L) {
- const char *path = luaL_checkstring (L, 1);
- int fail;
-#ifdef _WIN32
- fail = _mkdir (path);
-#else
- fail = mkdir (path, S_IRUSR | S_IWUSR | S_IXUSR | S_IRGRP |
- S_IWGRP | S_IXGRP | S_IROTH | S_IXOTH );
-#endif
- if (fail) {
- lua_pushnil (L);
- lua_pushfstring (L, "%s", strerror(errno));
- return 2;
- }
- lua_pushboolean (L, 1);
- return 1;
+ const char *path = luaL_checkstring(L, 1);
+ return pushresult(L, lfs_mkdir(path), NULL);
}
@@ -466,18 +465,8 @@ static int make_dir (lua_State *L) {
** @param #1 Directory path.
*/
static int remove_dir (lua_State *L) {
- const char *path = luaL_checkstring (L, 1);
- int fail;
-
- fail = rmdir (path);
-
- if (fail) {
- lua_pushnil (L);
- lua_pushfstring (L, "%s", strerror(errno));
- return 2;
- }
- lua_pushboolean (L, 1);
- return 1;
+ const char *path = luaL_checkstring(L, 1);
+ return pushresult(L, rmdir(path), NULL);
}
@@ -664,26 +653,24 @@ static const char *mode2string (mode_t mode) {
/*
-** Set access time and modification values for file
+** Set access time and modification values for a file.
+** @param #1 File path.
+** @param #2 Access time in seconds, current time is used if missing.
+** @param #3 Modification time in seconds, access time is used if missing.
*/
static int file_utime (lua_State *L) {
- const char *file = luaL_checkstring (L, 1);
- struct utimbuf utb, *buf;
-
- if (lua_gettop (L) == 1) /* set to current date/time */
- buf = NULL;
- else {
- utb.actime = (time_t)luaL_optnumber (L, 2, 0);
- utb.modtime = (time_t) luaL_optinteger (L, 3, utb.actime);
- buf = &utb;
- }
- if (utime (file, buf)) {
- lua_pushnil (L);
- lua_pushfstring (L, "%s", strerror (errno));
- return 2;
- }
- lua_pushboolean (L, 1);
- return 1;
+ const char *file = luaL_checkstring(L, 1);
+ struct utimbuf utb, *buf;
+
+ if (lua_gettop (L) == 1) /* set to current date/time */
+ buf = NULL;
+ else {
+ utb.actime = (time_t) luaL_optnumber(L, 2, 0);
+ utb.modtime = (time_t) luaL_optinteger(L, 3, utb.actime);
+ buf = &utb;
+ }
+
+ return pushresult(L, utime(file, buf), NULL);
}
@@ -820,7 +807,8 @@ static int _file_info_ (lua_State *L, int (*st)(const char*, STAT_STRUCT*)) {
if (st(file, &info)) {
lua_pushnil(L);
lua_pushfstring(L, "cannot obtain information from file '%s': %s", file, strerror(errno));
- return 2;
+ lua_pushinteger(L, errno);
+ return 3;
}
if (lua_isstring (L, 2)) {
const char *member = lua_tostring (L, 2);