Kiln » TortoiseHg » TortoiseHg
Clone URL:  
Pushed to one repository · View In Graph Contained in tip

fogcreek shellext: handle temporary file with CAtlTemporaryFile

Changeset d074300ef351

Parent 41ab2d81c589

by David Golub

Changes to 3 files · Browse files at d074300ef351 Showing diff from parent 41ab2d81c589 Diff from another changeset...

 
98
99
100
101
102
 
 
103
104
 
105
106
107
108
109
110
111
112
113
114
115
 
116
117
118
 
129
130
131
 
 
132
133
134
135
136
 
98
99
100
 
 
101
102
103
 
104
105
106
 
 
 
 
 
 
 
 
 
107
108
109
110
 
121
122
123
124
125
126
 
127
128
129
@@ -98,21 +98,13 @@
    if (!listFiles.IsEmpty())   { - CString strTempFile = GetTemporaryFile(); - if (strTempFile.IsEmpty()) + CAtlTemporaryFile file; + if (FAILED(file.Create()))   { - ATLTRACE("***** RunDialog: error: GetTemporaryFile returned empty string\n"); + ATLTRACE("***** RunDialog: error: failed to create temporary file\n");   return;   } - - ATLTRACE("RunDialog: temp file = %s\n", (LPCTSTR)strTempFile); - CAtlFile file; - if (FAILED(file.Create(strTempFile, GENERIC_WRITE, FILE_SHARE_READ, CREATE_ALWAYS))) - { - ATLTRACE("***** RunDialog: error: failed to create file '%s'\n", - (LPCTSTR)strTempFile); - return; - } + ATLTRACE("RunDialog: temp file = '%s'\n", file.TempFileName());     POSITION position = listFiles.GetHeadPosition();   while (position != NULL) @@ -129,8 +121,9 @@
  file.Write("\n", 1);   }   + strHgCmd += " --listfile "; + strHgCmd += file.TempFileName();   file.Close(); - strHgCmd += " --listfile " + Quote(strTempFile);   }     LaunchCommand(strHgCmd, strCwd);
 
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
 
72
73
74
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
75
76
77
@@ -72,27 +72,6 @@
  return true;  }   -CString GetTemporaryFile(LPCTSTR strPrefix) -{ - char szTempDir[MAX_PATH + 1]; - char szTempFile[MAX_PATH + 1]; - - if (::GetTempPath(MAX_PATH, szTempDir) == 0) - { - ATLTRACE("GetTemporaryFile: Failed to find temporary path\n"); - } - else if (::GetTempFileName(szTempDir, strPrefix, 0, szTempFile) != 0) - { - return szTempFile; - } - else - { - ATLTRACE("GetTemporaryFile: Failed to get temporary file\n"); - } - - return ""; -} -  CString DirName(const CString& strFileName)  {   if (strFileName.IsEmpty()) return strFileName;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 
19
20
21
22
23
24
25
26
27
 // Copyright (C) 2011 Fog Creek Software  //  // This program is free software: you can redistribute it and/or modify  // it under the terms of the GNU General Public License as published by  // the Free Software Foundation, either version 2 of the License, or  // (at your option) any later version.  //  // This program is distributed in the hope that it will be useful,  // but WITHOUT ANY WARRANTY; without even the implied warranty of  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the  // GNU General Public License for more details.  //  // You should have received a copy of the GNU General Public License  // along with this program. If not, see <http://www.gnu.org/licenses/>.    #pragma once    CString GetTHgProgRoot(); -CString GetTemporaryFile(LPCSTR strPrefix = "THG");  CString DirName(const CString& strFileName);  CString BaseName(const CString& strFileName);  bool LaunchCommand(const CString& strCommand, const CString& strCwd);  HICON GetTortoiseIcon(const CString& strIconName);  CString GetHgRepoRoot(LPCTSTR lpszPath);  bool IsHgRepo(const CString& lpszPath);  bool GetRegSZValueW(HKEY hKey, LPCWSTR lpszName, CStringW& strRes);  bool StartsWith(const CString& strWhole, const CString& strPrefix);  void Tokenize(CString str, CAtlList<CString>& rTokens, LPCTSTR lpszDelimiters = " ");