1 // TortoiseSVN - a Windows shell extension for easy version control
\r
3 // Copyright (C) 2003-2008 - TortoiseSVN
\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
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
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
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 "GitFolderStatus.h"
\r
28 #include "uxtheme.h"
\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
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
52 extern void LoadLangDll();
\r
53 extern CComCriticalSection g_csGlobalCOMGuard;
\r
54 typedef CComCritSecLock<CComCriticalSection> AutoLocker;
\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
63 // The actual OLE Shell context menu handler
\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
71 class CShellExt : public IContextMenu3,
\r
75 IShellIconOverlayIdentifier,
\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
93 ShellSubMenuMultiple,
\r
98 ShellMenuAddAsReplacement,
\r
106 ShellMenuCreateRepos,
\r
112 ShellMenuRemoveKeep,
\r
114 ShellMenuUpdateExt,
\r
118 ShellMenuDropCopyAdd,
\r
119 ShellMenuDropMoveAdd,
\r
121 ShellMenuDropMoveRename,
\r
123 ShellMenuDropCopyRename,
\r
124 ShellMenuDropExport,
\r
125 ShellMenuDropExportExtended,
\r
127 ShellMenuConflictEditor,
\r
130 ShellMenuShowChanged,
\r
131 ShellMenuIgnoreSub,
\r
133 ShellMenuIgnoreFile,
\r
134 ShellMenuIgnoreCaseSensitive,
\r
135 ShellMenuIgnoreCaseInsensitive,
\r
136 ShellMenuRepoBrowse,
\r
138 ShellMenuApplyPatch,
\r
139 ShellMenuCreatePatch,
\r
140 ShellMenuRevisionGraph,
\r
141 ShellMenuUnIgnoreSub,
\r
142 ShellMenuUnIgnoreCaseSensitive,
\r
145 // ShellMenuUnlock,
\r
146 // ShellMenuUnlockForce,
\r
147 ShellMenuProperties,
\r
148 ShellMenuDelUnversioned,
\r
149 ShellMenuClipPaste,
\r
155 ShellMenuFormatPatch,
\r
156 ShellMenuImportPatch,
\r
157 ShellMenuCherryPick,
\r
160 ShellMenuLastEntry // used to mark the menu array end
\r
163 // helper struct for context menu entries
\r
164 typedef struct MenuInfo
\r
166 GitCommands command; ///< the command which gets executed for this menu entry
\r
167 unsigned __int64 menuID; ///< the menu ID to recognize the entry. NULL if it shouldn't be added to the context menu automatically
\r
168 UINT iconID; ///< the icon to show for the menu entry
\r
169 UINT menuTextID; ///< the text of the menu entry
\r
170 UINT menuDescID; ///< the description text for the menu entry
\r
171 /// the following 8 params are for checking whether the menu entry should
\r
172 /// be added automatically, based on states of the selected item(s).
\r
173 /// The 'yes' states must be set, the 'no' states must not be set
\r
174 /// the four pairs are OR'ed together, the 'yes'/'no' states are AND'ed together.
\r
185 static MenuInfo menuInfo[];
\r
189 //std::map<int,std::string> verbMap;
\r
190 std::map<UINT_PTR, UINT_PTR> myIDMap;
\r
191 std::map<UINT_PTR, UINT_PTR> mySubMenuMap;
\r
192 std::map<stdstring, UINT_PTR> myVerbsMap;
\r
193 std::map<UINT_PTR, stdstring> myVerbsIDMap;
\r
195 std::vector<stdstring> files_;
\r
196 DWORD itemStates; ///< see the globals.h file for the ITEMIS_* defines
\r
197 DWORD itemStatesFolder; ///< used for states of the folder_ (folder background and/or drop target folder)
\r
198 stdstring uuidSource;
\r
199 stdstring uuidTarget;
\r
201 TCHAR stringtablebuffer[255];
\r
202 stdstring columnfilepath; ///< holds the last file/dir path for the column provider
\r
203 stdstring columnauthor; ///< holds the corresponding author of the file/dir above
\r
205 stdstring itemshorturl;
\r
206 stdstring ignoredprops;
\r
208 git_revnum_t columnrev; ///< holds the corresponding revision to the file/dir above
\r
209 git_wc_status_kind filestatus;
\r
210 std::map<UINT, HBITMAP> bitmaps;
\r
212 GitFolderStatus m_CachedStatus; // status cache
\r
213 CRemoteCacheLink m_remoteCacheLink;
\r
215 FN_GetBufferedPaintBits pfnGetBufferedPaintBits;
\r
216 FN_BeginBufferedPaint pfnBeginBufferedPaint;
\r
217 FN_EndBufferedPaint pfnEndBufferedPaint;
\r
219 #define MAKESTRING(ID) LoadStringEx(g_hResInst, ID, stringtablebuffer, sizeof(stringtablebuffer)/sizeof(TCHAR), (WORD)CRegStdWORD(_T("Software\\TortoiseGit\\LanguageID"), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT)))
\r
221 void InsertGitMenu(BOOL istop, HMENU menu, UINT pos, UINT_PTR id, UINT stringid, UINT icon, UINT idCmdFirst, GitCommands com, UINT uFlags);
\r
222 void InsertIgnoreSubmenus(UINT &idCmd, UINT idCmdFirst, HMENU hMenu, HMENU subMenu, UINT &indexMenu, int &indexSubMenu, unsigned __int64 topmenu, bool bShowIcons);
\r
223 stdstring WriteFileListToTempFile();
\r
224 bool WriteClipboardPathsToTempFile(stdstring& tempfile);
\r
225 LPCTSTR GetMenuTextFromResource(int id);
\r
226 void GetColumnStatus(const TCHAR * path, BOOL bIsDir);
\r
227 HBITMAP IconToBitmap(UINT uIcon);
\r
228 STDMETHODIMP QueryDropContext(UINT uFlags, UINT idCmdFirst, HMENU hMenu, UINT &indexMenu);
\r
229 bool IsIllegalFolder(std::wstring folder, int * cslidarray);
\r
230 HBITMAP IconToBitmapPARGB32(UINT uIcon);
\r
231 HRESULT Create32BitHBITMAP(HDC hdc, const SIZE *psize, __deref_opt_out void **ppvBits, __out HBITMAP* phBmp);
\r
232 HRESULT ConvertBufferToPARGB32(HPAINTBUFFER hPaintBuffer, HDC hdc, HICON hicon, SIZE& sizIcon);
\r
233 bool HasAlpha(__in ARGB *pargb, SIZE& sizImage, int cxRow);
\r
234 HRESULT ConvertToPARGB32(HDC hdc, __inout ARGB *pargb, HBITMAP hbmp, SIZE& sizImage, int cxRow);
\r
238 CShellExt(FileState state);
\r
239 virtual ~CShellExt();
\r
241 /** \name IUnknown
\r
245 STDMETHODIMP QueryInterface(REFIID, LPVOID FAR *);
\r
246 STDMETHODIMP_(ULONG) AddRef();
\r
247 STDMETHODIMP_(ULONG) Release();
\r
250 /** \name IContextMenu2
\r
251 * IContextMenu2 members
\r
254 STDMETHODIMP QueryContextMenu(HMENU hMenu, UINT indexMenu, UINT idCmdFirst, UINT idCmdLast, UINT uFlags);
\r
255 STDMETHODIMP InvokeCommand(LPCMINVOKECOMMANDINFO lpcmi);
\r
256 STDMETHODIMP GetCommandString(UINT_PTR idCmd, UINT uFlags, UINT FAR *reserved, LPSTR pszName, UINT cchMax);
\r
257 STDMETHODIMP HandleMenuMsg(UINT uMsg, WPARAM wParam, LPARAM lParam);
\r
260 /** \name IContextMenu3
\r
261 * IContextMenu3 members
\r
264 STDMETHODIMP HandleMenuMsg2(UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *pResult);
\r
267 /** \name IColumnProvider
\r
268 * IColumnProvider members
\r
271 STDMETHODIMP GetColumnInfo(DWORD dwIndex, SHCOLUMNINFO *psci);
\r
272 STDMETHODIMP GetItemData(LPCSHCOLUMNID pscid, LPCSHCOLUMNDATA pscd, VARIANT *pvarData);
\r
273 STDMETHODIMP Initialize(LPCSHCOLUMNINIT psci);
\r
276 /** \name IShellExtInit
\r
277 * IShellExtInit methods
\r
280 STDMETHODIMP Initialize(LPCITEMIDLIST pIDFolder, LPDATAOBJECT pDataObj, HKEY hKeyID);
\r
283 /** \name IPersistFile
\r
284 * IPersistFile methods
\r
287 STDMETHODIMP GetClassID(CLSID *pclsid);
\r
288 STDMETHODIMP Load(LPCOLESTR pszFileName, DWORD dwMode);
\r
289 STDMETHODIMP IsDirty(void) { return S_OK; };
\r
290 STDMETHODIMP Save(LPCOLESTR /*pszFileName*/, BOOL /*fRemember*/) { return S_OK; };
\r
291 STDMETHODIMP SaveCompleted(LPCOLESTR /*pszFileName*/) { return S_OK; };
\r
292 STDMETHODIMP GetCurFile(LPOLESTR * /*ppszFileName*/) { return S_OK; };
\r
295 /** \name IShellIconOverlayIdentifier
\r
296 * IShellIconOverlayIdentifier methods
\r
299 STDMETHODIMP GetOverlayInfo(LPWSTR pwszIconFile, int cchMax, int *pIndex, DWORD *pdwFlags);
\r
300 STDMETHODIMP GetPriority(int *pPriority);
\r
301 STDMETHODIMP IsMemberOf(LPCWSTR pwszPath, DWORD dwAttrib);
\r
304 /** \name IShellPropSheetExt
\r
305 * IShellPropSheetExt methods
\r
308 STDMETHODIMP AddPages(LPFNADDPROPSHEETPAGE lpfnAddPage, LPARAM lParam);
\r
309 STDMETHODIMP ReplacePage (UINT, LPFNADDPROPSHEETPAGE, LPARAM);
\r
312 /** \name ICopyHook
\r
313 * ICopyHook members
\r
316 STDMETHODIMP_(UINT) CopyCallback(HWND hWnd, UINT wFunc, UINT wFlags, LPCTSTR pszSrcFile, DWORD dwSrcAttribs, LPCTSTR pszDestFile, DWORD dwDestAttribs);
\r