3 #include "AppUtils.h"
\r
6 #include "resource.h"
\r
7 #include "MessageBox.h"
\r
9 CGitDiff::CGitDiff(void)
\r
13 CGitDiff::~CGitDiff(void)
\r
16 int CGitDiff::Parser(git_revnum_t &rev)
\r
18 if(rev == GIT_REV_ZERO)
\r
20 if(rev.GetLength() > 40)
\r
23 cmd.Format(_T("git.exe rev-parse %s"),rev);
\r
25 if(!g_Git.Run(cmd,&output,CP_UTF8))
\r
27 //int start=output.Find(_T('\n'));
\r
28 rev=output.Left(40);
\r
33 int CGitDiff::DiffNull(CTGitPath *pPath, git_revnum_t &rev1,bool bIsAdd)
\r
36 GetTempPath(temppath);
\r
41 if(rev1 != GIT_REV_ZERO )
\r
43 file1.Format(_T("%s%s_%s%s"),
\r
45 pPath->GetBaseFilename(),
\r
47 pPath->GetFileExtension());
\r
48 cmd.Format(_T("git.exe cat-file -p %s:\"%s\""),rev1,pPath->GetGitPathString());
\r
49 g_Git.RunLogFile(cmd,file1);
\r
52 file1=g_Git.m_CurrentDir+_T("\\")+pPath->GetWinPathString();
\r
55 CString tempfile=::GetTempFile();
\r
56 CStdioFile file(tempfile,CFile::modeReadWrite|CFile::modeCreate );
\r
57 //file.WriteString();
\r
60 CAppUtils::DiffFlags flags;
\r
63 CAppUtils::StartExtDiff(tempfile,file1,
\r
65 pPath->GetGitPathString()+_T(":")+rev1.Left(6)
\r
68 CAppUtils::StartExtDiff(file1,tempfile,
\r
69 pPath->GetGitPathString()+_T(":")+rev1.Left(6)
\r
75 int CGitDiff::Diff(CTGitPath * pPath,CTGitPath * pPath2, git_revnum_t & rev1, git_revnum_t & rev2, bool /*blame*/, bool /*unified*/)
\r
78 GetTempPath(temppath);
\r
85 if(pPath->IsDirectory() || pPath2->IsDirectory())
\r
87 cmd.Format(_T("git.exe diff-tree -r -z %s %s -- \"%s\""),
\r
88 rev2,rev1,pPath->GetGitPathString());
\r
91 if(g_Git.Run(cmd,&bytes))
\r
94 g_Git.StringAppend(&err,&bytes[0],CP_ACP);
\r
95 CMessageBox::Show(NULL,err,_T("TortoiseGit"),MB_OK|MB_ICONERROR);
\r
99 g_Git.StringAppend(&oldhash,&bytes[15],CP_ACP,40);
\r
101 g_Git.StringAppend(&newhash,&bytes[15+41],CP_ACP,40);
\r
107 subgit.m_CurrentDir=g_Git.m_CurrentDir+_T("\\")+pPath->GetWinPathString();
\r
110 if(pPath->HasAdminDir())
\r
112 int encode=CAppUtils::GetLogOutputEncode(&subgit);
\r
114 if(oldhash != GIT_REV_ZERO)
\r
116 cmd.Format(_T("git log -n1 HEAD --pretty=format:\"%%s\" %s"),oldhash);
\r
117 subgit.Run(cmd,&oldsub,encode);
\r
120 if(newsub != GIT_REV_ZERO)
\r
122 cmd.Format(_T("git log -n1 HEAD --pretty=format:\"%%s\" %s"),newhash);
\r
123 subgit.Run(cmd,&newsub,encode);
\r
127 msg.Format(_T("Submodule <b>%s</b> Change\r\n\r\n<b>From:</b> %s\r\n\t%s\r\n\r\n<b>To:</b> %s\r\n\t\t%s"),
\r
128 pPath->GetWinPath(),
\r
133 CMessageBox::Show(NULL,msg,_T("TortoiseGit"),MB_OK);
\r
138 if(rev1 != GIT_REV_ZERO )
\r
140 file1.Format(_T("%s%s_%s%s"),
\r
142 pPath->GetBaseFilename(),
\r
144 pPath->GetFileExtension());
\r
145 title1 = pPath->GetFileOrDirectoryName()+_T(":")+rev1.Left(6);
\r
146 cmd.Format(_T("git.exe cat-file -p %s:\"%s\""),rev1,pPath->GetGitPathString());
\r
147 g_Git.RunLogFile(cmd,file1);
\r
150 file1=g_Git.m_CurrentDir+_T("\\")+pPath->GetWinPathString();
\r
151 title1.Format( IDS_DIFF_WCNAME, pPath->GetFileOrDirectoryName() );
\r
156 if(rev2 != GIT_REV_ZERO)
\r
159 file2.Format(_T("%s%s_%s%s"),
\r
161 pPath2->GetBaseFilename(),
\r
163 pPath2->GetFileExtension());
\r
164 title2 = pPath2->GetFileOrDirectoryName()+_T(":")+rev2.Left(6);
\r
165 cmd.Format(_T("git.exe cat-file -p %s:\"%s\""),rev2,pPath2->GetGitPathString());
\r
166 g_Git.RunLogFile(cmd,file2);
\r
169 file2=g_Git.m_CurrentDir+_T("\\")+pPath2->GetWinPathString();
\r
170 title2.Format( IDS_DIFF_WCNAME, pPath2->GetFileOrDirectoryName() );
\r
173 CAppUtils::DiffFlags flags;
\r
174 CAppUtils::StartExtDiff(file2,file1,
\r