summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXavier Leroy <xavier.leroy@inria.fr>2001-04-10 11:15:05 +0000
committerXavier Leroy <xavier.leroy@inria.fr>2001-04-10 11:15:05 +0000
commit2c30b7b1912b31dec86096aa532f91e1dd15ddc0 (patch)
tree46e4175c4692b68ceacd24ed317871e87f55284f
parent7646d818a217e7c4019bb7b6f036ae1a597941af (diff)
downloadocaml-2c30b7b1912b31dec86096aa532f91e1dd15ddc0.tar.gz
Ajout de link pour W2K (L. Fourquaux)
git-svn-id: http://caml.inria.fr/svn/ocaml/trunk@3487 f963ae5c-01c2-4b8c-9fe0-0dff7051ff02
-rw-r--r--otherlibs/win32unix/Makefile.nt2
-rw-r--r--otherlibs/win32unix/link.c41
-rw-r--r--otherlibs/win32unix/unix.ml2
3 files changed, 43 insertions, 2 deletions
diff --git a/otherlibs/win32unix/Makefile.nt b/otherlibs/win32unix/Makefile.nt
index e21cd1b1f6..f7931d27e5 100644
--- a/otherlibs/win32unix/Makefile.nt
+++ b/otherlibs/win32unix/Makefile.nt
@@ -24,7 +24,7 @@ CAMLOPT=..\..\boot\ocamlrun ..\..\ocamlopt -I ..\..\stdlib
WIN_OBJS = accept.obj bind.obj channels.obj close.obj \
close_on.obj connect.obj createprocess.obj dup.obj dup2.obj \
getpeername.obj getpid.obj getsockname.obj gettimeofday.obj \
- listen.obj lseek.obj \
+ link.obj listen.obj lseek.obj \
mkdir.obj open.obj pipe.obj read.obj select.obj sendrecv.obj \
shutdown.obj sleep.obj socket.obj sockopt.obj startup.obj system.obj \
unixsupport.obj windir.obj winwait.obj write.obj
diff --git a/otherlibs/win32unix/link.c b/otherlibs/win32unix/link.c
new file mode 100644
index 0000000000..cc05646cb7
--- /dev/null
+++ b/otherlibs/win32unix/link.c
@@ -0,0 +1,41 @@
+/***********************************************************************/
+/* */
+/* Objective Caml */
+/* */
+/* File contributed by Lionel Fourquaux */
+/* */
+/* Copyright 2001 Institut National de Recherche en Informatique et */
+/* en Automatique. All rights reserved. This file is distributed */
+/* under the terms of the GNU Library General Public License. */
+/* */
+/***********************************************************************/
+
+/* $Id$ */
+
+#include <windows.h>
+#include <mlvalues.h>
+#include <fail.h>
+#include "unixsupport.h"
+
+typedef
+BOOL (WINAPI *tCreateHardLink)(
+ LPCTSTR lpFileName,
+ LPCTSTR lpExistingFileName,
+ LPSECURITY_ATTRIBUTES lpSecurityAttributes
+);
+
+value unix_link(value path1, value path2) /* ML */
+{
+ HMODULE hModKernel32;
+ tCreateHardLink pCreateHardLink;
+ hModKernel32 = GetModuleHandle("KERNEL32.DLL");
+ pCreateHardLink =
+ (tCreateHardLink) GetProcAddress(hModKernel32, "CreateHardLinkA");
+ if (pCreateHardLink == NULL)
+ invalid_argument("Unix.link not implemented");
+ if (! pCreateHardLink(String_val(path2), String_val(path1), NULL)) {
+ _dosmaperr(GetLastError());
+ uerror("link", path2);
+ }
+ return Val_unit;
+}
diff --git a/otherlibs/win32unix/unix.ml b/otherlibs/win32unix/unix.ml
index 25cc960ec3..1beaa96177 100644
--- a/otherlibs/win32unix/unix.ml
+++ b/otherlibs/win32unix/unix.ml
@@ -251,7 +251,7 @@ let fstat fd = invalid_arg "Unix.fstat not implemented"
external unlink : string -> unit = "unix_unlink"
external rename : string -> string -> unit = "unix_rename"
-let link f1 f2 = invalid_arg "Unix.link not implemented"
+external link : string -> string -> unit = "unix_link"
(* File permissions and ownership *)