+ int CurrentEntry;\r
+ CurrentEntry = this->m_ctrlPull.GetCurrentEntry(); \r
+ this->m_regPullButton = CurrentEntry;\r
+\r
+\r
+ this->m_bAbort=false;\r
+ this->m_GitCmdList.clear();\r
+\r
+ this->UpdateData();\r
+ UpateCombox();\r
+\r
+ m_oldHash = g_Git.GetHash(CString(_T("HEAD")));\r
+\r
+ if( CurrentEntry == 0)\r
+ {\r
+ if( g_Git.GetHash(this->m_strLocalBranch) != m_oldHash)\r
+ {\r
+ CMessageBox::Show(NULL,_T("Pull require local branch must be current branch"),_T("TortoiseGit"),MB_OK|MB_ICONERROR);\r
+ return; \r
+ }\r
+ }\r
+\r
+ if(this->m_strURL.IsEmpty())\r
+ {\r
+ CMessageBox::Show(NULL,_T("URL can't Empty"),_T("TortoiseGit"),MB_OK|MB_ICONERROR);\r
+ return;\r
+ }\r
+\r
+ if(this->m_bAutoLoadPuttyKey)\r
+ {\r
+ CAppUtils::LaunchPAgent(NULL,&this->m_strURL);\r
+ }\r
+\r
+ this->SwitchToRun();\r
+\r
+ CString force;\r
+ if(this->m_bForce)\r
+ force = _T(" --force ");\r
+\r
+ CString cmd;\r
+\r
+ ShowTab(IDC_CMD_LOG);\r
+\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_LOGLIST-1,false);\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_CHANGELIST-1,false);\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_CONFLICT-1,false);\r
+\r
+ this->GetDlgItem(IDC_BUTTON_COMMIT)->ShowWindow(SW_HIDE);\r
+\r
+ ///Pull \r
+ if(CurrentEntry == 0) //Pull\r
+ {\r
+ cmd.Format(_T("git.exe pull %s \"%s\" %s"),\r
+ force,\r
+ m_strURL,\r
+ this->m_strRemoteBranch);\r
+\r
+ m_CurrentCmd = GIT_COMMAND_PULL;\r
+ m_GitCmdList.push_back(cmd);\r
+\r
+ m_pThread = AfxBeginThread(ProgressThreadEntry, this, THREAD_PRIORITY_NORMAL,0,CREATE_SUSPENDED);\r
+ if (m_pThread==NULL)\r
+ {\r
+ // ReportError(CString(MAKEINTRESOURCE(IDS_ERR_THREADSTARTFAILED)));\r
+ }\r
+ else\r
+ {\r
+ m_pThread->m_bAutoDelete = TRUE;\r
+ m_pThread->ResumeThread();\r
+ }\r
+\r
+ }\r
+ \r
+}\r
+\r
+void CSyncDlg::PullComplete()\r
+{\r
+ EnableControlButton(true);\r
+ SwitchToInput();\r
+ this->FetchOutList(true);\r
+\r
+ CString newhash;\r
+ newhash = g_Git.GetHash(CString(_T("HEAD")));\r
+\r
+ \r
+\r
+ if( this ->m_GitCmdStatus )\r
+ {\r
+ CTGitPathList list;\r
+ if(g_Git.ListConflictFile(list))\r
+ {\r
+ this->m_ctrlCmdOut.SetSel(-1,-1);\r
+ this->m_ctrlCmdOut.ReplaceSel(_T("Get conflict files fail\n"));\r
+\r
+ this->ShowTab(IDC_CMD_LOG);\r
+ return;\r
+ }\r
+\r
+ if(list.GetCount()>0)\r
+ {\r
+ this->m_ConflictFileList.Clear(); \r
+ CTGitPathList list;\r
+ CTGitPath path;\r
+ list.AddPath(path);\r
+\r
+ this->m_ConflictFileList.GetStatus(&list,true);\r
+ this->m_ConflictFileList.Show(CTGitPath::LOGACTIONS_UNMERGED,\r
+ CTGitPath::LOGACTIONS_UNMERGED);\r
+ \r
+ this->ShowTab(IDC_IN_CONFLICT);\r
+\r
+ this->GetDlgItem(IDC_BUTTON_COMMIT)->ShowWindow(SW_NORMAL);\r
+ }\r
+ else\r
+ this->ShowTab(IDC_CMD_LOG);\r
+\r
+ }else\r
+ {\r
+ if(newhash == this->m_oldHash)\r
+ {\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_CHANGELIST-1,false);\r
+ this->m_InLogList.ShowText(_T("No commits get after pull"));\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_LOGLIST-1,true);\r
+ }\r
+ else\r
+ {\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_CHANGELIST-1,true);\r
+ this->m_ctrlTabCtrl.ShowTab(IDC_IN_LOGLIST-1,true);\r
+ \r
+ this->AddDiffFileList(&m_InChangeFileList,&m_arInChangeList,newhash,m_oldHash);\r
+ \r
+ m_InLogList.FillGitLog(NULL,CGit:: LOG_INFO_STAT| CGit::LOG_INFO_FILESTATE | CGit::LOG_INFO_SHOW_MERGEDFILE,\r
+ &this->m_oldHash,&newhash);\r
+ }\r
+ this->ShowTab(IDC_IN_LOGLIST);\r
+ }\r