summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/fhandler_socket.cc
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2005-02-19 20:03:18 +0000
committerCorinna Vinschen <corinna@vinschen.de>2005-02-19 20:03:18 +0000
commitc2d0b9d89a3406e8905efa8fe58f9d948242e028 (patch)
tree2c543419a28ac35878e8c8b1cbe4c41881417c80 /winsup/cygwin/fhandler_socket.cc
parent2d7606a594bc02f4213fb14d780702d9be270e7f (diff)
downloadcygnal-c2d0b9d89a3406e8905efa8fe58f9d948242e028.tar.gz
cygnal-c2d0b9d89a3406e8905efa8fe58f9d948242e028.tar.bz2
cygnal-c2d0b9d89a3406e8905efa8fe58f9d948242e028.zip
* fhandler.h (class fhandler_socket): Declare new methods fchown,
fchmod and facl. * fhandler_socket.cc (fhandler_socket::fstat): Handle AF_LOCAL sockets. (fhandler_socket::fchmod): New method. (fhandler_socket::fchown): New method. (fhandler_socket::facl): New method.
Diffstat (limited to 'winsup/cygwin/fhandler_socket.cc')
-rw-r--r--winsup/cygwin/fhandler_socket.cc62
1 files changed, 57 insertions, 5 deletions
diff --git a/winsup/cygwin/fhandler_socket.cc b/winsup/cygwin/fhandler_socket.cc
index 4f5552662..757c5a76b 100644
--- a/winsup/cygwin/fhandler_socket.cc
+++ b/winsup/cygwin/fhandler_socket.cc
@@ -34,6 +34,7 @@
#include "select.h"
#include "wininfo.h"
#include <unistd.h>
+#include <sys/acl.h>
extern bool fdsock (cygheap_fdmanip& fd, const device *, SOCKET soc);
extern "C" {
@@ -386,17 +387,68 @@ fhandler_socket::dup (fhandler_base *child)
int __stdcall
fhandler_socket::fstat (struct __stat64 *buf)
{
- int res = fhandler_base::fstat (buf);
- if (!res)
+ int res;
+ if (get_device () == FH_UNIX)
{
- buf->st_dev = 0;
- buf->st_ino = (__ino64_t) ((DWORD) get_handle ());
- buf->st_mode = S_IFSOCK | S_IRWXU | S_IRWXG | S_IRWXO;
+ res = fhandler_base::fstat_fs (buf);
+ if (!res)
+ {
+ buf->st_mode = (buf->st_mode & ~S_IFMT) | S_IFSOCK;
+ }
+ }
+ else
+ {
+ res = fhandler_base::fstat (buf);
+ if (!res)
+ {
+ buf->st_dev = 0;
+ buf->st_ino = (__ino64_t) ((DWORD) get_handle ());
+ buf->st_mode = S_IFSOCK | S_IRWXU | S_IRWXG | S_IRWXO;
+ }
}
return res;
}
int
+fhandler_socket::fchmod (mode_t mode)
+{
+ if (get_device () == FH_UNIX)
+ {
+ fhandler_disk_file fh;
+ fh.set_name (pc);
+ fh.get_device () = FH_FS;
+ int ret = fh.fchmod (mode);
+ SetFileAttributes (pc, GetFileAttributes (pc) | FILE_ATTRIBUTE_SYSTEM);
+ return ret;
+ }
+ return 0;
+}
+
+int
+fhandler_socket::fchown (__uid32_t uid, __gid32_t gid)
+{
+ if (get_device () == FH_UNIX)
+ {
+ fhandler_disk_file fh;
+ fh.set_name (pc);
+ return fh.fchown (uid, gid);
+ }
+ return 0;
+}
+
+int
+fhandler_socket::facl (int cmd, int nentries, __aclent32_t *aclbufp)
+{
+ if (get_device () == FH_UNIX)
+ {
+ fhandler_disk_file fh;
+ fh.set_name (pc);
+ return fh.facl (cmd, nentries, aclbufp);
+ }
+ return fhandler_base::facl (cmd, nentries, aclbufp);
+}
+
+int
fhandler_socket::bind (const struct sockaddr *name, int namelen)
{
int res = -1;