+FsRtlCheckLockForReadAccess()
[captive.git] / src / libcaptive / fs / filelock.c
1 /* $Id$
2  * reactos file locking functions emulation of libcaptive
3  * Copyright (C) 2003 Jan Kratochvil <project-captive@jankratochvil.net>
4  * 
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; exactly version 2 of June 1991 is required
8  * 
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  * 
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17  */
18
19
20 #include "config.h"
21
22 #include "reactos/ddk/fsfuncs.h"        /* self */
23 #include <glib/gmessages.h>
24 #include "reactos/ntos/types.h" /* for VOID */
25 #include "reactos/ddk/status.h" /* for STATUS_SUCCESS */
26
27
28 VOID FsRtlInitializeFileLock(IN PFILE_LOCK FileLock,
29                 IN PCOMPLETE_LOCK_IRP_ROUTINE CompleteLockIrpRoutine OPTIONAL,IN PUNLOCK_ROUTINE UnlockRoutine OPTIONAL)
30 {
31         g_return_if_fail(FileLock!=NULL);
32
33         FileLock->CompleteLockIrpRoutine=CompleteLockIrpRoutine;
34         FileLock->UnlockRoutine=UnlockRoutine;
35
36         /* FIXME: NOT IMPLEMENTED YET */
37 }
38
39
40 NTSTATUS FsRtlFastUnlockAll(IN PFILE_LOCK FileLock,IN PFILE_OBJECT FileObject,IN PEPROCESS Process,IN PVOID Context OPTIONAL)
41 {
42         g_return_val_if_fail(FileLock!=NULL,STATUS_INVALID_PARAMETER);
43
44         /* FIXME: NOT IMPLEMENTED YET */
45
46         return STATUS_SUCCESS;
47 }
48
49
50 BOOLEAN FsRtlCheckLockForReadAccess(IN PFILE_LOCK FileLock,IN PIRP Irp)
51 {
52         g_return_val_if_fail(FileLock!=NULL,FALSE);     /* FALSE means 'no access */
53         g_return_val_if_fail(Irp!=NULL,FALSE);  /* FALSE means 'no access */
54
55         return TRUE;    /* permit access */
56 }