123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- using System;
- using System.Collections.Generic;
- using System.Text;
- namespace SMBLibrary.Win32
- {
- internal class PendingRequestCollection
- {
- private Dictionary<IntPtr, List<PendingRequest>> m_handleToNotifyChangeRequests = new Dictionary<IntPtr, List<PendingRequest>>();
- public void Add(PendingRequest request)
- {
- lock (m_handleToNotifyChangeRequests)
- {
- List<PendingRequest> pendingRequests;
- bool containsKey = m_handleToNotifyChangeRequests.TryGetValue(request.FileHandle, out pendingRequests);
- if (containsKey)
- {
- pendingRequests.Add(request);
- }
- else
- {
- pendingRequests = new List<PendingRequest>();
- pendingRequests.Add(request);
- m_handleToNotifyChangeRequests.Add(request.FileHandle, pendingRequests);
- }
- }
- }
- public void Remove(IntPtr handle, uint threadID)
- {
- lock (m_handleToNotifyChangeRequests)
- {
- List<PendingRequest> pendingRequests;
- bool containsKey = m_handleToNotifyChangeRequests.TryGetValue(handle, out pendingRequests);
- if (containsKey)
- {
- for (int index = 0; index < pendingRequests.Count; index++)
- {
- if (pendingRequests[index].ThreadID == threadID)
- {
- pendingRequests.RemoveAt(index);
- index--;
- }
- }
- if (pendingRequests.Count == 0)
- {
- m_handleToNotifyChangeRequests.Remove(handle);
- }
- }
- }
- }
- public List<PendingRequest> GetRequestsByHandle(IntPtr handle)
- {
- List<PendingRequest> pendingRequests;
- bool containsKey = m_handleToNotifyChangeRequests.TryGetValue((IntPtr)handle, out pendingRequests);
- if (containsKey)
- {
- return new List<PendingRequest>(pendingRequests);
- }
- return new List<PendingRequest>();
- }
- }
- }
|