~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

Wine Cross Reference
wine/dlls/kernel32/change.c

Version: ~ [ wine-1.5.30 ] ~ [ wine-1.5.29 ] ~ [ wine-1.5.28 ] ~ [ wine-1.5.27 ] ~ [ wine-1.5.26 ] ~ [ wine-1.5.25 ] ~ [ wine-1.5.24 ] ~ [ wine-1.5.23 ] ~ [ wine-1.5.22 ] ~ [ wine-1.5.21 ] ~ [ wine-1.5.20 ] ~ [ wine-1.5.19 ] ~ [ wine-1.5.18 ] ~ [ wine-1.5.17 ] ~ [ wine-1.5.16 ] ~ [ wine-1.5.15 ] ~ [ wine-1.5.14 ] ~ [ wine-1.5.13 ] ~ [ wine-1.5.12 ] ~ [ wine-1.5.11 ] ~ [ wine-1.5.10 ] ~ [ wine-1.5.9 ] ~ [ wine-1.5.8 ] ~ [ wine-1.5.7 ] ~ [ wine-1.4.1 ] ~ [ wine-1.5.6 ] ~ [ wine-1.5.5 ] ~ [ wine-1.5.4 ] ~ [ wine-1.5.3 ] ~ [ wine-1.5.2 ] ~ [ wine-1.5.1 ] ~ [ wine-1.5.0 ] ~ [ wine-1.4 ] ~ [ wine-1.4-rc6 ] ~ [ wine-1.4-rc5 ] ~ [ wine-1.4-rc4 ] ~ [ wine-1.4-rc3 ] ~ [ wine-1.4-rc2 ] ~ [ wine-1.4-rc1 ] ~ [ wine-1.3.37 ] ~ [ wine-1.3.36 ] ~ [ wine-1.3.35 ] ~ [ wine-1.3.34 ] ~ [ wine-1.3.33 ] ~ [ wine-1.3.32 ] ~ [ wine-1.3.31 ] ~ [ wine-1.3.30 ] ~ [ wine-1.3.29 ] ~ [ wine-1.3.28 ] ~ [ wine-1.3.27 ] ~ [ wine-1.3.26 ] ~ [ wine-1.3.25 ] ~ [ wine-1.3.24 ] ~ [ wine-1.3.23 ] ~ [ wine-1.3.22 ] ~ [ wine-1.3.21 ] ~ [ wine-1.3.20 ] ~ [ wine-1.3.19 ] ~ [ wine-1.3.18 ] ~ [ wine-1.2.3 ] ~ [ wine-1.3.17 ] ~ [ wine-1.3.16 ] ~ [ wine-1.3.15 ] ~ [ wine-1.3.14 ] ~ [ wine-1.3.13 ] ~ [ wine-1.3.12 ] ~ [ wine-1.3.11 ] ~ [ wine-1.3.10 ] ~ [ wine-1.3.9 ] ~ [ wine-1.2.2 ] ~ [ wine-1.3.8 ] ~ [ wine-1.3.7 ] ~ [ wine-1.3.6 ] ~ [ wine-1.3.5 ] ~ [ wine-1.2.1 ] ~ [ wine-1.3.4 ] ~ [ wine-1.3.3 ] ~ [ wine-1.3.2 ] ~ [ wine-1.3.1 ] ~ [ wine-1.3.0 ] ~ [ wine-1.2 ] ~ [ wine-1.2-rc7 ] ~ [ wine-1.2-rc6 ] ~ [ wine-1.2-rc5 ] ~ [ wine-1.2-rc4 ] ~ [ wine-1.2-rc3 ] ~ [ wine-1.2-rc2 ] ~ [ wine-1.2-rc1 ] ~ [ wine-1.1.44 ] ~ [ wine-1.1.43 ] ~ [ wine-1.1.42 ] ~ [ wine-1.1.41 ] ~ [ wine-1.1.40 ] ~ [ wine-1.1.39 ] ~ [ wine-1.1.38 ] ~ [ wine-1.1.37 ] ~ [ wine-1.1.36 ] ~ [ wine-1.1.35 ] ~ [ wine-1.1.34 ] ~ [ wine-1.1.33 ] ~ [ wine-1.1.32 ] ~ [ wine-1.1.31 ] ~ [ wine-1.1.30 ] ~ [ wine-1.1.29 ] ~ [ wine-1.1.28 ] ~ [ wine-1.1.27 ] ~ [ wine-1.1.26 ] ~ [ wine-1.1.25 ] ~ [ wine-1.1.24 ] ~ [ wine-1.1.23 ] ~ [ wine-1.1.22 ] ~ [ wine-1.1.21 ] ~ [ wine-1.1.20 ] ~ [ wine-1.1.19 ] ~ [ wine-1.1.18 ] ~ [ wine-1.1.17 ] ~ [ wine-1.1.16 ] ~ [ wine-1.1.15 ] ~ [ wine-1.1.14 ] ~ [ wine-1.1.13 ] ~ [ wine-1.1.12 ] ~ [ wine-1.1.11 ] ~ [ wine-1.1.10 ] ~ [ wine-1.1.9 ] ~ [ wine-1.1.8 ] ~ [ wine-1.1.7 ] ~ [ wine-1.0.1 ] ~ [ wine-1.1.6 ] ~ [ wine-1.1.5 ] ~ [ wine-1.1.4 ] ~ [ wine-1.1.3 ] ~ [ wine-1.1.2 ] ~ [ wine-1.1.1 ] ~ [ wine-1.1.0 ] ~ [ wine-1.0 ] ~

  1 /*
  2  * Win32 file change notification functions
  3  *
  4  * Copyright 1998 Ulrich Weigand
  5  *
  6  * This library is free software; you can redistribute it and/or
  7  * modify it under the terms of the GNU Lesser General Public
  8  * License as published by the Free Software Foundation; either
  9  * version 2.1 of the License, or (at your option) any later version.
 10  *
 11  * This library is distributed in the hope that it will be useful,
 12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 14  * Lesser General Public License for more details.
 15  *
 16  * You should have received a copy of the GNU Lesser General Public
 17  * License along with this library; if not, write to the Free Software
 18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
 19  */
 20 
 21 #include "config.h"
 22 
 23 #include <stdarg.h>
 24 #include <stdlib.h>
 25 #include <string.h>
 26 
 27 #include "ntstatus.h"
 28 #define WIN32_NO_STATUS
 29 #define NONAMELESSUNION
 30 #define NONAMELESSSTRUCT
 31 #include "windef.h"
 32 #include "winbase.h"
 33 #include "winerror.h"
 34 #include "winternl.h"
 35 #include "kernel_private.h"
 36 #include "wine/debug.h"
 37 
 38 WINE_DEFAULT_DEBUG_CHANNEL(file);
 39 
 40 /****************************************************************************
 41  *              FindFirstChangeNotificationA (KERNEL32.@)
 42  */
 43 HANDLE WINAPI FindFirstChangeNotificationA( LPCSTR lpPathName, BOOL bWatchSubtree,
 44                                             DWORD dwNotifyFilter )
 45 {
 46     WCHAR *pathW;
 47 
 48     if (!(pathW = FILE_name_AtoW( lpPathName, FALSE ))) return INVALID_HANDLE_VALUE;
 49     return FindFirstChangeNotificationW( pathW, bWatchSubtree, dwNotifyFilter );
 50 }
 51 
 52 /*
 53  * NtNotifyChangeDirectoryFile may write back to the IO_STATUS_BLOCK
 54  * asynchronously.  We don't care about the contents, but it can't
 55  * be placed on the stack since it will go out of scope when we return.
 56  */
 57 static IO_STATUS_BLOCK FindFirstChange_iosb;
 58 
 59 /****************************************************************************
 60  *              FindFirstChangeNotificationW (KERNEL32.@)
 61  */
 62 HANDLE WINAPI FindFirstChangeNotificationW( LPCWSTR lpPathName, BOOL bWatchSubtree,
 63                                             DWORD dwNotifyFilter)
 64 {
 65     UNICODE_STRING nt_name;
 66     OBJECT_ATTRIBUTES attr;
 67     NTSTATUS status;
 68     HANDLE handle = INVALID_HANDLE_VALUE;
 69 
 70     TRACE( "%s %d %x\n", debugstr_w(lpPathName), bWatchSubtree, dwNotifyFilter );
 71 
 72     if (!RtlDosPathNameToNtPathName_U( lpPathName, &nt_name, NULL, NULL ))
 73     {
 74         SetLastError( ERROR_PATH_NOT_FOUND );
 75         return handle;
 76     }
 77 
 78     attr.Length = sizeof(attr);
 79     attr.RootDirectory = 0;
 80     attr.Attributes = OBJ_CASE_INSENSITIVE;
 81     attr.ObjectName = &nt_name;
 82     attr.SecurityDescriptor = NULL;
 83     attr.SecurityQualityOfService = NULL;
 84 
 85     status = NtOpenFile( &handle, FILE_LIST_DIRECTORY | SYNCHRONIZE,
 86                          &attr, &FindFirstChange_iosb,
 87                          FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE,
 88                          FILE_DIRECTORY_FILE | FILE_SYNCHRONOUS_IO_NONALERT );
 89     RtlFreeUnicodeString( &nt_name );
 90 
 91     if (status != STATUS_SUCCESS)
 92     {
 93         SetLastError( RtlNtStatusToDosError(status) );
 94         return INVALID_HANDLE_VALUE;
 95     }
 96 
 97     status = NtNotifyChangeDirectoryFile( handle, NULL, NULL, NULL,
 98                                           &FindFirstChange_iosb,
 99                                           NULL, 0, dwNotifyFilter, bWatchSubtree );
100     if (status != STATUS_PENDING)
101     {
102         NtClose( handle );
103         SetLastError( RtlNtStatusToDosError(status) );
104         return INVALID_HANDLE_VALUE;
105     }
106     return handle;
107 }
108 
109 /****************************************************************************
110  *              FindNextChangeNotification (KERNEL32.@)
111  */
112 BOOL WINAPI FindNextChangeNotification( HANDLE handle )
113 {
114     NTSTATUS status;
115 
116     TRACE("%p\n",handle);
117 
118     status = NtNotifyChangeDirectoryFile( handle, NULL, NULL, NULL,
119                                           &FindFirstChange_iosb,
120                                           NULL, 0, FILE_NOTIFY_CHANGE_SIZE, 0 );
121     if (status != STATUS_PENDING)
122     {
123         SetLastError( RtlNtStatusToDosError(status) );
124         return FALSE;
125     }
126     return TRUE;
127 }
128 
129 /****************************************************************************
130  *              FindCloseChangeNotification (KERNEL32.@)
131  */
132 BOOL WINAPI FindCloseChangeNotification( HANDLE handle )
133 {
134     return CloseHandle( handle );
135 }
136 
137 /****************************************************************************
138  *              ReadDirectoryChangesW (KERNEL32.@)
139  *
140  * NOTES
141  *
142  *  The filter is remember from the first run and ignored on successive runs.
143  *
144  *  If there's no output buffer on the first run, it's ignored successive runs
145  *   and STATUS_NOTIFY_ENUM_DIRECTORY is returned with an empty buffer.
146  *
147  *  If a NULL overlapped->hEvent is passed, the directory handle is used
148  *   for signalling.
149  */
150 BOOL WINAPI ReadDirectoryChangesW( HANDLE handle, LPVOID buffer, DWORD len, BOOL subtree,
151                                    DWORD filter, LPDWORD returned, LPOVERLAPPED overlapped,
152                                    LPOVERLAPPED_COMPLETION_ROUTINE completion )
153 {
154     OVERLAPPED ov, *pov;
155     IO_STATUS_BLOCK *ios;
156     NTSTATUS status;
157     BOOL ret = TRUE;
158     LPVOID cvalue = NULL;
159 
160     TRACE("%p %p %08x %d %08x %p %p %p\n", handle, buffer, len, subtree, filter,
161            returned, overlapped, completion );
162 
163     if (!overlapped)
164     {
165         memset( &ov, 0, sizeof ov );
166         ov.hEvent = CreateEventW( NULL, 0, 0, NULL );
167         pov = &ov;
168     }
169     else
170     {
171         pov = overlapped;
172         if (!completion && ((ULONG_PTR)overlapped->hEvent & 1) == 0) cvalue = overlapped;
173     }
174 
175     ios = (PIO_STATUS_BLOCK) pov;
176     ios->u.Status = STATUS_PENDING;
177 
178     status = NtNotifyChangeDirectoryFile( handle, pov->hEvent, NULL, cvalue,
179                                           ios, buffer, len, filter, subtree );
180     if (status == STATUS_PENDING)
181     {
182         if (overlapped)
183             return TRUE;
184 
185         WaitForSingleObjectEx( ov.hEvent, INFINITE, TRUE );
186         CloseHandle( ov.hEvent );
187         if (returned)
188             *returned = ios->Information;
189         status = ios->u.Status;
190     }
191 
192     if (status != STATUS_SUCCESS)
193     {
194         SetLastError( RtlNtStatusToDosError(status) );
195         ret = FALSE;
196     }
197 
198     return ret;
199 }
200 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~ [ freetext search ] ~ [ file search ] ~

This page was automatically generated by the LXR engine.
Visit the LXR main site for more information.