OSDN Git Service

build error link error
[tortoisegit/TortoiseGitJp.git] / TortoiseShell / ShellExt.h
1 // TortoiseSVN - a Windows shell extension for easy version control\r
2 \r
3 // Copyright (C) 2003-2008 - TortoiseSVN\r
4 \r
5 // This program is free software; you can redistribute it and/or\r
6 // modify it under the terms of the GNU General Public License\r
7 // as published by the Free Software Foundation; either version 2\r
8 // of the License, or (at your option) any later version.\r
9 \r
10 // This program is distributed in the hope that it will be useful,\r
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of\r
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
13 // GNU General Public License for more details.\r
14 \r
15 // You should have received a copy of the GNU General Public License\r
16 // along with this program; if not, write to the Free Software Foundation,\r
17 // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.\r
18 //\r
19 #pragma once\r
20 \r
21 #include "Globals.h"\r
22 #include "registry.h"\r
23 #include "resource.h"\r
24 #include "ShellCache.h"\r
25 #include "RemoteCacheLink.h"\r
26 #include "GitStatus.h"\r
27 //#include "SVNFolderStatus.h"\r
28 #include "uxtheme.h"\r
29 \r
30 extern  UINT                            g_cRefThisDll;                  // Reference count of this DLL.\r
31 extern  HINSTANCE                       g_hmodThisDll;                  // Instance handle for this DLL\r
32 extern  ShellCache                      g_ShellCache;                   // caching of registry entries, ...\r
33 extern  DWORD                           g_langid;\r
34 extern  DWORD                           g_langTimeout;\r
35 extern  HINSTANCE                       g_hResInst;\r
36 extern  stdstring                       g_filepath;\r
37 extern  git_wc_status_kind      g_filestatus;                   ///< holds the corresponding status to the file/dir above\r
38 extern  bool                            g_readonlyoverlay;              ///< whether to show the read only overlay or not\r
39 extern  bool                            g_lockedoverlay;                ///< whether to show the locked overlay or not\r
40 \r
41 extern bool                                     g_normalovlloaded;\r
42 extern bool                                     g_modifiedovlloaded;\r
43 extern bool                                     g_conflictedovlloaded;\r
44 extern bool                                     g_readonlyovlloaded;\r
45 extern bool                                     g_deletedovlloaded;\r
46 extern bool                                     g_lockedovlloaded;\r
47 extern bool                                     g_addedovlloaded;\r
48 extern bool                                     g_ignoredovlloaded;\r
49 extern bool                                     g_unversionedovlloaded;\r
50 extern LPCTSTR                          g_MenuIDString;\r
51 \r
52 extern  void                            LoadLangDll();\r
53 extern  CComCriticalSection     g_csGlobalCOMGuard;\r
54 typedef CComCritSecLock<CComCriticalSection> AutoLocker;\r
55 \r
56 typedef DWORD ARGB;\r
57 \r
58 typedef HRESULT (WINAPI *FN_GetBufferedPaintBits) (HPAINTBUFFER hBufferedPaint, RGBQUAD **ppbBuffer, int *pcxRow);\r
59 typedef HPAINTBUFFER (WINAPI *FN_BeginBufferedPaint) (HDC hdcTarget, const RECT *prcTarget, BP_BUFFERFORMAT dwFormat, BP_PAINTPARAMS *pPaintParams, HDC *phdc);\r
60 typedef HRESULT (WINAPI *FN_EndBufferedPaint) (HPAINTBUFFER hBufferedPaint, BOOL fUpdateTarget);\r
61 \r
62 \r
63 // The actual OLE Shell context menu handler\r
64 /**\r
65  * \ingroup TortoiseShell\r
66  * The main class of our COM object / Shell Extension.\r
67  * It contains all Interfaces we implement for the shell to use.\r
68  * \remark The implementations of the different interfaces are\r
69  * split into several *.cpp files to keep them in a reasonable size.\r
70  */\r
71 class CShellExt : public IContextMenu3,\r
72                                                         IPersistFile,\r
73                                                         IColumnProvider,\r
74                                                         IShellExtInit,\r
75                                                         IShellIconOverlayIdentifier,\r
76                                                         IShellPropSheetExt,\r
77                                                         ICopyHookW\r
78 \r
79 // COMPILER ERROR? You need the latest version of the\r
80 // platform SDK which has references to IColumnProvider \r
81 // in the header files.  Download it here:\r
82 // http://www.microsoft.com/msdownload/platformsdk/sdkupdate/\r
83 {\r
84 protected:\r
85 \r
86         enum GitCommands\r
87         {\r
88                 ShellSeparator = 0,\r
89                 ShellSubMenu = 1,\r
90                 ShellSubMenuFolder,\r
91                 ShellSubMenuFile,\r
92                 ShellSubMenuLink,\r
93                 ShellSubMenuMultiple,\r
94                 ShellMenuCheckout,\r
95                 ShellMenuUpdate,\r
96                 ShellMenuCommit,\r
97                 ShellMenuAdd,\r
98                 ShellMenuAddAsReplacement,\r
99                 ShellMenuRevert,\r
100                 ShellMenuCleanup,\r
101                 ShellMenuResolve,\r
102                 ShellMenuSwitch,\r
103                 ShellMenuImport,\r
104                 ShellMenuExport,\r
105                 ShellMenuAbout,\r
106                 ShellMenuCreateRepos,\r
107                 ShellMenuCopy,\r
108                 ShellMenuMerge,\r
109                 ShellMenuMergeAll,\r
110                 ShellMenuSettings,\r
111                 ShellMenuRemove,\r
112                 ShellMenuRemoveKeep,\r
113                 ShellMenuRename,\r
114                 ShellMenuUpdateExt,\r
115                 ShellMenuDiff,\r
116                 ShellMenuPrevDiff,\r
117                 ShellMenuUrlDiff,\r
118                 ShellMenuDropCopyAdd,\r
119                 ShellMenuDropMoveAdd,\r
120                 ShellMenuDropMove,\r
121                 ShellMenuDropMoveRename,\r
122                 ShellMenuDropCopy,\r
123                 ShellMenuDropCopyRename,\r
124                 ShellMenuDropExport,\r
125                 ShellMenuDropExportExtended,\r
126                 ShellMenuLog,\r
127                 ShellMenuConflictEditor,\r
128                 ShellMenuRelocate,\r
129                 ShellMenuHelp,\r
130                 ShellMenuShowChanged,\r
131                 ShellMenuIgnoreSub,\r
132                 ShellMenuIgnore,\r
133                 ShellMenuIgnoreFile,\r
134                 ShellMenuIgnoreCaseSensitive,\r
135                 ShellMenuIgnoreCaseInsensitive,\r
136                 ShellMenuRepoBrowse,\r
137                 ShellMenuBlame,\r
138                 ShellMenuApplyPatch,\r
139                 ShellMenuCreatePatch,\r
140                 ShellMenuRevisionGraph,\r
141                 ShellMenuUnIgnoreSub,\r
142                 ShellMenuUnIgnoreCaseSensitive,\r
143                 ShellMenuUnIgnore,\r
144                 ShellMenuLock,\r
145                 ShellMenuUnlock,\r
146                 ShellMenuUnlockForce,\r
147                 ShellMenuProperties,\r
148                 ShellMenuDelUnversioned,\r
149                 ShellMenuClipPaste,\r
150                 ShellMenuLastEntry                      // used to mark the menu array end\r
151         };\r
152 \r
153         // helper struct for context menu entries\r
154         typedef struct MenuInfo\r
155         {\r
156                 GitCommands                     command;                ///< the command which gets executed for this menu entry\r
157                 unsigned __int64        menuID;                 ///< the menu ID to recognize the entry. NULL if it shouldn't be added to the context menu automatically\r
158                 UINT                            iconID;                 ///< the icon to show for the menu entry\r
159                 UINT                            menuTextID;             ///< the text of the menu entry\r
160                 UINT                            menuDescID;             ///< the description text for the menu entry\r
161                 /// the following 8 params are for checking whether the menu entry should\r
162                 /// be added automatically, based on states of the selected item(s).\r
163                 /// The 'yes' states must be set, the 'no' states must not be set\r
164                 /// the four pairs are OR'ed together, the 'yes'/'no' states are AND'ed together.\r
165                 DWORD                           firstyes;\r
166                 DWORD                           firstno;\r
167                 DWORD                           secondyes;\r
168                 DWORD                           secondno;\r
169                 DWORD                           thirdyes;\r
170                 DWORD                           thirdno;\r
171                 DWORD                           fourthyes;\r
172                 DWORD                           fourthno;\r
173         };\r
174 \r
175         static MenuInfo menuInfo[];\r
176         WORD fullver;\r
177         FileState m_State;\r
178         ULONG   m_cRef;\r
179         //std::map<int,std::string> verbMap;\r
180         std::map<UINT_PTR, UINT_PTR>    myIDMap;\r
181         std::map<UINT_PTR, UINT_PTR>    mySubMenuMap;\r
182         std::map<stdstring, UINT_PTR> myVerbsMap;\r
183         std::map<UINT_PTR, stdstring> myVerbsIDMap;\r
184         stdstring       folder_;\r
185         std::vector<stdstring> files_;\r
186         DWORD itemStates;                               ///< see the globals.h file for the ITEMIS_* defines\r
187         DWORD itemStatesFolder;                 ///< used for states of the folder_ (folder background and/or drop target folder)\r
188         stdstring uuidSource;\r
189         stdstring uuidTarget;\r
190         int space;\r
191         TCHAR stringtablebuffer[255];\r
192         stdstring columnfilepath;               ///< holds the last file/dir path for the column provider\r
193         stdstring columnauthor;                 ///< holds the corresponding author of the file/dir above\r
194         stdstring itemurl;\r
195         stdstring itemshorturl;\r
196         stdstring ignoredprops;\r
197         stdstring owner;\r
198 //      git_revnum_t columnrev;                 ///< holds the corresponding revision to the file/dir above\r
199         git_wc_status_kind      filestatus;\r
200         std::map<UINT, HBITMAP> bitmaps;\r
201 \r
202 //      SVNFolderStatus         m_CachedStatus;         // status cache\r
203         CRemoteCacheLink        m_remoteCacheLink;\r
204 \r
205         FN_GetBufferedPaintBits pfnGetBufferedPaintBits;\r
206         FN_BeginBufferedPaint pfnBeginBufferedPaint;\r
207         FN_EndBufferedPaint pfnEndBufferedPaint;\r
208 \r
209 #define MAKESTRING(ID) LoadStringEx(g_hResInst, ID, stringtablebuffer, sizeof(stringtablebuffer)/sizeof(TCHAR), (WORD)CRegStdWORD(_T("Software\\TortoiseSVN\\LanguageID"), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT)))\r
210 private:\r
211         void                    InsertGitMenu(BOOL istop, HMENU menu, UINT pos, UINT_PTR id, UINT stringid, UINT icon, UINT idCmdFirst, GitCommands com, UINT uFlags);\r
212         void                    InsertIgnoreSubmenus(UINT &idCmd, UINT idCmdFirst, HMENU hMenu, HMENU subMenu, UINT &indexMenu, int &indexSubMenu, unsigned __int64 topmenu, bool bShowIcons);\r
213         stdstring               WriteFileListToTempFile();\r
214         bool                    WriteClipboardPathsToTempFile(stdstring& tempfile);\r
215         LPCTSTR                 GetMenuTextFromResource(int id);\r
216         void                    GetColumnStatus(const TCHAR * path, BOOL bIsDir);\r
217         HBITMAP                 IconToBitmap(UINT uIcon);\r
218         STDMETHODIMP    QueryDropContext(UINT uFlags, UINT idCmdFirst, HMENU hMenu, UINT &indexMenu);\r
219         bool                    IsIllegalFolder(std::wstring folder, int * cslidarray);\r
220         HBITMAP                 IconToBitmapPARGB32(UINT uIcon);\r
221         HRESULT                 Create32BitHBITMAP(HDC hdc, const SIZE *psize, __deref_opt_out void **ppvBits, __out HBITMAP* phBmp);\r
222         HRESULT                 ConvertBufferToPARGB32(HPAINTBUFFER hPaintBuffer, HDC hdc, HICON hicon, SIZE& sizIcon);\r
223         bool                    HasAlpha(__in ARGB *pargb, SIZE& sizImage, int cxRow);\r
224         HRESULT                 ConvertToPARGB32(HDC hdc, __inout ARGB *pargb, HBITMAP hbmp, SIZE& sizImage, int cxRow);\r
225 \r
226 \r
227 public:\r
228         CShellExt(FileState state);\r
229         virtual ~CShellExt();\r
230 \r
231         /** \name IUnknown \r
232          * IUnknown members\r
233          */\r
234         //@{\r
235         STDMETHODIMP         QueryInterface(REFIID, LPVOID FAR *);\r
236         STDMETHODIMP_(ULONG) AddRef();\r
237         STDMETHODIMP_(ULONG) Release();\r
238         //@}\r
239 \r
240         /** \name IContextMenu2 \r
241          * IContextMenu2 members\r
242          */\r
243         //@{\r
244         STDMETHODIMP    QueryContextMenu(HMENU hMenu, UINT indexMenu, UINT idCmdFirst, UINT idCmdLast, UINT uFlags);\r
245         STDMETHODIMP    InvokeCommand(LPCMINVOKECOMMANDINFO lpcmi);\r
246         STDMETHODIMP    GetCommandString(UINT_PTR idCmd, UINT uFlags, UINT FAR *reserved, LPSTR pszName, UINT cchMax);\r
247         STDMETHODIMP    HandleMenuMsg(UINT uMsg, WPARAM wParam, LPARAM lParam);\r
248         //@}\r
249 \r
250     /** \name IContextMenu3 \r
251          * IContextMenu3 members\r
252          */\r
253         //@{\r
254         STDMETHODIMP    HandleMenuMsg2(UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *pResult);\r
255         //@}\r
256 \r
257         /** \name IColumnProvider\r
258          * IColumnProvider members\r
259          */\r
260         //@{\r
261         STDMETHODIMP    GetColumnInfo(DWORD dwIndex, SHCOLUMNINFO *psci);\r
262         STDMETHODIMP    GetItemData(LPCSHCOLUMNID pscid, LPCSHCOLUMNDATA pscd, VARIANT *pvarData);\r
263         STDMETHODIMP    Initialize(LPCSHCOLUMNINIT psci);\r
264         //@}\r
265 \r
266         /** \name IShellExtInit\r
267          * IShellExtInit methods\r
268          */\r
269         //@{\r
270         STDMETHODIMP    Initialize(LPCITEMIDLIST pIDFolder, LPDATAOBJECT pDataObj, HKEY hKeyID);\r
271         //@}\r
272 \r
273     /** \name IPersistFile\r
274          * IPersistFile methods\r
275          */\r
276         //@{\r
277     STDMETHODIMP        GetClassID(CLSID *pclsid);\r
278     STDMETHODIMP        Load(LPCOLESTR pszFileName, DWORD dwMode);\r
279     STDMETHODIMP        IsDirty(void) { return S_OK; };\r
280     STDMETHODIMP        Save(LPCOLESTR /*pszFileName*/, BOOL /*fRemember*/) { return S_OK; };\r
281     STDMETHODIMP        SaveCompleted(LPCOLESTR /*pszFileName*/) { return S_OK; };\r
282     STDMETHODIMP        GetCurFile(LPOLESTR * /*ppszFileName*/) { return S_OK; };\r
283         //@}\r
284 \r
285         /** \name IShellIconOverlayIdentifier \r
286          * IShellIconOverlayIdentifier methods\r
287          */\r
288         //@{\r
289         STDMETHODIMP    GetOverlayInfo(LPWSTR pwszIconFile, int cchMax, int *pIndex, DWORD *pdwFlags);\r
290         STDMETHODIMP    GetPriority(int *pPriority); \r
291         STDMETHODIMP    IsMemberOf(LPCWSTR pwszPath, DWORD dwAttrib);\r
292         //@}\r
293 \r
294         /** \name IShellPropSheetExt \r
295          * IShellPropSheetExt methods\r
296          */\r
297         //@{\r
298         STDMETHODIMP    AddPages(LPFNADDPROPSHEETPAGE lpfnAddPage, LPARAM lParam);\r
299         STDMETHODIMP    ReplacePage (UINT, LPFNADDPROPSHEETPAGE, LPARAM);\r
300         //@}\r
301 \r
302         /** \name ICopyHook \r
303          * ICopyHook members\r
304          */\r
305         //@{\r
306         STDMETHODIMP_(UINT) CopyCallback(HWND hWnd, UINT wFunc, UINT wFlags, LPCTSTR pszSrcFile, DWORD dwSrcAttribs, LPCTSTR pszDestFile, DWORD dwDestAttribs);\r
307         //@}\r
308 \r
309 };\r