1 // TortoiseGit - a Windows shell extension for easy version control
\r
3 // Copyright (C) 2003-2008 - TortoiseGit
\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 "StandAloneDlg.h"
\r
22 #include "TGitPath.h"
\r
23 #include "ProjectProperties.h"
\r
25 #include "GitStatus.h"
\r
27 //#include "..\IBugTraqProvider\IBugTraqProvider_h.h"
\r
30 typedef int (__cdecl *GENERICCOMPAREFN)(const void * elem1, const void * elem2);
\r
33 * \ingroup TortoiseProc
\r
34 * Options which can be used to configure the way the dialog box works
\r
39 ProgOptRecursive = 0x01,
\r
40 ProgOptNonRecursive = 0x00,
\r
41 /// Don't actually do the merge - just practice it
\r
42 ProgOptDryRun = 0x04,
\r
43 ProgOptIgnoreExternals = 0x08,
\r
44 ProgOptKeeplocks = 0x10,
\r
45 /// for locking this means steal the lock, for unlocking it means breaking the lock
\r
46 ProgOptLockForce = 0x20,
\r
47 ProgOptSwitchAfterCopy = 0x40,
\r
48 ProgOptIncludeIgnored = 0x80,
\r
49 ProgOptIgnoreAncestry = 0x100,
\r
50 ProgOptEolDefault = 0x200,
\r
51 ProgOptEolCRLF = 0x400,
\r
52 ProgOptEolLF = 0x800,
\r
53 ProgOptEolCR = 0x1000,
\r
54 ProgOptSkipConflictCheck = 0x2000,
\r
55 ProgOptRecordOnly = 0x4000
\r
65 } ProgressCloseOptions;
\r
67 #define WM_SHOWCONFLICTRESOLVER (WM_APP + 100)
\r
72 git_wc_notify_sendmail_start,
\r
73 git_wc_notify_sendmail_error,
\r
74 git_wc_notify_sendmail_done,
\r
75 git_wc_notify_resolved
\r
77 }git_wc_notify_action_t;
\r
80 SENDMAIL_ATTACHMENT=0x1,
\r
81 SENDMAIL_COMBINED =0x2
\r
84 * \ingroup TortoiseProc
\r
85 * Handles different Subversion commands and shows the notify messages
\r
86 * in a listbox. Since several Subversion commands have similar notify
\r
87 * messages they are grouped together in this single class.
\r
89 class CGitProgressDlg : public CResizableStandAloneDialog
\r
95 GitProgress_Checkout,
\r
102 GitProgress_MergeReintegrate,
\r
103 GitProgress_MergeAll,
\r
104 GitProgress_Rename,
\r
105 GitProgress_Resolve,
\r
106 GitProgress_Revert,
\r
107 GitProgress_Switch,
\r
108 GitProgress_Unlock,
\r
109 GitProgress_Update,
\r
110 GitProgress_SendMail,
\r
114 DECLARE_DYNAMIC(CGitProgressDlg)
\r
118 CGitProgressDlg(CWnd* pParent = NULL);
\r
119 virtual ~CGitProgressDlg();
\r
122 void SetCommand(Command cmd) {m_Command = cmd;}
\r
123 void SetAutoClose(DWORD ac) {m_dwCloseOnEnd = ac;}
\r
124 void SetOptions(DWORD opts) {m_options = opts;}
\r
125 void SetPathList(const CTGitPathList& pathList) {m_targetPathList = pathList;}
\r
126 void SetUrl(const CString& url) {m_url.SetFromUnknown(url);}
\r
127 void SetSecondUrl(const CString& url) {m_url2.SetFromUnknown(url);}
\r
128 void SetCommitMessage(const CString& msg) {m_sMessage = msg;}
\r
130 // void SetRevision(const GitRev& rev) {m_Revision = rev;}
\r
131 // void SetRevisionEnd(const GitRev& rev) {m_RevisionEnd = rev;}
\r
133 void SetDiffOptions(const CString& opts) {m_diffoptions = opts;}
\r
134 void SetSendMailOption(CString &TO, CString &CC,CString &Subject,DWORD flags){m_SendMailTO=TO;m_SendMailSubject=Subject; m_SendMailCC=CC;this->m_SendMailFlags = flags;}
\r
135 void SetDepth(git_depth_t depth = git_depth_unknown) {m_depth = depth;}
\r
136 void SetPegRevision(GitRev pegrev = GitRev()) {m_pegRev = pegrev;}
\r
137 void SetProjectProperties(ProjectProperties props) {m_ProjectProperties = props;}
\r
138 void SetChangeList(const CString& changelist, bool keepchangelist) {m_changelist = changelist; m_keepchangelist = keepchangelist;}
\r
139 void SetSelectedList(const CTGitPathList& selPaths);
\r
140 // void SetRevisionRanges(const GitRevRangeArray& revArray) {m_revisionArray = revArray;}
\r
141 // void SetBugTraqProvider(const CComPtr<IBugTraqProvider> pBugtraqProvider) { m_BugTraqProvider = pBugtraqProvider;}
\r
143 * If the number of items for which the operation is done on is known
\r
144 * beforehand, that number can be set here. It is then used to show a more
\r
145 * accurate progress bar during the operation.
\r
147 void SetItemCount(long count) {if(count) m_itemCountTotal = count;}
\r
149 bool SetBackgroundImage(UINT nID);
\r
151 bool DidErrorsOccur() {return m_bErrorsOccurred;}
\r
153 enum { IDD = IDD_SVNPROGRESS };
\r
156 class NotificationData
\r
159 NotificationData(){} ;
\r
160 git_wc_notify_action_t action;
\r
162 action((git_wc_notify_action_t)-1),
\r
163 kind(git_node_none),
\r
164 content_state(git_wc_notify_state_inapplicable),
\r
165 prop_state(git_wc_notify_state_inapplicable),
\r
168 color(::GetSysColor(COLOR_WINDOWTEXT)),
\r
169 bConflictedActionItem(false),
\r
172 // lock_state(git_wc_notify_lock_state_unchanged)
\r
174 // merge_range.end = 0;
\r
175 // merge_range.start = 0;
\r
179 // The text we put into the first column (the Git action for normal items, just text for aux items)
\r
180 CString sActionColumnText;
\r
182 CTGitPath basepath;
\r
183 CString changelistname;
\r
185 /// git_wc_notify_action_t action;
\r
186 // git_node_kind_t kind;
\r
188 // git_wc_notify_state_t content_state;
\r
189 // git_wc_notify_state_t prop_state;
\r
190 // git_wc_notify_lock_state_t lock_state;
\r
191 // git_merge_range_t merge_range;
\r
194 CString owner; ///< lock owner
\r
195 bool bConflictedActionItem; // Is this item a conflict?
\r
196 bool bAuxItem; // Set if this item is not a true 'Git action'
\r
197 CString sPathColumnText;
\r
202 //Need update in the future implement the virtual methods from Git base class
\r
203 virtual BOOL Notify(const CTGitPath& path,
\r
204 git_wc_notify_action_t action,
\r
206 CString *strErr =NULL
\r
208 git_node_kind_t kind, const CString& mime_type,
\r
209 git_wc_notify_state_t content_state,
\r
210 git_wc_notify_state_t prop_state, LONG rev,
\r
211 const git_lock_t * lock, git_wc_notify_lock_state_t lock_state,
\r
212 const CString& changelistname,
\r
213 git_merge_range_t * range,
\r
214 git_error_t * err, apr_pool_t * pool*/
\r
217 // virtual git_wc_conflict_choice_t ConflictResolveCallback(const git_wc_conflict_description_t *description, CString& mergedfile);
\r
218 virtual BOOL OnInitDialog();
\r
219 virtual BOOL Cancel();
\r
220 virtual void OnCancel();
\r
221 virtual BOOL PreTranslateMessage(MSG* pMsg);
\r
222 virtual void DoDataExchange(CDataExchange* pDX);
\r
224 afx_msg void OnNMCustomdrawSvnprogress(NMHDR *pNMHDR, LRESULT *pResult);
\r
225 afx_msg void OnLvnGetdispinfoSvnprogress(NMHDR *pNMHDR, LRESULT *pResult);
\r
226 afx_msg void OnNMDblclkSvnprogress(NMHDR *pNMHDR, LRESULT *pResult);
\r
227 afx_msg void OnBnClickedLogbutton();
\r
228 afx_msg void OnBnClickedOk();
\r
229 afx_msg void OnBnClickedNoninteractive();
\r
230 afx_msg void OnHdnItemclickSvnprogress(NMHDR *pNMHDR, LRESULT *pResult);
\r
231 afx_msg BOOL OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message);
\r
232 afx_msg void OnClose();
\r
233 afx_msg void OnContextMenu(CWnd* pWnd, CPoint point);
\r
234 afx_msg LRESULT OnGitProgress(WPARAM wParam, LPARAM lParam);
\r
235 afx_msg void OnTimer(UINT_PTR nIDEvent);
\r
236 afx_msg void OnEnSetfocusInfotext();
\r
237 afx_msg void OnLvnBegindragSvnprogress(NMHDR *pNMHDR, LRESULT *pResult);
\r
238 afx_msg void OnSize(UINT nType, int cx, int cy);
\r
239 LRESULT OnShowConflictResolver(WPARAM, LPARAM);
\r
241 DECLARE_MESSAGE_MAP()
\r
244 static bool SortCompare(const NotificationData* pElem1, const NotificationData* pElem2);
\r
246 static BOOL m_bAscending;
\r
247 static int m_nSortedColumn;
\r
248 CStringList m_ExtStack;
\r
251 static UINT ProgressThreadEntry(LPVOID pVoid);
\r
252 UINT ProgressThread();
\r
253 virtual void OnOK();
\r
254 void ReportGitError();
\r
255 void ReportError(const CString& sError);
\r
256 void ReportWarning(const CString& sWarning);
\r
257 void ReportNotification(const CString& sNotification);
\r
258 void ReportCmd(const CString& sCmd);
\r
259 void ReportString(CString sMessage, const CString& sMsgKind, COLORREF color = ::GetSysColor(COLOR_WINDOWTEXT));
\r
260 void AddItemToList();
\r
261 CString BuildInfoString();
\r
262 CString GetPathFromColumnText(const CString& sColumnText);
\r
265 * Resizes the columns of the progress list so that the headings are visible.
\r
267 void ResizeColumns();
\r
269 /// Predicate function to tell us if a notification data item is auxiliary or not
\r
270 static bool NotificationDataIsAux(const NotificationData* pData);
\r
272 // the commands to execute
\r
273 bool CmdAdd(CString& sWindowTitle, bool& localoperation);
\r
274 bool CmdCheckout(CString& sWindowTitle, bool& localoperation);
\r
275 bool CmdCommit(CString& sWindowTitle, bool& localoperation);
\r
276 bool CmdCopy(CString& sWindowTitle, bool& localoperation);
\r
277 bool CmdExport(CString& sWindowTitle, bool& localoperation);
\r
278 bool CmdImport(CString& sWindowTitle, bool& localoperation);
\r
279 bool CmdLock(CString& sWindowTitle, bool& localoperation);
\r
280 bool CmdMerge(CString& sWindowTitle, bool& localoperation);
\r
281 bool CmdMergeAll(CString& sWindowTitle, bool& localoperation);
\r
282 bool CmdMergeReintegrate(CString& sWindowTitle, bool& localoperation);
\r
283 bool CmdRename(CString& sWindowTitle, bool& localoperation);
\r
284 bool CmdResolve(CString& sWindowTitle, bool& localoperation);
\r
285 bool CmdRevert(CString& sWindowTitle, bool& localoperation);
\r
286 bool CmdSwitch(CString& sWindowTitle, bool& localoperation);
\r
287 bool CmdUnlock(CString& sWindowTitle, bool& localoperation);
\r
288 bool CmdUpdate(CString& sWindowTitle, bool& localoperation);
\r
289 bool CmdSendMail(CString& sWindowTitle, bool& localoperation);
\r
292 typedef std::map<CStringA, git_revnum_t> StringRevMap;
\r
293 typedef std::vector<NotificationData *> NotificationDataVect;
\r
296 CString m_mergedfile;
\r
297 NotificationDataVect m_arData;
\r
299 CWinThread* m_pThread;
\r
300 volatile LONG m_bThreadRunning;
\r
302 ProjectProperties m_ProjectProperties;
\r
303 CListCtrl m_ProgList;
\r
305 int m_options; // Use values from the ProgressOptions enum
\r
306 git_depth_t m_depth;
\r
307 CTGitPathList m_targetPathList;
\r
308 CTGitPathList m_selectedPaths;
\r
311 CString m_sMessage;
\r
312 CString m_diffoptions;
\r
314 GitRev m_RevisionEnd;
\r
316 // GitRevRangeArray m_revisionArray;
\r
317 CString m_changelist;
\r
318 bool m_keepchangelist;
\r
320 DWORD m_dwCloseOnEnd;
\r
322 CTGitPath m_basePath;
\r
323 StringRevMap m_UpdateStartRevMap;
\r
324 StringRevMap m_FinishedRevMap;
\r
326 TCHAR m_columnbuf[MAX_PATH];
\r
330 bool m_bErrorsOccurred;
\r
331 bool m_bMergesAddsDeletesOccurred;
\r
334 BOOL bSecondResized;
\r
335 int nEnsureVisibleCount;
\r
337 CString m_sTotalBytesTransferred;
\r
341 bool m_bLockWarning;
\r
342 bool m_bLockExists;
\r
343 bool m_bFinishedItemAdded;
\r
344 bool m_bLastVisible;
\r
347 int m_itemCountTotal;
\r
349 bool m_AlwaysConflicted;
\r
351 DWORD m_SendMailFlags;
\r
352 CString m_SendMailTO;
\r
353 CString m_SendMailCC;
\r
354 CString m_SendMailSubject;
\r
356 /// CComPtr<IBugTraqProvider> m_BugTraqProvider;
\r
358 // some strings different methods can use
\r
359 CString sIgnoredIncluded;
\r
360 CString sExtExcluded;
\r
361 CString sExtIncluded;
\r
362 CString sIgnoreAncestry;
\r
363 CString sRespectAncestry;
\r
365 CString sRecordOnly;
\r