author | Claus Gittinger <cg@exept.de> |
Sun, 19 Nov 2017 22:17:17 +0100 | |
changeset 17771 | 0079b02e0f34 |
parent 17761 | 6aef9aa81103 |
child 17824 | ff3ebc3d0286 |
permissions | -rw-r--r-- |
6168 | 1 |
" |
2 |
COPYRIGHT (c) 2003 by eXept Software AG |
|
7637 | 3 |
All Rights Reserved |
6168 | 4 |
|
5 |
This software is furnished under a license and may be used |
|
6 |
only in accordance with the terms of that license and with the |
|
7 |
inclusion of the above copyright notice. This software may not |
|
8 |
be provided or otherwise made available to, or used by, any |
|
9 |
other person. No title to or ownership of the software is |
|
10 |
hereby transferred. |
|
11 |
" |
|
6618 | 12 |
"{ Package: 'stx:libtool' }" |
3841 | 13 |
|
15096 | 14 |
"{ NameSpace: Smalltalk }" |
15 |
||
3841 | 16 |
Object subclass:#FileOperation |
11444 | 17 |
instanceVariableNames:'errorString result actionForAll' |
3975
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
18 |
classVariableNames:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
19 |
poolDictionaries:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
20 |
category:'Interface-Support' |
3841 | 21 |
! |
22 |
||
3842 | 23 |
FileOperation subclass:#Copy |
6374 | 24 |
instanceVariableNames:'copiedFiles newFiles' |
3975
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
25 |
classVariableNames:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
26 |
poolDictionaries:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
27 |
privateIn:FileOperation |
3842 | 28 |
! |
29 |
||
7634 | 30 |
FileOperation::Copy subclass:#CopyCorrupted |
7637 | 31 |
instanceVariableNames:'' |
7634 | 32 |
classVariableNames:'' |
33 |
poolDictionaries:'' |
|
34 |
privateIn:FileOperation |
|
35 |
! |
|
36 |
||
3842 | 37 |
FileOperation subclass:#Create |
3975
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
38 |
instanceVariableNames:'createdFile' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
39 |
classVariableNames:'LastCreatedDirectory LastCreatedFile' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
40 |
poolDictionaries:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
41 |
privateIn:FileOperation |
3842 | 42 |
! |
43 |
||
44 |
FileOperation subclass:#Delete |
|
3975
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
45 |
instanceVariableNames:'fileName' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
46 |
classVariableNames:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
47 |
poolDictionaries:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
48 |
privateIn:FileOperation |
3842 | 49 |
! |
50 |
||
6168 | 51 |
FileOperation::Delete subclass:#Erase |
52 |
instanceVariableNames:'' |
|
53 |
classVariableNames:'' |
|
54 |
poolDictionaries:'' |
|
55 |
privateIn:FileOperation |
|
56 |
! |
|
57 |
||
3842 | 58 |
FileOperation subclass:#Move |
6374 | 59 |
instanceVariableNames:'movedFiles' |
3975
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
60 |
classVariableNames:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
61 |
poolDictionaries:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
62 |
privateIn:FileOperation |
3842 | 63 |
! |
64 |
||
65 |
FileOperation subclass:#Rename |
|
3975
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
66 |
instanceVariableNames:'renamedFiles' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
67 |
classVariableNames:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
68 |
poolDictionaries:'' |
dcaac82381dc
share goodRenameDefault code with FileBrowser
Claus Gittinger <cg@exept.de>
parents:
3877
diff
changeset
|
69 |
privateIn:FileOperation |
3842 | 70 |
! |
71 |
||
6168 | 72 |
!FileOperation class methodsFor:'documentation'! |
73 |
||
74 |
copyright |
|
75 |
" |
|
76 |
COPYRIGHT (c) 2003 by eXept Software AG |
|
7637 | 77 |
All Rights Reserved |
6168 | 78 |
|
79 |
This software is furnished under a license and may be used |
|
80 |
only in accordance with the terms of that license and with the |
|
81 |
inclusion of the above copyright notice. This software may not |
|
82 |
be provided or otherwise made available to, or used by, any |
|
83 |
other person. No title to or ownership of the software is |
|
84 |
hereby transferred. |
|
85 |
" |
|
86 |
! ! |
|
3841 | 87 |
|
7634 | 88 |
!FileOperation class methodsFor:'instance creation'! |
89 |
||
90 |
copyCorruptedFile:aSourceFile to:aDestFile |
|
15572 | 91 |
^ CopyCorrupted new |
92 |
copyFile:aSourceFile to:aDestFile withOverWriteWarning:false copyFileIfSame:false |
|
7634 | 93 |
|
94 |
"Created: / 07-02-2007 / 18:41:24 / cg" |
|
95 |
! |
|
5961 | 96 |
|
97 |
copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarningBoolean copyFileIfSame:copyIfSameBoolean |
|
7637 | 98 |
^ Copy |
99 |
copyFile:aSourceFile to:aDestFile |
|
100 |
withOverWriteWarning:overWriteWarningBoolean |
|
101 |
copyFileIfSame:copyIfSameBoolean |
|
5961 | 102 |
! |
103 |
||
104 |
copyFiles:aColOfSourceFiles to:aDirectory |
|
105 |
^ Copy copyFiles:aColOfSourceFiles to:aDirectory |
|
106 |
! |
|
107 |
||
108 |
createDirectoryIn:aDirectory |
|
109 |
^ Create createDirectoryIn:aDirectory |
|
110 |
! |
|
111 |
||
112 |
createDirectoryIn:aDirectory initialAnswer:defaultAnswer |
|
113 |
^ Create createDirectoryIn:aDirectory initialAnswer:defaultAnswer |
|
114 |
! |
|
115 |
||
116 |
createFileIn:aDirectory |
|
117 |
^ Create createFileIn:aDirectory |
|
118 |
! |
|
119 |
||
120 |
createHardLinkIn:dir |
|
121 |
^ Create createHardLinkIn:dir |
|
122 |
! |
|
123 |
||
6151 | 124 |
createLinkIn:dir soft:soft |
125 |
^ Create createLinkIn:dir soft:soft |
|
126 |
! |
|
127 |
||
5961 | 128 |
createSoftLinkIn:dir |
129 |
^ Create createSoftLinkIn:dir |
|
130 |
! |
|
131 |
||
132 |
deleteFiles:colOfFiles confirm:confirm |
|
133 |
^ Delete deleteFiles:colOfFiles confirm:confirm |
|
134 |
! |
|
135 |
||
6168 | 136 |
eraseFiles:colOfFiles confirm:confirm |
137 |
^ Erase deleteFiles:colOfFiles confirm:confirm |
|
138 |
! |
|
139 |
||
5961 | 140 |
moveFile:aSourceFile to:aDestFile |
6168 | 141 |
^ Move moveFile:aSourceFile to:aDestFile |
5961 | 142 |
! |
143 |
||
144 |
moveFiles:aCollectionOfFiles to:aDestDirectory |
|
6168 | 145 |
^ Move moveFiles:aCollectionOfFiles to:aDestDirectory |
5961 | 146 |
! |
147 |
||
148 |
renameFile:filename to:newFileString |
|
6168 | 149 |
^ Rename renameFile:filename to:newFileString |
5961 | 150 |
! |
151 |
||
152 |
renameFiles:aCollectionofFilenames |
|
6168 | 153 |
^ Rename renameFiles:aCollectionofFilenames |
5961 | 154 |
! ! |
155 |
||
3841 | 156 |
!FileOperation class methodsFor:'defaults'! |
157 |
||
6168 | 158 |
suffixForCopyOverExistingFile |
3841 | 159 |
^ '.copy' |
160 |
! ! |
|
161 |
||
15948 | 162 |
!FileOperation class methodsFor:'queries'! |
163 |
||
164 |
isAbstract |
|
165 |
^ self == FileOperation |
|
166 |
! ! |
|
167 |
||
3841 | 168 |
!FileOperation methodsFor:'accessing'! |
169 |
||
170 |
errorString |
|
171 |
^ errorString |
|
172 |
! |
|
173 |
||
174 |
errorString:something |
|
175 |
errorString := something. |
|
176 |
! |
|
177 |
||
178 |
result |
|
179 |
^ result |
|
180 |
! |
|
181 |
||
182 |
result:something |
|
183 |
result := something. |
|
184 |
! ! |
|
185 |
||
7634 | 186 |
!FileOperation methodsFor:'dialogs & helpers'! |
187 |
||
188 |
checkDirectoryExists:aDirectory |
|
189 |
aDirectory exists ifFalse:[ |
|
14187
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
190 |
(Dialog confirm:(AbstractFileBrowser classResources |
9663
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
191 |
stringWithCRs:'Non-existing directory: %1\\Create?' |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
192 |
with:aDirectory asString) |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
193 |
) ifFalse:[ |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
194 |
^ false |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
195 |
]. |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
196 |
aDirectory recursiveMakeDirectory. |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
197 |
aDirectory exists ifFalse:[ |
14187
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
198 |
Dialog warn:(AbstractFileBrowser classResources |
9663
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
199 |
string:'Failed to create directory: %1'). |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
200 |
^ false |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
201 |
]. |
7634 | 202 |
]. |
203 |
aDirectory isDirectory ifFalse:[ |
|
9663
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
204 |
Dialog warn:('Not a directory: %1' bindWith:aDirectory asString). |
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
205 |
^ false |
7634 | 206 |
]. |
207 |
^ true |
|
208 |
||
209 |
"Created: / 07-02-2007 / 18:30:49 / cg" |
|
9663
7837d4646761
changed: #checkDirectoryExists:
Claus Gittinger <cg@exept.de>
parents:
9650
diff
changeset
|
210 |
"Modified: / 09-12-2010 / 08:45:45 / cg" |
7634 | 211 |
! |
3841 | 212 |
|
6168 | 213 |
fileExistsDialogForNewFile:newFile oldFile:oldFile withCancel:withCancel |
4701 | 214 |
"return true, if the file should be moved/copied. |
215 |
Ask user if oldFile exists." |
|
216 |
||
6168 | 217 |
^ self fileExistsDialogForNewFile:newFile oldFile:oldFile withCancel:withCancel withRemoveIfSame:false. |
5862 | 218 |
! |
219 |
||
6168 | 220 |
fileExistsDialogForNewFile:newFile oldFile:oldFile withCancel:withCancel withRemoveIfSame:withRemoveIfSame |
5862 | 221 |
"return true, if the file should be moved/copied. |
222 |
If oldFile exists, ask user. |
|
223 |
If withRemoveIfSame is true, two additional possible values are returned: |
|
8557 | 224 |
#removeSource and #removeDestination. |
5862 | 225 |
" |
226 |
||
11444 | 227 |
^ self |
228 |
fileExistsDialogForNewFile:newFile oldFile:oldFile withCancel:withCancel withRemoveIfSame:withRemoveIfSame |
|
229 |
withAllAction:false |
|
230 |
||
231 |
"Modified: / 20-03-2012 / 11:44:51 / cg" |
|
232 |
! |
|
233 |
||
234 |
fileExistsDialogForNewFile:newFile oldFile:oldFile withCancel:withCancel withRemoveIfSame:withRemoveIfSame withAllAction:withAllAction |
|
235 |
"return true, if the file should be moved/copied. |
|
236 |
If oldFile exists, ask user. |
|
237 |
If withRemoveIfSame is true, two additional possible values are returned: |
|
238 |
#removeSource and #removeDestination. |
|
239 |
" |
|
240 |
||
17758 | 241 |
|msg oldSize newSize sameContents resources sourceType destType labels values default |
242 |
forAllHolder answer oldFileIsDirectory newFileIsDirectory |
|
243 |
oldFileTime newFileTime olderOrNewer |
|
244 |
newFileSize oldFileSize smallerOrLarger| |
|
4701 | 245 |
|
246 |
newFile exists ifFalse:[ ^ true ]. |
|
247 |
oldSize := oldFile fileSize. |
|
248 |
newSize := newFile fileSize. |
|
249 |
||
5888 | 250 |
sameContents := false. |
15453 | 251 |
oldFileIsDirectory := oldFile isDirectory. |
252 |
newFileIsDirectory := newFile isDirectory. |
|
5888 | 253 |
|
15453 | 254 |
newFileIsDirectory ifTrue:[ |
255 |
oldFileIsDirectory ifTrue:[ |
|
8557 | 256 |
"/ could (should?) recursively look for same contents here... |
257 |
]. |
|
5888 | 258 |
] ifFalse:[ |
15453 | 259 |
oldFileIsDirectory ifFalse:[ |
8557 | 260 |
sameContents := oldSize = newSize and:[oldFile sameContentsAs:newFile]. |
261 |
] |
|
5888 | 262 |
]. |
263 |
||
8557 | 264 |
resources := AbstractFileBrowser classResources. |
265 |
||
5888 | 266 |
"/ for now: |
15453 | 267 |
oldFileIsDirectory ~~ newFileIsDirectory ifTrue:[ |
8557 | 268 |
Dialog warn:(resources string:'Will not overwrite directory with file and vice versa.'). |
269 |
^ false. |
|
5888 | 270 |
]. |
271 |
||
15453 | 272 |
sourceType := newFileIsDirectory ifTrue:'directory' ifFalse:'file'. |
273 |
destType := oldFileIsDirectory ifTrue:'directory' ifFalse:'file'. |
|
3841 | 274 |
|
4701 | 275 |
sameContents ifTrue:[ |
17761 | 276 |
msg := 'Overwrite existing destination ',destType,':\\ %1\ size: %3 of %2\\with %8 source (same contents):\\ %4\ size: %6 of %5'. |
4701 | 277 |
] ifFalse:[ |
17761 | 278 |
msg := 'Overwrite existing destination ',destType,':\\ %1\ size: %3 of %2\\with %8 source (%9):\\ %4\ size: %6 of %5'. |
4701 | 279 |
]. |
17758 | 280 |
|
15572 | 281 |
newFileTime := newFile modificationTime ? Timestamp now. |
282 |
oldFileTime := oldFile modificationTime ? Timestamp now. |
|
283 |
olderOrNewer := newFileTime < oldFileTime |
|
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
284 |
ifTrue:[ 'newer' ] |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
285 |
ifFalse:[ 'older' ]. |
17758 | 286 |
|
287 |
newFileSize := newFile fileSize. |
|
288 |
oldFileSize := oldFile fileSize. |
|
289 |
smallerOrLarger := newFileSize < oldFileSize |
|
17761 | 290 |
ifTrue:[ 'larger' ] |
17758 | 291 |
ifFalse:[ |
292 |
newFileSize = oldFileSize |
|
293 |
ifTrue:['same size'] |
|
17761 | 294 |
ifFalse:['smaller' ]]. |
17758 | 295 |
|
7637 | 296 |
msg := resources |
8557 | 297 |
stringWithCRs:msg |
298 |
withArgs:(Array |
|
299 |
with:newFile asString allBold |
|
15572 | 300 |
with:(newFileTime printStringFormat:'%(Day)-%(mon)-%(year) %h:%m:%s') |
8557 | 301 |
with:newSize |
302 |
with:oldFile asString allBold |
|
15572 | 303 |
with:(oldFileTime printStringFormat:'%(Day)-%(mon)-%(year) %h:%m:%s') |
8557 | 304 |
with:oldSize |
17761 | 305 |
with:destType "/ file or directory - no longer used in template |
17758 | 306 |
with:(resources string:olderOrNewer) |
307 |
with:(resources string:smallerOrLarger) ). |
|
4701 | 308 |
|
5862 | 309 |
(sameContents and:[withRemoveIfSame]) ifTrue:[ |
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
310 |
labels := #( 'No' 'Remove Destination' 'Remove Source' 'Yes'). |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
311 |
values := #( false #removeDestination #removeSource true ). |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
312 |
withCancel ifTrue:[ |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
313 |
labels := #('Cancel') , labels. |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
314 |
values := #( nil ) , values. |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
315 |
]. |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
316 |
default := #removeSource. |
5862 | 317 |
] ifFalse:[ |
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
318 |
labels := #( 'No' 'Yes'). |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
319 |
values := #( false true ). |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
320 |
withCancel ifTrue:[ |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
321 |
labels := #('Cancel') , labels. |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
322 |
values := #( nil ) , values. |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
323 |
]. |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
324 |
default := false. |
5862 | 325 |
]. |
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
326 |
|
11444 | 327 |
forAllHolder := false asValue. |
15453 | 328 |
Dialog modifyingBoxWith:[:box | |
11444 | 329 |
withAllAction ifTrue:[ |
13345
ef9354aa1ab9
aboutToOpenBoxNotificationSignal semantic change (for Jan)
Claus Gittinger <cg@exept.de>
parents:
12726
diff
changeset
|
330 |
box addVerticalSpace:10. |
ef9354aa1ab9
aboutToOpenBoxNotificationSignal semantic change (for Jan)
Claus Gittinger <cg@exept.de>
parents:
12726
diff
changeset
|
331 |
box verticalPanel |
11444 | 332 |
add:(CheckBox |
17761 | 333 |
label:(resources string:'Same action for all') |
11444 | 334 |
model:forAllHolder). |
335 |
]. |
|
336 |
] do:[ |
|
337 |
answer := OptionBox |
|
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
338 |
request:msg |
17758 | 339 |
label:(resources string:'Confirm overwrite existing file') |
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
340 |
image:(YesNoBox iconBitmap) |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
341 |
buttonLabels:(resources array:labels) |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
342 |
values:values |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
343 |
default:default |
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
344 |
onCancel:nil. |
11444 | 345 |
]. |
346 |
(withAllAction and:[answer notNil]) ifTrue:[ |
|
347 |
actionForAll := answer |
|
348 |
]. |
|
349 |
^ answer |
|
9512
fc8df478d3f1
changed: #fileExistsDialogForNewFile:oldFile:withCancel:withRemoveIfSame:
Claus Gittinger <cg@exept.de>
parents:
9501
diff
changeset
|
350 |
|
11444 | 351 |
"Created: / 20-03-2012 / 11:44:34 / cg" |
17761 | 352 |
"Modified: / 17-11-2017 / 13:28:04 / cg" |
3841 | 353 |
! ! |
354 |
||
6285 | 355 |
!FileOperation methodsFor:'queries'! |
356 |
||
357 |
isErase |
|
358 |
^ false |
|
359 |
! ! |
|
360 |
||
3842 | 361 |
!FileOperation::Copy class methodsFor:'actions'! |
362 |
||
363 |
copyFile:aSourceFile to:aDestFile |
|
364 |
|instance| |
|
365 |
||
366 |
instance := self new. |
|
367 |
instance copyFile:aSourceFile to:aDestFile. |
|
368 |
^ instance |
|
369 |
! |
|
370 |
||
371 |
copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning |
|
372 |
|instance| |
|
373 |
||
374 |
instance := self new. |
|
375 |
instance copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning. |
|
376 |
^ instance |
|
377 |
! |
|
378 |
||
5961 | 379 |
copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarningBoolean copyFileIfSame:copyIfSameBoolean |
3842 | 380 |
|instance| |
381 |
||
382 |
instance := self new. |
|
5961 | 383 |
instance copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarningBoolean copyFileIfSame:copyIfSameBoolean. |
3842 | 384 |
^ instance |
385 |
! |
|
386 |
||
387 |
copyFiles:aColOfSourceFiles to:aDirectory |
|
388 |
|instance| |
|
389 |
||
390 |
instance := self new. |
|
391 |
instance copyFiles:aColOfSourceFiles to:aDirectory. |
|
392 |
^ instance |
|
393 |
! |
|
394 |
||
395 |
copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning |
|
396 |
|instance| |
|
397 |
||
398 |
instance := self new. |
|
399 |
instance copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning. |
|
400 |
^ instance |
|
401 |
! |
|
402 |
||
403 |
copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning copyFileIfSame:copy |
|
404 |
|instance| |
|
405 |
||
406 |
instance := self new. |
|
407 |
instance copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning copyFileIfSame:copy. |
|
408 |
^ instance |
|
409 |
! ! |
|
410 |
||
411 |
!FileOperation::Copy methodsFor:'accessing'! |
|
412 |
||
413 |
colOfCopiedFiles |
|
6373 | 414 |
"obsolete - bad name" |
415 |
||
416 |
^ self collectionOfCopiedFiles |
|
417 |
! |
|
418 |
||
419 |
collectionOfCopiedFiles |
|
6374 | 420 |
copiedFiles isNil ifTrue:[ |
7637 | 421 |
copiedFiles := OrderedCollection new. |
3842 | 422 |
]. |
6374 | 423 |
^ copiedFiles |
424 |
! |
|
425 |
||
426 |
collectionOfNewFiles |
|
427 |
newFiles isNil ifTrue:[ |
|
7637 | 428 |
newFiles := OrderedCollection new. |
6374 | 429 |
]. |
430 |
^ newFiles |
|
3842 | 431 |
! ! |
432 |
||
433 |
!FileOperation::Copy methodsFor:'actions'! |
|
434 |
||
435 |
copyFile:aSourceFile to:aDestFile |
|
436 |
self copyFile:aSourceFile to:aDestFile withOverWriteWarning:true |
|
437 |
! |
|
438 |
||
439 |
copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning |
|
15572 | 440 |
self copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning copyFileIfSame:true |
3842 | 441 |
! |
442 |
||
6373 | 443 |
copyFiles:aColOfSourceFiles to:aDirectory |
7637 | 444 |
^ self copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:true. |
6373 | 445 |
! |
446 |
||
7637 | 447 |
copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning |
6373 | 448 |
^ self copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning copyFileIfSame:true. |
449 |
! ! |
|
450 |
||
451 |
!FileOperation::Copy methodsFor:'actions-basic'! |
|
452 |
||
7634 | 453 |
basicCopy:aSourceFile to:newFile |
454 |
aSourceFile isDirectory ifTrue:[ |
|
8289
8dcce3984b27
fixed recursive directory copy
Claus Gittinger <cg@exept.de>
parents:
7637
diff
changeset
|
455 |
aSourceFile recursiveCopyTo:newFile. |
8dcce3984b27
fixed recursive directory copy
Claus Gittinger <cg@exept.de>
parents:
7637
diff
changeset
|
456 |
"/ OperatingSystem recursiveCopyDirectory:(aSourceFile pathName) to:(newFile pathName). |
7634 | 457 |
] ifFalse:[ |
8289
8dcce3984b27
fixed recursive directory copy
Claus Gittinger <cg@exept.de>
parents:
7637
diff
changeset
|
458 |
aSourceFile copyTo:newFile. |
7634 | 459 |
]. |
3842 | 460 |
|
7634 | 461 |
"Created: / 07-02-2007 / 18:35:52 / cg" |
462 |
! |
|
463 |
||
464 |
copyFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarningBoolean copyFileIfSame:copyIfSameBoolean |
|
465 |
|newFile fileString targetDirectory suffix| |
|
466 |
||
467 |
aDestFile isDirectory ifTrue:[ |
|
13703 | 468 |
targetDirectory := aDestFile. |
469 |
newFile := aDestFile construct:(aSourceFile baseName). |
|
3842 | 470 |
] ifFalse:[ |
13703 | 471 |
targetDirectory := aDestFile directory. |
472 |
newFile := aDestFile. |
|
3842 | 473 |
]. |
7634 | 474 |
|
15572 | 475 |
"/ do not copy if destination directory doesnt exist. |
7634 | 476 |
(self checkDirectoryExists:targetDirectory) ifFalse:[ |
13703 | 477 |
result := false. |
478 |
^ self |
|
3842 | 479 |
]. |
480 |
(newFile exists) ifTrue:[ |
|
13703 | 481 |
((newFile asString = aSourceFile asString) and:[copyIfSameBoolean]) ifTrue:[ |
482 |
[newFile exists] whileTrue:[ |
|
483 |
suffix := newFile suffix. |
|
484 |
fileString := newFile baseName withoutSuffix, self class suffixForCopyOverExistingFile, '.', suffix. |
|
485 |
newFile := targetDirectory construct:fileString. |
|
486 |
]. |
|
487 |
] ifFalse:[ |
|
488 |
overWriteWarningBoolean ifTrue:[ |
|
489 |
(self fileExistsDialogForNewFile:newFile oldFile:aSourceFile withCancel:false withRemoveIfSame:false) ifFalse:[ |
|
490 |
result := false. |
|
491 |
^ self. |
|
492 |
] |
|
493 |
] ifFalse:[ |
|
15572 | 494 |
(Dialog confirm:('Destination "%1" exists - overwrite?' bindWith:aDestFile)) ifFalse:[ |
13703 | 495 |
result := false. |
496 |
^ self. |
|
15572 | 497 |
] |
13703 | 498 |
] |
499 |
]. |
|
3842 | 500 |
]. |
13703 | 501 |
StreamError handle:[:ex| |
502 |
"was not able to copy it" |
|
503 |
newFile remove. |
|
504 |
WarningBox warn:'on copy file - ', ex description. |
|
505 |
self errorString:('on copy file - ', ex description asString). |
|
506 |
result := false. |
|
507 |
^ self |
|
3842 | 508 |
] do:[ |
13703 | 509 |
self basicCopy:aSourceFile to:newFile. |
3842 | 510 |
]. |
4006
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
511 |
DirectoryContents flushCachedDirectoryFor:(aSourceFile directory). |
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
512 |
result := true. |
7634 | 513 |
|
514 |
"Modified: / 07-02-2007 / 18:36:02 / cg" |
|
3842 | 515 |
! |
516 |
||
517 |
copyFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning copyFileIfSame:copy |
|
7634 | 518 |
|newFile suffix fileString doCopy| |
3842 | 519 |
|
7634 | 520 |
"/ do not copy if destination directory doest exist. |
521 |
(self checkDirectoryExists:aDirectory) ifFalse:[ |
|
7637 | 522 |
result := false. |
523 |
^ self |
|
3842 | 524 |
]. |
6374 | 525 |
|
526 |
aColOfSourceFiles do:[:filename | |
|
7637 | 527 |
newFile := aDirectory construct:(filename baseName). |
528 |
doCopy := true. |
|
529 |
(newFile exists) ifTrue:[ |
|
530 |
((newFile asString = filename asString) and:[copy]) ifTrue:[ |
|
531 |
[newFile exists] whileTrue:[ |
|
532 |
suffix := newFile suffix. |
|
533 |
fileString := newFile withoutSuffix baseName, self class suffixForCopyOverExistingFile. |
|
534 |
suffix notEmpty ifTrue:[ |
|
535 |
fileString := fileString, '.', suffix. |
|
536 |
]. |
|
537 |
newFile := aDirectory construct:fileString. |
|
538 |
]. |
|
539 |
] ifFalse:[ |
|
540 |
overWriteWarning ifTrue:[ |
|
541 |
doCopy := (self fileExistsDialogForNewFile:newFile oldFile:filename withCancel:(aColOfSourceFiles size > 1) withRemoveIfSame:false). |
|
542 |
doCopy isNil ifTrue:[ |
|
543 |
" abort pressed " |
|
544 |
result := false. |
|
545 |
^ self. |
|
546 |
] |
|
547 |
] |
|
548 |
]. |
|
549 |
]. |
|
550 |
doCopy ifTrue:[ |
|
551 |
Error handle:[:ex| |
|
552 |
|msg| |
|
7634 | 553 |
|
7637 | 554 |
msg := 'on copy file - ', ex description asString. |
555 |
"was not able to copy it" |
|
556 |
result := false. |
|
557 |
self errorString:msg. |
|
558 |
( Dialog |
|
559 |
confirm:('Error ',msg) |
|
560 |
title:'Copy' |
|
561 |
yesLabel:'Continue' |
|
562 |
noLabel:'Abort') ifTrue:[ |
|
563 |
ex proceed. |
|
564 |
] ifFalse:[ |
|
565 |
^ self. |
|
566 |
]. |
|
567 |
] do:[ |
|
568 |
self basicCopy:filename to:newFile |
|
569 |
]. |
|
570 |
self collectionOfCopiedFiles add:filename. |
|
571 |
self collectionOfNewFiles add:newFile. |
|
572 |
] |
|
3842 | 573 |
]. |
4006
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
574 |
DirectoryContents flushCachedDirectoryFor:aDirectory. |
3842 | 575 |
result := true. |
7634 | 576 |
|
577 |
"Modified: / 07-02-2007 / 18:36:54 / cg" |
|
578 |
! ! |
|
579 |
||
580 |
!FileOperation::CopyCorrupted methodsFor:'actions-basic'! |
|
581 |
||
582 |
basicCopy:aSourceFile to:newFile |
|
583 |
aSourceFile isDirectory ifTrue:[ |
|
7637 | 584 |
newFile makeDirectory. |
585 |
aSourceFile directoryContentsDo:[:eachFileOrDirectory | |
|
586 |
self basicCopy:(aSourceFile construct:eachFileOrDirectory) to:(newFile construct:eachFileOrDirectory) |
|
587 |
]. |
|
7634 | 588 |
] ifFalse:[ |
7637 | 589 |
self basicCopyFile:aSourceFile to:newFile. |
7634 | 590 |
]. |
591 |
||
592 |
"Created: / 07-02-2007 / 18:39:03 / cg" |
|
593 |
! |
|
594 |
||
595 |
basicCopyFile:sourceFile to:destFile |
|
596 |
"this is a copy which is tolerant w.r.t. read errors. |
|
597 |
Wheneven a read fails, a number of retries is performed |
|
598 |
(with smaller buffer sizes) and, a block of zeros is eventually written. |
|
599 |
This allows for partially corrupted data to be read from a tape or disk." |
|
600 |
||
601 |
|in in2 out doWrite doRead fileSize offset buffer bufferSize nRead nWritten nSingle |
|
602 |
lostStart lostEnd seekFailed| |
|
603 |
||
9501 | 604 |
buffer := ByteArray new:(self bufferSize). |
7634 | 605 |
bufferSize := buffer size. |
606 |
offset := 0. |
|
15572 | 607 |
sourceFile info isCharacterSpecial ifTrue:[ |
608 |
] ifFalse:[ |
|
609 |
fileSize := sourceFile fileSize. |
|
610 |
]. |
|
7634 | 611 |
in := sourceFile readStream binary. |
612 |
out := destFile writeStream binary. |
|
613 |
||
614 |
doWrite := [:n | |
|
8557 | 615 |
nWritten := out nextPutBytes:n from:buffer startingAt:1. |
616 |
offset := offset + nWritten. |
|
617 |
nWritten ~= n ifTrue:[ |
|
618 |
self error:'Write error'. |
|
619 |
]. |
|
620 |
]. |
|
7634 | 621 |
|
622 |
doRead := [:n | |
|
8557 | 623 |
ReadError handle:[:ex | |
624 |
nRead := 0. |
|
625 |
in position:offset. |
|
626 |
] do:[ |
|
627 |
nRead := in nextBytes:n into:buffer startingAt:1. |
|
628 |
]. |
|
629 |
]. |
|
7634 | 630 |
|
631 |
[ |
|
15572 | 632 |
[ |
633 |
(fileSize notNil |
|
634 |
ifTrue:[offset < fileSize] |
|
635 |
ifFalse:[true "in atEnd not"]) |
|
636 |
] whileTrue:[ |
|
637 |
|n| |
|
638 |
||
639 |
n := fileSize notNil |
|
640 |
ifTrue:[ bufferSize min:(fileSize - offset) ] |
|
641 |
ifFalse:[ bufferSize ]. |
|
642 |
Transcript show:'read @'; showCR:offset. |
|
643 |
doRead value:n. |
|
8557 | 644 |
nRead > 0 ifTrue:[ |
645 |
lostStart notNil ifTrue:[ |
|
646 |
Transcript showCR:'CORRUPT: ',(lostStart printString),' .. ',(lostEnd printString). |
|
647 |
lostStart := nil. |
|
648 |
]. |
|
649 |
doWrite value:nRead. |
|
650 |
]. |
|
7634 | 651 |
|
15572 | 652 |
nRead == n ifTrue:[ |
8557 | 653 |
bufferSize < buffer size ifTrue:[ |
654 |
bufferSize := bufferSize * 2. |
|
655 |
]. |
|
656 |
] ifFalse:[ |
|
657 |
nRead == 0 ifTrue:[ |
|
658 |
"/ try reading single blocks for a while... |
|
9501 | 659 |
nSingle := self defectBlockRetryCount. |
8557 | 660 |
[ |
9501 | 661 |
nSingle > 0 |
8557 | 662 |
and:[ |
9501 | 663 |
doRead value:(self defectBlockCopySize). |
8557 | 664 |
nRead > 0] |
665 |
] whileTrue:[ |
|
666 |
lostStart notNil ifTrue:[ |
|
667 |
Transcript showCR:'CORRUPT: ',(lostStart printString),' .. ',(lostEnd printString). |
|
668 |
lostStart := nil. |
|
669 |
]. |
|
9501 | 670 |
Transcript showCR:'single block at ',offset printString, 'size=',nRead printString. |
8557 | 671 |
doWrite value:nRead. |
672 |
nSingle := nSingle - 1. |
|
673 |
]. |
|
7634 | 674 |
|
8557 | 675 |
nRead == 0 ifTrue:[ |
676 |
in2 := sourceFile readStream binary. |
|
677 |
Error handle:[:ex | |
|
678 |
] do:[ |
|
679 |
in2 position:0. |
|
680 |
in2 nextBytes:buffer size into:buffer startingAt:1. |
|
681 |
]. |
|
682 |
seekFailed := false. |
|
683 |
Error handle:[:ex | |
|
684 |
seekFailed := true. |
|
685 |
] do:[ |
|
686 |
in2 position:offset. |
|
687 |
]. |
|
688 |
seekFailed ifTrue:[ |
|
9501 | 689 |
buffer atAllPut:0. |
8557 | 690 |
Transcript showCR:'bad seek at ',offset printString. |
9501 | 691 |
doWrite value:(self defectBlockCopySize). |
8557 | 692 |
] ifFalse:[ |
693 |
in close. |
|
694 |
in := in2. |
|
9501 | 695 |
doRead value:(self defectBlockCopySize). |
8557 | 696 |
nRead > 0 ifTrue:[ |
7634 | 697 |
Transcript showCR:'single after reopen at ',offset printString. |
8557 | 698 |
doWrite value:nRead. |
699 |
] ifFalse:[ |
|
700 |
lostStart isNil ifTrue:[ |
|
701 |
lostStart := lostEnd := offset. |
|
702 |
] ifFalse:[ |
|
703 |
lostEnd := offset. |
|
704 |
]. |
|
9501 | 705 |
buffer atAllPut:0. |
7634 | 706 |
Transcript showCR:'bad at ',offset printString. |
9501 | 707 |
doWrite value:(self defectBlockCopySize). |
708 |
bufferSize := (self defectBlockCopySize). |
|
8557 | 709 |
]. |
710 |
] |
|
711 |
] |
|
712 |
]. |
|
713 |
]. |
|
15572 | 714 |
Transcript show:'wrote @'; showCR:offset. |
8557 | 715 |
]. |
7634 | 716 |
] ensure:[ |
8557 | 717 |
in close. |
718 |
out close. |
|
7634 | 719 |
]. |
720 |
lostStart notNil ifTrue:[ |
|
8557 | 721 |
Transcript showCR:'CORRUPT: ',(lostStart printString),' .. ',(lostEnd printString). |
722 |
lostStart := nil. |
|
7634 | 723 |
]. |
724 |
||
725 |
"Created: / 07-02-2007 / 18:40:32 / cg" |
|
9501 | 726 |
"Modified: / 21-06-2010 / 14:25:22 / cg" |
727 |
! ! |
|
728 |
||
729 |
!FileOperation::CopyCorrupted methodsFor:'defaults'! |
|
730 |
||
731 |
bufferSize |
|
732 |
^ 1024*1024*1 |
|
733 |
||
734 |
"Created: / 21-06-2010 / 14:20:35 / cg" |
|
735 |
! |
|
736 |
||
737 |
defectBlockCopySize |
|
738 |
"/ ^ 256 |
|
9650 | 739 |
^ 128*1024 |
9501 | 740 |
|
741 |
"Created: / 21-06-2010 / 14:22:23 / cg" |
|
9650 | 742 |
"Modified: / 27-11-2010 / 18:06:10 / cg" |
9501 | 743 |
! |
744 |
||
745 |
defectBlockRetryCount |
|
9650 | 746 |
^ 1 |
9501 | 747 |
|
748 |
"Created: / 21-06-2010 / 14:24:45 / cg" |
|
9650 | 749 |
"Modified: / 27-11-2010 / 18:05:19 / cg" |
3842 | 750 |
! ! |
751 |
||
752 |
!FileOperation::Create class methodsFor:'actions'! |
|
753 |
||
3863 | 754 |
createDirectoryIn:aDirectory |
3842 | 755 |
|
756 |
|instance| |
|
757 |
||
758 |
instance := self new. |
|
3863 | 759 |
instance createDirectoryIn:aDirectory. |
3842 | 760 |
^ instance |
761 |
! |
|
762 |
||
5961 | 763 |
createDirectoryIn:aDirectory initialAnswer:defaultAnswer |
764 |
||
765 |
|instance| |
|
766 |
||
767 |
instance := self new. |
|
768 |
instance createDirectoryIn:aDirectory initialAnswer:defaultAnswer. |
|
769 |
^ instance |
|
770 |
! |
|
771 |
||
3863 | 772 |
createFileIn:aFile |
3842 | 773 |
|
774 |
|instance| |
|
775 |
||
776 |
instance := self new. |
|
3863 | 777 |
instance createFileIn:aFile. |
3842 | 778 |
^ instance |
3877 | 779 |
! |
780 |
||
781 |
createHardLinkIn:aFile |
|
782 |
"create an new hard link in a files directory" |
|
783 |
||
6151 | 784 |
^ self createLinkIn:aFile soft:false |
785 |
! |
|
786 |
||
787 |
createLinkIn:aFile soft:soft |
|
788 |
"create an new soft or hard link in a files directory" |
|
789 |
||
3877 | 790 |
|instance| |
791 |
||
792 |
instance := self new. |
|
6151 | 793 |
instance createLinkIn:aFile soft:soft. |
3877 | 794 |
^ instance |
795 |
! |
|
796 |
||
797 |
createSoftLinkIn:aFile |
|
798 |
"create an new soft link in a files directory" |
|
799 |
||
6151 | 800 |
^ self createLinkIn:aFile soft:true |
3842 | 801 |
! ! |
802 |
||
3863 | 803 |
!FileOperation::Create methodsFor:'accessing'! |
804 |
||
805 |
createdFile |
|
806 |
^ createdFile |
|
807 |
! |
|
808 |
||
809 |
createdFile:something |
|
810 |
createdFile := something. |
|
3842 | 811 |
! ! |
812 |
||
813 |
!FileOperation::Create methodsFor:'actions'! |
|
814 |
||
3863 | 815 |
createDirectoryIn:startDirectory |
4522 | 816 |
|defaultDirectory| |
3863 | 817 |
|
4522 | 818 |
"/ stupid - that one already exists |
819 |
"/ LastCreatedDirectory notNil ifTrue:[ |
|
820 |
"/ defaultDirectory := LastCreatedDirectory baseName. |
|
821 |
"/ ]. |
|
7637 | 822 |
|
4522 | 823 |
^ self createDirectoryIn:startDirectory initialAnswer:defaultDirectory |
824 |
! |
|
825 |
||
6373 | 826 |
createHardLinkIn:aFile |
827 |
"create an new hard link in a files directory" |
|
828 |
||
829 |
self createLinkIn:aFile soft:false. |
|
830 |
! |
|
831 |
||
832 |
createSoftLinkIn:aFile |
|
833 |
"create an new soft link in a files directory" |
|
834 |
||
835 |
self createLinkIn:aFile soft:true. |
|
836 |
! |
|
837 |
||
838 |
operationError:msg |
|
839 |
self result:false. |
|
840 |
Dialog warn:msg. |
|
841 |
self errorString:msg. |
|
842 |
! ! |
|
843 |
||
844 |
!FileOperation::Create methodsFor:'actions-basic'! |
|
845 |
||
4522 | 846 |
createDirectoryIn:startDirectory initialAnswer:initialAnswerArg |
4584 | 847 |
|resources initialAnswer msg startBaseName newName newDir| |
848 |
||
849 |
resources := AbstractFileBrowser classResources. |
|
3842 | 850 |
|
3863 | 851 |
startBaseName := startDirectory baseName. |
4522 | 852 |
initialAnswer := initialAnswerArg. |
853 |
(startDirectory construct:initialAnswer) exists ifTrue:[ |
|
15096 | 854 |
initialAnswer := nil. |
3863 | 855 |
]. |
7084 | 856 |
newName := Dialog |
15096 | 857 |
request:(resources string:'Create New Directory in %1:' with:startBaseName allBold) |
858 |
initialAnswer:initialAnswer |
|
859 |
okLabel:(resources string:'Create') |
|
860 |
title:(resources string:'Create Directory') |
|
861 |
onCancel:[ |
|
862 |
self result:false. |
|
863 |
^ self |
|
864 |
]. |
|
3863 | 865 |
newName isEmpty ifTrue:[ |
15096 | 866 |
self result:false. |
867 |
^ self |
|
3863 | 868 |
]. |
4522 | 869 |
newDir := startDirectory construct:newName. |
870 |
newDir exists ifTrue:[ |
|
15096 | 871 |
Dialog warn:(newName, ' already exists.'). |
872 |
result := false. |
|
873 |
^ self |
|
3842 | 874 |
]. |
875 |
||
15096 | 876 |
OsError handle:[:ex| |
877 |
msg := errorString := 'cannot create directory "', newName,'" (', (OperatingSystem lastErrorString) , ')'. |
|
878 |
errorString := msg. |
|
879 |
Dialog warn:errorString. |
|
880 |
result := false. |
|
881 |
^ self |
|
882 |
] do:[ |
|
883 |
newDir makeDirectory |
|
3842 | 884 |
]. |
15096 | 885 |
|
4522 | 886 |
self createdFile:newDir. |
887 |
LastCreatedDirectory := newDir. |
|
3842 | 888 |
result := true. |
7084 | 889 |
|
890 |
"Modified: / 05-09-2006 / 11:52:48 / cg" |
|
3842 | 891 |
! |
892 |
||
3863 | 893 |
createFileIn:aFile |
3842 | 894 |
"create an empty file" |
895 |
||
16322 | 896 |
|resources aStream msg file directory newName defaultFile newFile| |
4584 | 897 |
|
898 |
resources := AbstractFileBrowser classResources. |
|
3842 | 899 |
|
3863 | 900 |
aFile isDirectory ifTrue:[ |
15096 | 901 |
directory := aFile |
3863 | 902 |
] ifFalse:[ |
15096 | 903 |
directory := aFile directory. |
904 |
file := aFile |
|
3863 | 905 |
]. |
906 |
LastCreatedFile isNil ifTrue:[ |
|
15096 | 907 |
defaultFile := aFile baseName. |
3863 | 908 |
] ifFalse:[ |
15096 | 909 |
defaultFile := LastCreatedFile baseName. |
3842 | 910 |
]. |
3863 | 911 |
newName := Dialog |
15096 | 912 |
request:(resources string:'Create New File in %1:' with:directory baseName allBold) |
913 |
initialAnswer:defaultFile |
|
914 |
okLabel:(resources string:'Create') |
|
915 |
title:(resources string:'Create File') |
|
916 |
onCancel:[ |
|
917 |
self result:false. |
|
918 |
^ self |
|
919 |
]. |
|
16322 | 920 |
|
921 |
newName isEmptyOrNil ifTrue:[ |
|
15096 | 922 |
self result:false. |
16322 | 923 |
^ self |
924 |
]. |
|
925 |
||
926 |
newFile := directory construct:newName. |
|
927 |
||
928 |
(newFile exists) ifTrue:[ |
|
929 |
(newFile isRegularFile) ifTrue:[ |
|
930 |
newFile fileSize == 0 ifTrue:[ |
|
931 |
Dialog |
|
932 |
information:(resources stringWithCRs:'An empty "%1" (i.e. with size 0) already existed.' with:newName). |
|
933 |
self createdFile:newFile. |
|
934 |
self result:true. |
|
935 |
^ self |
|
936 |
]. |
|
15096 | 937 |
(Dialog |
16322 | 938 |
confirm:(resources stringWithCRs:'"%1" already exists (with size %2)\\Truncate ?' with:newName with:newFile fileSize) |
939 |
yesLabel:(resources string:'Truncate') |
|
940 |
noLabel:(resources string:'Cancel')) |
|
15096 | 941 |
ifFalse:[ |
942 |
self result:false. |
|
943 |
^ self |
|
944 |
]. |
|
16322 | 945 |
] ifFalse:[ |
946 |
Dialog warn:(resources stringWithCRs:'"%1" already exists as a %2' with:newFile fileType). |
|
15096 | 947 |
self result:false. |
16322 | 948 |
^ self |
949 |
]. |
|
3842 | 950 |
]. |
16322 | 951 |
|
952 |
FileStream openErrorSignal handle:[:ex| |
|
953 |
msg := resources string:'Cannot create file "%1" (%2)' with:newName with:(FileStream lastErrorString). |
|
954 |
errorString := msg. |
|
955 |
self result:false. |
|
956 |
Dialog warn:errorString. |
|
957 |
^ self. |
|
958 |
] do:[ |
|
959 |
aStream := newFile newReadWriteStream. |
|
960 |
]. |
|
961 |
aStream close. |
|
962 |
self createdFile:newFile. |
|
963 |
LastCreatedFile := newFile. |
|
964 |
self result:true. |
|
3877 | 965 |
! |
966 |
||
967 |
createLinkIn:aFile soft:symbolic |
|
4788 | 968 |
"ask for the link target; |
969 |
then, create an new soft or hard link in aFile's directory" |
|
3877 | 970 |
|
4788 | 971 |
|resources newPath oldPath box string if1 if2| |
4584 | 972 |
|
973 |
resources := AbstractFileBrowser classResources. |
|
3877 | 974 |
|
10383 | 975 |
newPath := (aFile isDirectory ifTrue:[ aFile ] ifFalse:[ aFile directory ]) asValue. |
976 |
oldPath := aFile asValue. |
|
3877 | 977 |
|
978 |
box := Dialog new. |
|
4585 | 979 |
box label:'Create Link'. |
980 |
||
981 |
string := 'Create ', (symbolic ifTrue:['Symbolic'] ifFalse:['Hard']) ,' Link from:'. |
|
13738 | 982 |
box addTextLabel:(resources string:string) adjust:#left. |
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
983 |
if1 := box addFilenameInputFieldOn:oldPath in:nil tabable:true. |
13738 | 984 |
box addTextLabel:(resources string:'to:') adjust:#left. |
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
985 |
if2 := box addFilenameInputFieldOn:newPath in:nil value tabable:true. |
3877 | 986 |
|
987 |
box addAbortAndOkButtons. |
|
988 |
||
6250
5b0673ccff1c
refactored intention revealing code:
Claus Gittinger <cg@exept.de>
parents:
6185
diff
changeset
|
989 |
aFile isDirectory ifFalse:[ |
10383 | 990 |
box focusOnField:if1. |
3877 | 991 |
]. |
992 |
box showAtPointer. |
|
993 |
||
4788 | 994 |
box accepted ifFalse:[ |
10383 | 995 |
self result:false. |
4788 | 996 |
] ifTrue:[ |
10383 | 997 |
self doCreateLinkFrom:(oldPath value) to:(newPath value) soft:symbolic. |
3877 | 998 |
]. |
10383 | 999 |
|
1000 |
"Modified: / 24-07-2011 / 08:24:14 / cg" |
|
3877 | 1001 |
! |
1002 |
||
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1003 |
doCreateLinkFrom:oldPath to:newPathArg soft:symbolic |
4788 | 1004 |
"actually create a soft or hard link" |
1005 |
||
17121 | 1006 |
|resources newPath newPathFile oldPathFile| |
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1007 |
|
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1008 |
newPath := newPathArg. |
4788 | 1009 |
|
1010 |
resources := AbstractFileBrowser classResources. |
|
1011 |
||
17121 | 1012 |
oldPath isNil ifTrue:[ |
17117 | 1013 |
self operationError:'Missing source'. |
1014 |
^ self. |
|
4788 | 1015 |
]. |
17121 | 1016 |
newPath isNil ifTrue:[ |
17117 | 1017 |
self operationError:'Missing link name (target)'. |
1018 |
^ self. |
|
4788 | 1019 |
]. |
1020 |
||
1021 |
newPathFile := newPath asFilename. |
|
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1022 |
oldPathFile := oldPath asFilename. |
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1023 |
|
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1024 |
newPathFile exists ifTrue:[ |
17117 | 1025 |
newPathFile isDirectory ifTrue:[ |
1026 |
newPathFile := newPathFile construct:(oldPathFile baseName). |
|
1027 |
newPath := newPathFile name. |
|
1028 |
]. |
|
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1029 |
]. |
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1030 |
|
4788 | 1031 |
newPathFile exists ifTrue:[ |
17117 | 1032 |
self operationError:(resources string:'%1 already exists' with:newPath allBold). |
1033 |
^ self. |
|
4788 | 1034 |
]. |
6150
5028485a29c6
fixed new-symbolic link operation
Claus Gittinger <cg@exept.de>
parents:
6088
diff
changeset
|
1035 |
oldPathFile exists ifFalse:[ |
17117 | 1036 |
symbolic ifTrue:[ |
1037 |
oldPathFile isAbsolute ifTrue:[ |
|
1038 |
self operationError:(resources string:'%1 does not exist' with:oldPath allBold). |
|
1039 |
^ self. |
|
1040 |
]. |
|
1041 |
(newPathFile directory construct:oldPath) exists ifFalse:[ |
|
1042 |
Dialog warn:(resources string:'%1 does not exist (Warning only)' with:oldPath allBold). |
|
1043 |
]. |
|
1044 |
] ifFalse:[ |
|
1045 |
self operationError:(resources string:'%1 does not exist' with:oldPath allBold). |
|
1046 |
^ self. |
|
1047 |
]. |
|
4788 | 1048 |
]. |
1049 |
((symbolic not) and:[oldPathFile isDirectory]) ifTrue:[ |
|
17117 | 1050 |
self operationError:(resources string:'%1 is a directory' with:oldPath allBold). |
1051 |
^ self. |
|
4788 | 1052 |
]. |
1053 |
ErrorSignal handle:[:ex | |
|
17121 | 1054 |
self operationError:ex description. |
4788 | 1055 |
] do:[ |
17117 | 1056 |
symbolic ifTrue:[ |
1057 |
newPathFile createAsSymbolicLinkTo:oldPathFile. |
|
1058 |
] ifFalse:[ |
|
1059 |
newPathFile createAsHardLinkTo:oldPathFile. |
|
1060 |
]. |
|
1061 |
self createdFile:newPathFile. |
|
1062 |
self result:true. |
|
4788 | 1063 |
]. |
3842 | 1064 |
! ! |
1065 |
||
1066 |
!FileOperation::Delete class methodsFor:'actions'! |
|
1067 |
||
1068 |
deleteFile:aFileOrDirectory |
|
6168 | 1069 |
"delete aFileOrDirectory" |
3842 | 1070 |
|
1071 |
|instance| |
|
1072 |
||
1073 |
instance := self new. |
|
1074 |
instance deleteFile:aFileOrDirectory. |
|
1075 |
^ instance |
|
1076 |
! |
|
1077 |
||
6168 | 1078 |
deleteFiles:aCollectionOfFiles |
1079 |
^ self deleteFiles:aCollectionOfFiles confirm:true |
|
5081 | 1080 |
! |
1081 |
||
6168 | 1082 |
deleteFiles:aCollectionOfFiles confirm:confirm |
1083 |
"delete aCollectionOfFiles" |
|
3842 | 1084 |
|
1085 |
|instance| |
|
1086 |
||
1087 |
instance := self new. |
|
6168 | 1088 |
instance deleteFiles:aCollectionOfFiles confirm:confirm. |
3842 | 1089 |
^ instance |
1090 |
! ! |
|
1091 |
||
1092 |
!FileOperation::Delete methodsFor:'actions'! |
|
1093 |
||
6373 | 1094 |
deleteFiles:colOfFiles |
1095 |
^ self deleteFiles:colOfFiles confirm:true. |
|
1096 |
! |
|
1097 |
||
1098 |
eraseFilesContentsBeforeRemoving:file |
|
1099 |
"intentionally left blank" |
|
1100 |
! ! |
|
1101 |
||
1102 |
!FileOperation::Delete methodsFor:'actions-basic'! |
|
1103 |
||
3842 | 1104 |
deleteFile:aFileOrDirectory |
1105 |
| file isDirectory | |
|
1106 |
||
1107 |
aFileOrDirectory notNil ifTrue:[ |
|
7637 | 1108 |
file := aFileOrDirectory asFilename. |
3842 | 1109 |
|
7637 | 1110 |
isDirectory := file isDirectory. |
3842 | 1111 |
|
7637 | 1112 |
Error handle:[:ex| |
1113 |
"was not able to remove it" |
|
1114 |
Dialog warn:(ex description). |
|
1115 |
self errorString:(ex description). |
|
1116 |
result := false. |
|
1117 |
^ self. |
|
1118 |
] do:[ |
|
1119 |
isDirectory ifTrue:[ |
|
1120 |
file recursiveRemove |
|
1121 |
] ifFalse:[ |
|
1122 |
self eraseFilesContentsBeforeRemoving:file. |
|
1123 |
file remove |
|
1124 |
]. |
|
1125 |
]. |
|
1126 |
"/ flush parent directory or directory |
|
3842 | 1127 |
]. |
4006
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
1128 |
DirectoryContents flushCachedDirectoryFor:(file directory). |
3842 | 1129 |
result := true. |
5746
a505fc181e11
warning string (backslash in pc-filename)
Claus Gittinger <cg@exept.de>
parents:
5687
diff
changeset
|
1130 |
|
a505fc181e11
warning string (backslash in pc-filename)
Claus Gittinger <cg@exept.de>
parents:
5687
diff
changeset
|
1131 |
"Modified: / 17-03-2004 / 12:42:02 / cg" |
3842 | 1132 |
! |
1133 |
||
5081 | 1134 |
deleteFiles:colOfFiles confirm:confirm |
14280 | 1135 |
|resources answer nFilesToDelete ask labels values fileTypeString |
1136 |
msg lbls vals dontAskForNonEmptyDirectory nFilesDone| |
|
5081 | 1137 |
|
7051 | 1138 |
dontAskForNonEmptyDirectory := false. |
5081 | 1139 |
ask := confirm. |
4584 | 1140 |
resources := AbstractFileBrowser classResources. |
3842 | 1141 |
|
4701 | 1142 |
nFilesToDelete := colOfFiles size. |
9576 | 1143 |
nFilesDone := 0. |
4408
8c0c80b68ae7
ask again, if dir is not empty
Claus Gittinger <cg@exept.de>
parents:
4395
diff
changeset
|
1144 |
colOfFiles do:[:filenameOrString | |
9576 | 1145 |
|filename doDelete skip| |
4665
cd7e02bf5d85
fixed to allow deleting bad symbolic links
Claus Gittinger <cg@exept.de>
parents:
4664
diff
changeset
|
1146 |
|
9576 | 1147 |
filename := filenameOrString asFilename. |
1148 |
skip := false. |
|
1149 |
fileTypeString := ''. |
|
1150 |
filename isSymbolicLink ifTrue:[ |
|
1151 |
fileTypeString := 'symbolic link '. |
|
1152 |
] ifFalse:[ |
|
1153 |
filename exists ifFalse:[ |
|
1154 |
(Dialog |
|
1155 |
confirm:('%1 does not exist.' bindWith:filename asString allBold) |
|
1156 |
yesLabel:(resources string:'Proceed') |
|
1157 |
noLabel:(resources string:'Cancel')) |
|
1158 |
ifFalse:[ |
|
1159 |
^ self. |
|
1160 |
]. |
|
1161 |
skip := true. |
|
1162 |
] |
|
1163 |
]. |
|
1164 |
skip ifFalse:[ |
|
1165 |
ask ifTrue:[ |
|
1166 |
nFilesToDelete = 1 ifTrue:[ |
|
1167 |
labels := #('No' 'Yes'). |
|
1168 |
values := #(#no #yes). |
|
1169 |
] ifFalse:[ |
|
1170 |
labels := #('Cancel' 'No' 'Yes' 'Yes to All' ). |
|
1171 |
values := #(#cancel #no #yes #yesToAll). |
|
1172 |
]. |
|
14280 | 1173 |
(Filename trashDirectoryOrNil notNil) ifTrue:[ |
1174 |
filename directory pathName ~= Filename trashDirectoryOrNil pathName ifTrue:[ |
|
1175 |
nFilesToDelete = 1 ifTrue:[ |
|
1176 |
labels := labels , #('Move to Trash'). |
|
1177 |
] ifFalse:[ |
|
1178 |
labels := labels , #('Move all to Trash'). |
|
1179 |
]. |
|
1180 |
values := values , #(#moveToTrash). |
|
1181 |
]. |
|
1182 |
]. |
|
9576 | 1183 |
msg := self isErase ifTrue:'Really erase' ifFalse:'Really delete'. |
1184 |
msg := msg , |
|
1185 |
(nFilesToDelete = 1 |
|
1186 |
ifTrue:'\\%1%2 ?' |
|
1187 |
ifFalse:'\\%1%2 \\(%3 files alltogether)'). |
|
1188 |
answer := Dialog |
|
1189 |
confirmWithCancel:(resources |
|
1190 |
stringWithCRs:msg |
|
1191 |
with:fileTypeString |
|
1192 |
with:(filename asString allBold) |
|
1193 |
with:nFilesToDelete) |
|
1194 |
labels:(resources array:labels) |
|
1195 |
values:values |
|
1196 |
default:(values indexOf:#yes). |
|
1197 |
] ifFalse:[ |
|
1198 |
answer := #yesToAll. |
|
1199 |
]. |
|
5673 | 1200 |
|
9576 | 1201 |
answer == #cancel ifTrue:[ |
1202 |
^ self. |
|
1203 |
]. |
|
5673 | 1204 |
|
9576 | 1205 |
answer == #yesToAll ifTrue:[ |
1206 |
ask := false. |
|
1207 |
answer := #yes. |
|
1208 |
]. |
|
14280 | 1209 |
answer == #moveToTrash ifTrue:[ |
1210 |
|trashFn nr| |
|
4408
8c0c80b68ae7
ask again, if dir is not empty
Claus Gittinger <cg@exept.de>
parents:
4395
diff
changeset
|
1211 |
|
14280 | 1212 |
ask := false. |
1213 |
ProgressNotification progressPercentage:(nFilesDone / nFilesToDelete)*100. |
|
1214 |
trashFn := Filename trashDirectoryOrNil construct:filename baseName. |
|
1215 |
[trashFn exists] whileTrue:[ |
|
1216 |
nr := (nr ? 0) + 1. |
|
1217 |
trashFn := Filename trashDirectoryOrNil construct:filename baseName,'.',nr printString. |
|
1218 |
]. |
|
1219 |
filename moveTo:trashFn. |
|
1220 |
nFilesDone := nFilesDone + 1. |
|
1221 |
] ifFalse:[ |
|
1222 |
answer == #yes ifTrue:[ |
|
1223 |
doDelete := true. |
|
1224 |
filename isSymbolicLink ifFalse:[ |
|
1225 |
dontAskForNonEmptyDirectory ifFalse:[ |
|
1226 |
filename isNonEmptyDirectory ifTrue:[ |
|
1227 |
colOfFiles size == 1 ifTrue:[ |
|
1228 |
lbls := #('Cancel' 'Remove'). |
|
1229 |
vals := #(false true). |
|
1230 |
] ifFalse:[ |
|
1231 |
lbls := #('Cancel All' 'Keep' 'Remove' 'Remove All'). |
|
1232 |
vals := #(nil false true #removeAll). |
|
1233 |
]. |
|
1234 |
doDelete := Dialog |
|
1235 |
confirmWithCancel:(resources |
|
1236 |
stringWithCRs:'Directory ''%1'' is not empty\remove anyway ?' |
|
1237 |
with:filename pathName allBold) |
|
1238 |
labels:( resources array:lbls ) |
|
1239 |
values:vals |
|
1240 |
default:(vals indexOf:true). |
|
1241 |
doDelete == nil ifTrue:[ |
|
1242 |
^ self |
|
1243 |
]. |
|
1244 |
doDelete == #removeAll ifTrue:[ |
|
1245 |
dontAskForNonEmptyDirectory := true. |
|
1246 |
doDelete := true. |
|
1247 |
]. |
|
9576 | 1248 |
]. |
1249 |
]. |
|
1250 |
]. |
|
14280 | 1251 |
doDelete ifTrue:[ |
1252 |
ProgressNotification progressPercentage:(nFilesDone / nFilesToDelete)*100. |
|
1253 |
self deleteFile:filename. |
|
1254 |
nFilesDone := nFilesDone + 1. |
|
1255 |
] |
|
9576 | 1256 |
]. |
1257 |
]. |
|
14280 | 1258 |
ProgressNotification progressPercentage:(nFilesDone / nFilesToDelete)*100. |
9576 | 1259 |
]. |
3842 | 1260 |
]. |
7051 | 1261 |
|
9576 | 1262 |
"Modified: / 11-10-2010 / 13:08:20 / cg" |
6168 | 1263 |
! ! |
1264 |
||
6373 | 1265 |
!FileOperation::Erase methodsFor:'actions-basic'! |
6168 | 1266 |
|
1267 |
eraseFilesContentsBeforeRemoving:file |
|
7634 | 1268 |
"fill file with zeros (to be really erased from the disk). |
1269 |
We use this, if the file contains security relevant data (such as crypto-keys)" |
|
6168 | 1270 |
|
1271 |
|writeStream fileSize remaining buffer bufferSize nWritten| |
|
1272 |
||
1273 |
fileSize := file fileSize. |
|
1274 |
writeStream := file asFilename readWriteStream. |
|
8293 | 1275 |
[ |
1276 |
remaining := fileSize. |
|
1277 |
bufferSize := 8192. |
|
1278 |
buffer := ByteArray new:bufferSize. |
|
6168 | 1279 |
|
8293 | 1280 |
[remaining > 0] whileTrue:[ |
1281 |
nWritten := writeStream |
|
1282 |
nextPutBytes:(bufferSize min:remaining) |
|
1283 |
from:buffer. |
|
1284 |
remaining := remaining - nWritten. |
|
1285 |
ProgressNotification progressPercentage:(1 - (remaining / fileSize))*100. |
|
1286 |
]. |
|
1287 |
] ensure:[ |
|
1288 |
writeStream close. |
|
6168 | 1289 |
]. |
7634 | 1290 |
|
1291 |
"Modified: / 07-02-2007 / 18:20:21 / cg" |
|
3842 | 1292 |
! ! |
1293 |
||
6285 | 1294 |
!FileOperation::Erase methodsFor:'queries'! |
1295 |
||
1296 |
isErase |
|
1297 |
^ true |
|
1298 |
! ! |
|
1299 |
||
3842 | 1300 |
!FileOperation::Move class methodsFor:'actions'! |
1301 |
||
1302 |
moveFile:aSourceFile to:aDestFile |
|
1303 |
|instance| |
|
1304 |
||
1305 |
instance := self new. |
|
1306 |
instance moveFile:aSourceFile to:aDestFile. |
|
1307 |
^ instance |
|
1308 |
! |
|
1309 |
||
1310 |
moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning |
|
1311 |
|instance| |
|
1312 |
||
1313 |
instance := self new. |
|
1314 |
instance moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning. |
|
1315 |
^ instance |
|
1316 |
! |
|
1317 |
||
1318 |
moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning moveFileIfSame:move |
|
1319 |
|instance| |
|
1320 |
||
1321 |
instance := self new. |
|
1322 |
instance moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning moveFileIfSame:move. |
|
1323 |
^ instance |
|
1324 |
! |
|
1325 |
||
1326 |
moveFiles:aColOfSourceFiles to:aDirectory |
|
1327 |
|instance| |
|
1328 |
||
1329 |
instance := self new. |
|
1330 |
instance moveFiles:aColOfSourceFiles to:aDirectory. |
|
1331 |
^ instance |
|
1332 |
! |
|
1333 |
||
1334 |
moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning |
|
1335 |
|instance| |
|
1336 |
||
1337 |
instance := self new. |
|
1338 |
instance moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning. |
|
1339 |
^ instance |
|
1340 |
! |
|
1341 |
||
1342 |
moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning moveFileIfSame:move |
|
1343 |
|instance| |
|
1344 |
||
1345 |
instance := self new. |
|
1346 |
instance moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning moveFileIfSame:move. |
|
1347 |
^ instance |
|
1348 |
! ! |
|
1349 |
||
1350 |
!FileOperation::Move methodsFor:'accessing'! |
|
1351 |
||
1352 |
colOfMovedFiles |
|
6373 | 1353 |
"obsolete - bad name" |
1354 |
||
1355 |
^ self collectionOfMovedFiles |
|
1356 |
! |
|
1357 |
||
1358 |
collectionOfMovedFiles |
|
6374 | 1359 |
movedFiles isNil ifTrue:[ |
7637 | 1360 |
movedFiles := OrderedCollection new. |
3842 | 1361 |
]. |
6374 | 1362 |
^ movedFiles |
3842 | 1363 |
! ! |
1364 |
||
1365 |
!FileOperation::Move methodsFor:'actions'! |
|
1366 |
||
1367 |
moveFile:aSourceFile to:aDestFile |
|
1368 |
||
1369 |
^ self moveFile:aSourceFile to:aDestFile withOverWriteWarning:true. |
|
1370 |
! |
|
1371 |
||
1372 |
moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning |
|
1373 |
||
1374 |
^ self moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning moveFileIfSame:true |
|
1375 |
! |
|
1376 |
||
6373 | 1377 |
moveFiles:aColOfSourceFiles to:aDirectory |
1378 |
||
1379 |
^ self moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:true |
|
1380 |
! |
|
1381 |
||
1382 |
moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning |
|
1383 |
||
1384 |
^ self moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning moveFileIfSame:true |
|
1385 |
! ! |
|
1386 |
||
1387 |
!FileOperation::Move methodsFor:'actions-basic'! |
|
1388 |
||
3842 | 1389 |
moveFile:aSourceFile to:aDestFile withOverWriteWarning:overWriteWarning moveFileIfSame:move |
1390 |
||
5862 | 1391 |
|newFile fileString targetDirectory targetIsDirectory suffix doMove| |
3842 | 1392 |
|
1393 |
targetIsDirectory := aDestFile isDirectory. |
|
1394 |
targetIsDirectory ifTrue:[ |
|
8361 | 1395 |
targetDirectory := aDestFile. |
1396 |
newFile := aDestFile construct:(aSourceFile baseName). |
|
3842 | 1397 |
] ifFalse:[ |
8361 | 1398 |
targetDirectory := aDestFile directory. |
1399 |
newFile := aDestFile. |
|
3842 | 1400 |
]. |
1401 |
"/ do not copy if destination directory doest exist. |
|
6250
5b0673ccff1c
refactored intention revealing code:
Claus Gittinger <cg@exept.de>
parents:
6185
diff
changeset
|
1402 |
targetDirectory exists ifFalse:[ |
8361 | 1403 |
Dialog warn:'Cannot move to non-existing directory ', targetDirectory asString. |
1404 |
result := false. |
|
1405 |
^ self |
|
3842 | 1406 |
]. |
1407 |
(newFile exists) ifTrue:[ |
|
8361 | 1408 |
((newFile asString = aSourceFile asString) and:[move]) ifTrue:[ |
1409 |
[newFile exists] whileTrue:[ |
|
1410 |
suffix := newFile suffix. |
|
1411 |
fileString := newFile baseName withoutSuffix, self class suffixForCopyOverExistingFile, '.', suffix. |
|
1412 |
newFile := targetDirectory construct:fileString. |
|
1413 |
]. |
|
1414 |
] ifFalse:[ |
|
1415 |
overWriteWarning ifTrue:[ |
|
1416 |
doMove := self fileExistsDialogForNewFile:newFile oldFile:aSourceFile withCancel:false withRemoveIfSame:true. |
|
1417 |
doMove == #removeSource ifTrue:[ |
|
8397
921162bfd791
Change #halt: to #shouldImplement or #assert:
Stefan Vogel <sv@exept.de>
parents:
8361
diff
changeset
|
1418 |
self shouldImplement. |
8361 | 1419 |
result := false. |
1420 |
^ self. |
|
1421 |
]. |
|
1422 |
doMove == #removeDestination ifTrue:[ |
|
8397
921162bfd791
Change #halt: to #shouldImplement or #assert:
Stefan Vogel <sv@exept.de>
parents:
8361
diff
changeset
|
1423 |
self shouldImplement. |
8361 | 1424 |
result := false. |
1425 |
^ self. |
|
1426 |
]. |
|
1427 |
doMove == true ifFalse:[ |
|
1428 |
result := false. |
|
1429 |
^ self. |
|
1430 |
]. |
|
5862 | 1431 |
|
8361 | 1432 |
] ifFalse:[ |
1433 |
result := false. |
|
1434 |
^ self. |
|
1435 |
] |
|
1436 |
]. |
|
3842 | 1437 |
]. |
1438 |
Error handle:[:ex| |
|
8361 | 1439 |
"was not able to copy it" |
13703 | 1440 |
WarningBox warn:'Error in move file operation: ', ex description. |
1441 |
self errorString:('Error in move file operation- ', ex description asString). |
|
8361 | 1442 |
result := false. |
1443 |
^ self |
|
3842 | 1444 |
] do:[ |
8361 | 1445 |
aSourceFile moveTo:newFile. |
3842 | 1446 |
]. |
4006
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
1447 |
DirectoryContents flushCachedDirectoryFor:(aSourceFile directory). |
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
1448 |
result := true. |
3842 | 1449 |
! |
1450 |
||
1451 |
moveFiles:aColOfSourceFiles to:aDirectory withOverWriteWarning:overWriteWarning moveFileIfSame:move |
|
1452 |
||
5862 | 1453 |
|newFile suffix fileString doMove doRemoveSource doRemoveDestination| |
3842 | 1454 |
|
5854
8c6042ba7495
ask if non-existing directory should be created
Claus Gittinger <cg@exept.de>
parents:
5846
diff
changeset
|
1455 |
aDirectory exists ifFalse:[ |
14187
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1456 |
(Dialog confirm:(AbstractFileBrowser classResources |
11444 | 1457 |
stringWithCRs:'Non-existing directory "%1" .\Create ?' |
1458 |
with:aDirectory asString allBold)) ifFalse:[ |
|
1459 |
result := false. |
|
1460 |
^ self |
|
1461 |
]. |
|
1462 |
aDirectory makeDirectory. |
|
1463 |
aDirectory exists ifFalse:[ |
|
14187
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1464 |
Dialog warn:(AbstractFileBrowser classResources |
11444 | 1465 |
stringWithCRs:'Cannot create directory "%1" !!\Create ?.' |
1466 |
with:aDirectory asString allBold). |
|
1467 |
result := false. |
|
1468 |
^ self |
|
1469 |
] |
|
3842 | 1470 |
]. |
5788 | 1471 |
(aDirectory isDirectory) ifFalse:[ |
11444 | 1472 |
Dialog warn:('Destination %1 is not a directory.' bindWith:aDirectory asString allBold). |
1473 |
result := false. |
|
1474 |
^ self |
|
3842 | 1475 |
]. |
1476 |
aColOfSourceFiles do:[: filename | |
|
11444 | 1477 |
newFile := aDirectory construct:filename baseName. |
5790 | 1478 |
|
11444 | 1479 |
doMove := true. |
1480 |
doRemoveSource := false. |
|
1481 |
doRemoveDestination := false. |
|
5862 | 1482 |
|
11444 | 1483 |
(newFile exists) ifTrue:[ |
1484 |
((newFile asString = filename asString) and:[move]) ifTrue:[ |
|
1485 |
[newFile exists] whileTrue:[ |
|
1486 |
suffix := newFile suffix. |
|
1487 |
fileString := newFile withoutSuffix baseName , self class suffixForCopyOverExistingFile, '.', suffix. |
|
1488 |
newFile := aDirectory construct:fileString. |
|
1489 |
]. |
|
1490 |
] ifFalse:[ |
|
1491 |
overWriteWarning ifTrue:[ |
|
1492 |
(doMove := actionForAll) isNil ifTrue:[ |
|
1493 |
doMove := self |
|
1494 |
fileExistsDialogForNewFile:newFile oldFile:filename |
|
1495 |
withCancel:(aColOfSourceFiles size > 1) withRemoveIfSame:true |
|
1496 |
withAllAction: true. |
|
1497 |
doMove isNil ifTrue:[ "/ cancel |
|
1498 |
result := false. |
|
1499 |
^ self. |
|
1500 |
]. |
|
1501 |
]. |
|
1502 |
(doMove == #removeSource) ifTrue:[ |
|
1503 |
doRemoveSource := true. |
|
1504 |
doMove := false |
|
1505 |
] ifFalse:[ |
|
1506 |
(doMove == #removeDestination) ifTrue:[ |
|
1507 |
doRemoveDestination := true. |
|
1508 |
doMove := false |
|
1509 |
] |
|
1510 |
] |
|
1511 |
] |
|
1512 |
]. |
|
1513 |
]. |
|
4522 | 1514 |
|
11444 | 1515 |
(doMove or:[doRemoveSource or:[doRemoveDestination]]) ifTrue:[ |
1516 |
Error handle:[:ex| |
|
1517 |
"was not able to copy it" |
|
1518 |
|descriptionString| |
|
5862 | 1519 |
|
11444 | 1520 |
result := false. |
1521 |
descriptionString := ex description asString. |
|
1522 |
self errorString:(' Error in Move-File Operation:', descriptionString). |
|
1523 |
( Dialog |
|
1524 |
confirm:(' Error in Move-File Operation: ', descriptionString) |
|
1525 |
title:'Move' |
|
1526 |
yesLabel:'Continue' |
|
1527 |
noLabel:'Abort' |
|
1528 |
) ifFalse:[ |
|
1529 |
^ self. |
|
1530 |
]. |
|
1531 |
] do:[ |
|
1532 |
doRemoveSource ifTrue:[ |
|
1533 |
filename remove |
|
1534 |
] ifFalse:[ |
|
1535 |
doRemoveDestination ifTrue:[ |
|
1536 |
newFile remove |
|
1537 |
] ifFalse:[ |
|
1538 |
filename moveTo:newFile. |
|
1539 |
] |
|
1540 |
] |
|
1541 |
]. |
|
1542 |
self collectionOfMovedFiles add:filename |
|
1543 |
] |
|
3842 | 1544 |
]. |
4006
8c706ba8b3b5
change flushCachedDirectory: senders to flushCachedDirectoryFor:
penk
parents:
3977
diff
changeset
|
1545 |
DirectoryContents flushCachedDirectoryFor:aDirectory. |
3842 | 1546 |
result := true. |
11444 | 1547 |
|
1548 |
"Modified: / 20-03-2012 / 11:53:35 / cg" |
|
3842 | 1549 |
! ! |
1550 |
||
1551 |
!FileOperation::Rename class methodsFor:'actions'! |
|
1552 |
||
1553 |
renameFile:oldFile to:newName |
|
1554 |
|instance| |
|
1555 |
||
1556 |
instance := self new. |
|
1557 |
instance renameFile:oldFile to:newName. |
|
1558 |
^ instance |
|
1559 |
! |
|
1560 |
||
7637 | 1561 |
renameFiles:aColOfFiles |
3842 | 1562 |
|instance| |
1563 |
||
1564 |
instance := self new. |
|
1565 |
instance renameFiles:aColOfFiles. |
|
1566 |
^ instance |
|
1567 |
! ! |
|
1568 |
||
1569 |
!FileOperation::Rename methodsFor:'accessing'! |
|
1570 |
||
1571 |
renamedFiles |
|
1572 |
renamedFiles isNil ifTrue:[ |
|
7637 | 1573 |
renamedFiles := OrderedCollection new. |
3842 | 1574 |
]. |
1575 |
^ renamedFiles |
|
1576 |
! ! |
|
1577 |
||
6373 | 1578 |
!FileOperation::Rename methodsFor:'actions-basic'! |
3842 | 1579 |
|
1580 |
renameFile:oldFile to:newName |
|
1581 |
"rename a file (or directory)" |
|
1582 |
||
7334
e0bd092badd1
care for same-name rename on OS which is not filename-case-sensitive
Claus Gittinger <cg@exept.de>
parents:
7084
diff
changeset
|
1583 |
|newFile msg resources sameFile| |
3842 | 1584 |
|
1585 |
(oldFile isNil or:[newName isNil]) ifTrue:[ |
|
12726 | 1586 |
result := false. |
1587 |
^ self. |
|
3842 | 1588 |
]. |
1589 |
(oldFile asString isBlank or:[newName isBlank]) ifTrue:[ |
|
12726 | 1590 |
result := false. |
1591 |
^ self. |
|
3842 | 1592 |
]. |
5656 | 1593 |
newName asFilename isAbsolute ifTrue:[ |
12726 | 1594 |
newFile := newName asFilename. |
5656 | 1595 |
] ifFalse:[ |
12726 | 1596 |
(oldFile baseName = newName) ifTrue:[ |
1597 |
result := false |
|
1598 |
]. |
|
1599 |
newFile := oldFile directory construct:newName. |
|
3842 | 1600 |
]. |
1601 |
||
5656 | 1602 |
oldFile pathName = newFile pathName ifTrue:[ |
12726 | 1603 |
^ self. |
4674
64a49fadc47e
do op if newName is same as old in a rename operation
Claus Gittinger <cg@exept.de>
parents:
4665
diff
changeset
|
1604 |
]. |
7334
e0bd092badd1
care for same-name rename on OS which is not filename-case-sensitive
Claus Gittinger <cg@exept.de>
parents:
7084
diff
changeset
|
1605 |
Filename isCaseSensitive ifFalse:[ |
12726 | 1606 |
sameFile := (oldFile pathName sameAs: newFile pathName) |
7334
e0bd092badd1
care for same-name rename on OS which is not filename-case-sensitive
Claus Gittinger <cg@exept.de>
parents:
7084
diff
changeset
|
1607 |
] ifTrue:[ |
12726 | 1608 |
sameFile := false |
7334
e0bd092badd1
care for same-name rename on OS which is not filename-case-sensitive
Claus Gittinger <cg@exept.de>
parents:
7084
diff
changeset
|
1609 |
]. |
4674
64a49fadc47e
do op if newName is same as old in a rename operation
Claus Gittinger <cg@exept.de>
parents:
4665
diff
changeset
|
1610 |
|
5656 | 1611 |
resources := Dialog classResources. |
1612 |
||
12726 | 1613 |
OsError handle:[:ex| |
1614 |
msg := resources |
|
1615 |
stringWithCRs:'Cannot rename file %1 to %2 !!\\(%3)' |
|
1616 |
with:oldFile baseName |
|
1617 |
with:newName |
|
17111 | 1618 |
with:ex errorString. |
12726 | 1619 |
Dialog warn:msg. |
1620 |
result := false. |
|
1621 |
^ self. |
|
3842 | 1622 |
] do:[ |
12726 | 1623 |
sameFile ifFalse:[ |
1624 |
newFile exists ifTrue:[ |
|
1625 |
(newFile sameContentsAs:oldFile) ifTrue:[ |
|
1626 |
msg := '%1 exists [with same contents] - rename (i.e. overwrite) anyway ?' |
|
1627 |
] ifFalse:[ |
|
1628 |
msg := '%1 exists - rename (i.e. overwrite) anyway ?' |
|
1629 |
]. |
|
1630 |
(Dialog confirmWithCancel:(resources string:msg with:newName allBold) default:false) ifFalse:[ |
|
1631 |
result := false. |
|
1632 |
^ self. |
|
1633 |
] |
|
1634 |
]. |
|
1635 |
]. |
|
1636 |
oldFile renameTo:newFile. |
|
1637 |
self renamedFiles add:newFile. |
|
3842 | 1638 |
]. |
1639 |
result := true. |
|
7334
e0bd092badd1
care for same-name rename on OS which is not filename-case-sensitive
Claus Gittinger <cg@exept.de>
parents:
7084
diff
changeset
|
1640 |
|
e0bd092badd1
care for same-name rename on OS which is not filename-case-sensitive
Claus Gittinger <cg@exept.de>
parents:
7084
diff
changeset
|
1641 |
"Modified: / 21-09-2006 / 18:32:12 / cg" |
3842 | 1642 |
! |
1643 |
||
7637 | 1644 |
renameFiles:aColOfFiles |
5827 | 1645 |
|resources queryBox b lastNewName lastOldName initialText oldName newName renameAll doRename| |
4584 | 1646 |
|
1647 |
resources := AbstractFileBrowser classResources. |
|
5827 | 1648 |
renameAll := false. |
3842 | 1649 |
|
1650 |
queryBox := FilenameEnterBox new. |
|
4584 | 1651 |
queryBox okText:(resources string:'Rename'). |
5827 | 1652 |
|
3842 | 1653 |
aColOfFiles size > 1 ifTrue:[ |
14187
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1654 |
b := queryBox addAbortButtonLabelled:(resources string:'Cancel All'). |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1655 |
b action:[^ self]. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1656 |
queryBox addButton:(Button label:(resources string:'Rename All') action:[renameAll := true. queryBox okPressed]) before:(queryBox okButton). |
3842 | 1657 |
]. |
5827 | 1658 |
aColOfFiles do:[:oldFile | |
14187
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1659 |
oldName := oldFile baseName asString. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1660 |
lastNewName notNil ifTrue:[ |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1661 |
initialText := DoWhatIMeanSupport goodRenameDefaultForFile:oldName lastOld:lastOldName lastNew:lastNewName. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1662 |
]. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1663 |
doRename := false. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1664 |
(renameAll and:[initialText notNil]) ifTrue:[ |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1665 |
doRename := true. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1666 |
newName := initialText. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1667 |
] ifFalse:[ |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1668 |
queryBox title:(resources string:'Rename %1 to:' with:(oldName allBold)). |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1669 |
queryBox initialText:(initialText ? oldName). |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1670 |
queryBox action:[:newEnteredName | newName := newEnteredName. doRename := true.]. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1671 |
queryBox show "showAtPointer". |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1672 |
"/ queryBox accepted ifFalse:[self halt]. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1673 |
]. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1674 |
doRename ifTrue:[ |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1675 |
(self renameFile:oldFile to:newName asString) ifTrue:[ |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1676 |
result := true |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1677 |
]. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1678 |
lastOldName := oldName. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1679 |
lastNewName := newName. |
fe7fa2d23b0b
Do not refer to FileBrowser methods
Stefan Vogel <sv@exept.de>
parents:
13738
diff
changeset
|
1680 |
]. |
3842 | 1681 |
] |
1682 |
! ! |
|
1683 |
||
3841 | 1684 |
!FileOperation class methodsFor:'documentation'! |
1685 |
||
1686 |
version |
|
15948 | 1687 |
^ '$Header$' |
9501 | 1688 |
! |
1689 |
||
1690 |
version_CVS |
|
15948 | 1691 |
^ '$Header$' |
3841 | 1692 |
! ! |
12726 | 1693 |