Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

213 lines
8.3 KiB

  1. //+-------------------------------------------------------------------------
  2. //
  3. // Microsoft Windows
  4. // Copyright (C) Microsoft Corporation, 1998.
  5. //
  6. // File: Hndlrq.h
  7. //
  8. // Contents: Keeps tracks of Handlers and UI assignments
  9. //
  10. // Classes: CHndlrQueue
  11. //
  12. // Notes:
  13. //
  14. // History: 05-Nov-97 rogerg Created.
  15. // 17-Nov-97 susia Converted to an Autosync Queue
  16. //
  17. //--------------------------------------------------------------------------
  18. #ifndef _HANDLERQUEUE_
  19. #define _HANDLERQUEUE_
  20. typedef enum _tagHANDLERSTATE
  21. {
  22. HANDLERSTATE_CREATE = 0x01, // state is initialized to this.
  23. HANDLERSTATE_INCREATE = 0x02, // state is initialized to this.
  24. HANDLERSTATE_INITIALIZE = 0x03, // set after a successfull creation.
  25. HANDLERSTATE_ININITIALIZE = 0x04, // set during initialization call
  26. HANDLERSTATE_ADDHANDLERTEMS = 0x05, // items need to be enumerated
  27. HANDLERSTATE_INADDHANDLERITEMS = 0x06, // in the items enumerator
  28. HANDLERSTATE_PREPAREFORSYNC = 0x07, // set during queue tranfers
  29. HANDLERSTATE_INPREPAREFORSYNC = 0x08, // handler is currently in a prepfosync call.
  30. HANDLERSTATE_DEAD = 0x0F, // handler has been released. Data Stays around.
  31. } HANDLERSTATE;
  32. typedef enum _tagQUEUETYPE
  33. {
  34. QUEUETYPE_SETTINGS = 0x3, // set during queue tranfers
  35. QUEUETYPE_SCHEDULE = 0x4, // set during queue tranfers
  36. } QUEUETYPE;
  37. // so can share the queue with AutoSync and Idle just define a checkstate struct
  38. // to keep track of items.
  39. typedef struct _tagITEMCHECKSTATE
  40. {
  41. DWORD dwAutoSync;
  42. DWORD dwIdle;
  43. DWORD dwSchedule;
  44. } ITEMCHECKSTATE;
  45. typedef struct _ITEMLIST
  46. {
  47. struct _ITEMLIST *pnextItem;
  48. WORD wItemId; // Id that uniquely identifies Item within a handler.
  49. void *pHandlerInfo; // pointer to the handler that owns this item
  50. INT iItem; // Index of Item in the current ListView.!!!Initialize to -1
  51. SYNCMGRITEM offlineItem; // enumerator structure item returned
  52. ITEMCHECKSTATE *pItemCheckState; // list of check states per connection
  53. } ITEMLIST;
  54. typedef ITEMLIST* LPITEMLIST;
  55. typedef struct _HANDLERINFO {
  56. struct _HANDLERINFO *pNextHandler; // next handler in queue
  57. WORD wHandlerId; // Id that uniquely identifies this instance of the Handler
  58. CLSID clsidHandler; // CLSID of the handler Handler
  59. SYNCMGRHANDLERINFO SyncMgrHandlerInfo; // copy of handler info GetHandlerInfo CallHANDLERSTATE HandlerState; // Current state of the handler
  60. HANDLERSTATE HandlerState;
  61. DWORD dwRegistrationFlags; // flags as item is registered
  62. DWORD dwSyncFlags; // sync flags originally passed in Initialize.
  63. WORD wItemCount; // number of items on this handler
  64. LPITEMLIST pFirstItem; // ptr to first Item of the handler in the list.
  65. LPSYNCMGRSYNCHRONIZE pSyncMgrHandler;
  66. } HANDLERINFO;
  67. typedef HANDLERINFO* LPHANDLERINFO;
  68. class CHndlrQueue {
  69. private:
  70. LPHANDLERINFO m_pFirstHandler; // first handler in queue
  71. WORD m_wHandlerCount; // number of handlers in this queue
  72. QUEUETYPE m_QueueType; // type of queue this is.
  73. CRITICAL_SECTION m_CriticalSection; // critical section for the queue.
  74. LPCONNECTIONSETTINGS m_ConnectionList; // hold the settings per connection
  75. int m_ConnectionCount; // number of connections
  76. BOOL m_fItemsMissing; // set if any handlers have missing items.
  77. public:
  78. CHndlrQueue(QUEUETYPE QueueType);
  79. ~CHndlrQueue();
  80. STDMETHODIMP Init();
  81. STDMETHODIMP_(ULONG) AddRef();
  82. STDMETHODIMP_(ULONG) Release();
  83. // main queue routines
  84. STDMETHODIMP AddHandler(REFCLSID clsidHandler, WORD *wHandlerId);
  85. STDMETHODIMP RemoveHandler(WORD wHandlerId);
  86. STDMETHODIMP FreeAllHandlers(void);
  87. // For updating hWnd and ListView Information.
  88. STDMETHODIMP GetHandlerInfo(REFCLSID clsidHandler,LPSYNCMGRHANDLERINFO pSyncMgrHandlerInfo);
  89. STDMETHODIMP FindFirstHandlerInState
  90. (HANDLERSTATE hndlrState,
  91. WORD *wHandlerID);
  92. STDMETHODIMP FindNextHandlerInState
  93. (WORD wLastHandlerID,
  94. HANDLERSTATE hndlrState,
  95. WORD *wHandlerID);
  96. STDMETHODIMP GetHandlerIDFromClsid
  97. (REFCLSID clsidHandlerIn,
  98. WORD *pwHandlerId);
  99. STDMETHODIMP FindFirstItemOnConnection
  100. (TCHAR *pszConnectionName,
  101. CLSID *pclsidHandler,
  102. SYNCMGRITEMID* OfflineItemID,
  103. WORD *pwHandlerId,WORD *pwItemID);
  104. STDMETHODIMP FindNextItemOnConnection
  105. (TCHAR *pszConnectionName,
  106. WORD wLastHandlerId,
  107. WORD wLastItemID,
  108. CLSID *pclsidHandler,
  109. SYNCMGRITEMID* OfflineItemID,
  110. WORD *pwHandlerId,
  111. WORD *pwItemID,
  112. BOOL fAllHandlers,
  113. DWORD *pdwCheckState);
  114. STDMETHODIMP GetSyncItemDataOnConnection
  115. (int iConnectionIndex,
  116. WORD wHandlerId,
  117. WORD wItemID,
  118. CLSID *pclsidHandler,
  119. SYNCMGRITEM* offlineItem,
  120. ITEMCHECKSTATE *pItemCheckState,
  121. BOOL fSchedSync,
  122. BOOL fClear);
  123. STDMETHODIMP SetSyncCheckStateFromListViewItem
  124. (SYNCTYPE SyncType,INT iItem,
  125. BOOL fChecked,
  126. INT iConnectionItem);
  127. //AutoSync specific methods
  128. STDMETHODIMP ReadSyncSettingsPerConnection(SYNCTYPE syncType,WORD wHandlerID);
  129. STDMETHODIMP InitSyncSettings(SYNCTYPE syncType,HWND hwndRasCombo);
  130. STDMETHODIMP CommitSyncChanges(SYNCTYPE syncType,CRasUI *pRas);
  131. // Idle Specific methods.
  132. STDMETHODIMP ReadAdvancedIdleSettings(LPCONNECTIONSETTINGS pConnectionSettings);
  133. STDMETHODIMP WriteAdvancedIdleSettings(LPCONNECTIONSETTINGS pConnectionSettings);
  134. //SchedSync specific methods
  135. STDMETHODIMP ReadSchedSyncSettingsOnConnection(WORD wHandlerID, TCHAR *pszSchedName);
  136. STDMETHODIMP InitSchedSyncSettings(LPCONNECTIONSETTINGS pConnectionSettings);
  137. STDMETHODIMP CommitSchedSyncChanges(TCHAR * pszSchedName,
  138. TCHAR * pszFriendlyName,
  139. TCHAR * pszConnectionName,
  140. DWORD dwConnType,BOOL fCleanReg);
  141. STDMETHODIMP InsertItem(LPHANDLERINFO pCurHandler,
  142. LPSYNC_HANDLER_ITEM_INFO pHandlerItemInfo);
  143. STDMETHODIMP AddHandlerItem(LPSYNC_HANDLER_ITEM_INFO pHandlerItemInfo);
  144. STDMETHODIMP SetItemCheck(REFCLSID pclsidHandler,
  145. SYNCMGRITEMID *OfflineItemID, DWORD dwCheckState);
  146. STDMETHODIMP GetItemCheck(REFCLSID pclsidHandler,
  147. SYNCMGRITEMID *OfflineItemID, DWORD *pdwCheckState);
  148. STDMETHODIMP SetItemListViewID(CLSID clsidHandler,SYNCMGRITEMID OfflineItemID,INT iItem); // assigns list view ID to an Item.
  149. DWORD GetCheck(WORD wParam, INT iItem);
  150. STDMETHODIMP SetConnectionCheck(WORD wParam, DWORD dwState, INT iConnectionItem);
  151. STDMETHODIMP ListViewItemHasProperties(INT iItem); // determines if there are properties associated with this item.
  152. STDMETHODIMP ShowProperties(HWND hwndParent,INT iItem); // show properties for this listView Item.
  153. STDMETHODIMP CreateServer(WORD wHandlerId, const CLSID *pCLSIDServer);
  154. STDMETHODIMP Initialize(WORD wHandlerId,DWORD dwReserved,DWORD dwSyncFlags,
  155. DWORD cbCookie,const BYTE *lpCookie);
  156. STDMETHODIMP SetHandlerInfo(WORD wHandlerId,LPSYNCMGRHANDLERINFO pSyncMgrHandlerInfo);
  157. STDMETHODIMP AddHandlerItemsToQueue(WORD wHandlerId);
  158. STDMETHODIMP AddItemToHandler(WORD wHandlerId,SYNCMGRITEM *pOffineItem);
  159. STDMETHODIMP GetItemName(WORD wHandlerId, WORD wItemID, WCHAR *pwszName, UINT cchName);
  160. STDMETHODIMP GetItemIcon(WORD wHandlerId, WORD wItemID, HICON *phIcon);
  161. private:
  162. // private functions for finding proper handlers and items.
  163. STDMETHODIMP LookupHandlerFromId(WORD wHandlerId,LPHANDLERINFO *pHandlerInfo);
  164. ULONG m_cRef;
  165. };
  166. #endif // _HANDLERQUEUE_