OSDN Git Service

Change Dir Structure to be same as TortoiseSVN'
[tortoisegit/TortoiseGitJp.git] / src / 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                 ShellMenuPull,\r
151                 ShellMenuPush,\r
152                 ShellMenuClone,\r
153                 ShellMenuLastEntry                      // used to mark the menu array end\r
154         };\r
155 \r
156         // helper struct for context menu entries\r
157         typedef struct MenuInfo\r
158         {\r
159                 GitCommands                     command;                ///< the command which gets executed for this menu entry\r
160                 unsigned __int64        menuID;                 ///< the menu ID to recognize the entry. NULL if it shouldn't be added to the context menu automatically\r
161                 UINT                            iconID;                 ///< the icon to show for the menu entry\r
162                 UINT                            menuTextID;             ///< the text of the menu entry\r
163                 UINT                            menuDescID;             ///< the description text for the menu entry\r
164                 /// the following 8 params are for checking whether the menu entry should\r
165                 /// be added automatically, based on states of the selected item(s).\r
166                 /// The 'yes' states must be set, the 'no' states must not be set\r
167                 /// the four pairs are OR'ed together, the 'yes'/'no' states are AND'ed together.\r
168                 DWORD                           firstyes;\r
169                 DWORD                           firstno;\r
170                 DWORD                           secondyes;\r
171                 DWORD                           secondno;\r
172                 DWORD                           thirdyes;\r
173                 DWORD                           thirdno;\r
174                 DWORD                           fourthyes;\r
175                 DWORD                           fourthno;\r
176         };\r
177 \r
178         static MenuInfo menuInfo[];\r
179         WORD fullver;\r
180         FileState m_State;\r
181         ULONG   m_cRef;\r
182         //std::map<int,std::string> verbMap;\r
183         std::map<UINT_PTR, UINT_PTR>    myIDMap;\r
184         std::map<UINT_PTR, UINT_PTR>    mySubMenuMap;\r
185         std::map<stdstring, UINT_PTR> myVerbsMap;\r
186         std::map<UINT_PTR, stdstring> myVerbsIDMap;\r
187         stdstring       folder_;\r
188         std::vector<stdstring> files_;\r
189         DWORD itemStates;                               ///< see the globals.h file for the ITEMIS_* defines\r
190         DWORD itemStatesFolder;                 ///< used for states of the folder_ (folder background and/or drop target folder)\r
191         stdstring uuidSource;\r
192         stdstring uuidTarget;\r
193         int space;\r
194         TCHAR stringtablebuffer[255];\r
195         stdstring columnfilepath;               ///< holds the last file/dir path for the column provider\r
196         stdstring columnauthor;                 ///< holds the corresponding author of the file/dir above\r
197         stdstring itemurl;\r
198         stdstring itemshorturl;\r
199         stdstring ignoredprops;\r
200         stdstring owner;\r
201 //      git_revnum_t columnrev;                 ///< holds the corresponding revision to the file/dir above\r
202         git_wc_status_kind      filestatus;\r
203         std::map<UINT, HBITMAP> bitmaps;\r
204 \r
205 //      SVNFolderStatus         m_CachedStatus;         // status cache\r
206         CRemoteCacheLink        m_remoteCacheLink;\r
207 \r
208         FN_GetBufferedPaintBits pfnGetBufferedPaintBits;\r
209         FN_BeginBufferedPaint pfnBeginBufferedPaint;\r
210         FN_EndBufferedPaint pfnEndBufferedPaint;\r
211 \r
212 #define MAKESTRING(ID) LoadStringEx(g_hResInst, ID, stringtablebuffer, sizeof(stringtablebuffer)/sizeof(TCHAR), (WORD)CRegStdWORD(_T("Software\\TortoiseSVN\\LanguageID"), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT)))\r
213 private:\r
214         void                    InsertGitMenu(BOOL istop, HMENU menu, UINT pos, UINT_PTR id, UINT stringid, UINT icon, UINT idCmdFirst, GitCommands com, UINT uFlags);\r
215         void                    InsertIgnoreSubmenus(UINT &idCmd, UINT idCmdFirst, HMENU hMenu, HMENU subMenu, UINT &indexMenu, int &indexSubMenu, unsigned __int64 topmenu, bool bShowIcons);\r
216         stdstring               WriteFileListToTempFile();\r
217         bool                    WriteClipboardPathsToTempFile(stdstring& tempfile);\r
218         LPCTSTR                 GetMenuTextFromResource(int id);\r
219         void                    GetColumnStatus(const TCHAR * path, BOOL bIsDir);\r
220         HBITMAP                 IconToBitmap(UINT uIcon);\r
221         STDMETHODIMP    QueryDropContext(UINT uFlags, UINT idCmdFirst, HMENU hMenu, UINT &indexMenu);\r
222         bool                    IsIllegalFolder(std::wstring folder, int * cslidarray);\r
223         HBITMAP                 IconToBitmapPARGB32(UINT uIcon);\r
224         HRESULT                 Create32BitHBITMAP(HDC hdc, const SIZE *psize, __deref_opt_out void **ppvBits, __out HBITMAP* phBmp);\r
225         HRESULT                 ConvertBufferToPARGB32(HPAINTBUFFER hPaintBuffer, HDC hdc, HICON hicon, SIZE& sizIcon);\r
226         bool                    HasAlpha(__in ARGB *pargb, SIZE& sizImage, int cxRow);\r
227         HRESULT                 ConvertToPARGB32(HDC hdc, __inout ARGB *pargb, HBITMAP hbmp, SIZE& sizImage, int cxRow);\r
228 \r
229 \r
230 public:\r
231         CShellExt(FileState state);\r
232         virtual ~CShellExt();\r
233 \r
234         /** \name IUnknown \r
235          * IUnknown members\r
236          */\r
237         //@{\r
238         STDMETHODIMP         QueryInterface(REFIID, LPVOID FAR *);\r
239         STDMETHODIMP_(ULONG) AddRef();\r
240         STDMETHODIMP_(ULONG) Release();\r
241         //@}\r
242 \r
243         /** \name IContextMenu2 \r
244          * IContextMenu2 members\r
245          */\r
246         //@{\r
247         STDMETHODIMP    QueryContextMenu(HMENU hMenu, UINT indexMenu, UINT idCmdFirst, UINT idCmdLast, UINT uFlags);\r
248         STDMETHODIMP    InvokeCommand(LPCMINVOKECOMMANDINFO lpcmi);\r
249         STDMETHODIMP    GetCommandString(UINT_PTR idCmd, UINT uFlags, UINT FAR *reserved, LPSTR pszName, UINT cchMax);\r
250         STDMETHODIMP    HandleMenuMsg(UINT uMsg, WPARAM wParam, LPARAM lParam);\r
251         //@}\r
252 \r
253     /** \name IContextMenu3 \r
254          * IContextMenu3 members\r
255          */\r
256         //@{\r
257         STDMETHODIMP    HandleMenuMsg2(UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *pResult);\r
258         //@}\r
259 \r
260         /** \name IColumnProvider\r
261          * IColumnProvider members\r
262          */\r
263         //@{\r
264         STDMETHODIMP    GetColumnInfo(DWORD dwIndex, SHCOLUMNINFO *psci);\r
265         STDMETHODIMP    GetItemData(LPCSHCOLUMNID pscid, LPCSHCOLUMNDATA pscd, VARIANT *pvarData);\r
266         STDMETHODIMP    Initialize(LPCSHCOLUMNINIT psci);\r
267         //@}\r
268 \r
269         /** \name IShellExtInit\r
270          * IShellExtInit methods\r
271          */\r
272         //@{\r
273         STDMETHODIMP    Initialize(LPCITEMIDLIST pIDFolder, LPDATAOBJECT pDataObj, HKEY hKeyID);\r
274         //@}\r
275 \r
276     /** \name IPersistFile\r
277          * IPersistFile methods\r
278          */\r
279         //@{\r
280     STDMETHODIMP        GetClassID(CLSID *pclsid);\r
281     STDMETHODIMP        Load(LPCOLESTR pszFileName, DWORD dwMode);\r
282     STDMETHODIMP        IsDirty(void) { return S_OK; };\r
283     STDMETHODIMP        Save(LPCOLESTR /*pszFileName*/, BOOL /*fRemember*/) { return S_OK; };\r
284     STDMETHODIMP        SaveCompleted(LPCOLESTR /*pszFileName*/) { return S_OK; };\r
285     STDMETHODIMP        GetCurFile(LPOLESTR * /*ppszFileName*/) { return S_OK; };\r
286         //@}\r
287 \r
288         /** \name IShellIconOverlayIdentifier \r
289          * IShellIconOverlayIdentifier methods\r
290          */\r
291         //@{\r
292         STDMETHODIMP    GetOverlayInfo(LPWSTR pwszIconFile, int cchMax, int *pIndex, DWORD *pdwFlags);\r
293         STDMETHODIMP    GetPriority(int *pPriority); \r
294         STDMETHODIMP    IsMemberOf(LPCWSTR pwszPath, DWORD dwAttrib);\r
295         //@}\r
296 \r
297         /** \name IShellPropSheetExt \r
298          * IShellPropSheetExt methods\r
299          */\r
300         //@{\r
301         STDMETHODIMP    AddPages(LPFNADDPROPSHEETPAGE lpfnAddPage, LPARAM lParam);\r
302         STDMETHODIMP    ReplacePage (UINT, LPFNADDPROPSHEETPAGE, LPARAM);\r
303         //@}\r
304 \r
305         /** \name ICopyHook \r
306          * ICopyHook members\r
307          */\r
308         //@{\r
309         STDMETHODIMP_(UINT) CopyCallback(HWND hWnd, UINT wFunc, UINT wFlags, LPCTSTR pszSrcFile, DWORD dwSrcAttribs, LPCTSTR pszDestFile, DWORD dwDestAttribs);\r
310         //@}\r
311 \r
312 };\r