diff options
author | Jacek Antonelli | 2008-08-15 23:44:46 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:44:46 -0500 |
commit | 38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4 (patch) | |
tree | adca584755d22ca041a2dbfc35d4eca01f70b32c /linden/indra/mac_updater/FSCopyObject.h | |
parent | README.txt (diff) | |
download | meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.zip meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.gz meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.bz2 meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.xz |
Second Life viewer sources 1.13.2.12
Diffstat (limited to 'linden/indra/mac_updater/FSCopyObject.h')
-rw-r--r-- | linden/indra/mac_updater/FSCopyObject.h | 285 |
1 files changed, 285 insertions, 0 deletions
diff --git a/linden/indra/mac_updater/FSCopyObject.h b/linden/indra/mac_updater/FSCopyObject.h new file mode 100644 index 0000000..6cbbf94 --- /dev/null +++ b/linden/indra/mac_updater/FSCopyObject.h | |||
@@ -0,0 +1,285 @@ | |||
1 | /** | ||
2 | * @file FSCopyObject.h | ||
3 | * @brief Mac OSX updater program | ||
4 | * | ||
5 | * Copyright (c) 2004-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | /* | ||
29 | File: FSCopyObject.h | ||
30 | |||
31 | Contains: A Copy/Delete Files/Folders engine which uses the HFS+ API's | ||
32 | |||
33 | Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple Computer, Inc. | ||
34 | ("Apple") in consideration of your agreement to the following terms, and your | ||
35 | use, installation, modification or redistribution of this Apple software | ||
36 | constitutes acceptance of these terms. If you do not agree with these terms, | ||
37 | please do not use, install, modify or redistribute this Apple software. | ||
38 | |||
39 | In consideration of your agreement to abide by the following terms, and subject | ||
40 | to these terms, Apple grants you a personal, non-exclusive license, under AppleÕs | ||
41 | copyrights in this original Apple software (the "Apple Software"), to use, | ||
42 | reproduce, modify and redistribute the Apple Software, with or without | ||
43 | modifications, in source and/or binary forms; provided that if you redistribute | ||
44 | the Apple Software in its entirety and without modifications, you must retain | ||
45 | this notice and the following text and disclaimers in all such redistributions of | ||
46 | the Apple Software. Neither the name, trademarks, service marks or logos of | ||
47 | Apple Computer, Inc. may be used to endorse or promote products derived from the | ||
48 | Apple Software without specific prior written permission from Apple. Except as | ||
49 | expressly stated in this notice, no other rights or licenses, express or implied, | ||
50 | are granted by Apple herein, including but not limited to any patent rights that | ||
51 | may be infringed by your derivative works or by other works in which the Apple | ||
52 | Software may be incorporated. | ||
53 | |||
54 | The Apple Software is provided by Apple on an "AS IS" basis. APPLE MAKES NO | ||
55 | WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED | ||
56 | WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS FOR A PARTICULAR | ||
57 | PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE OR IN | ||
58 | COMBINATION WITH YOUR PRODUCTS. | ||
59 | |||
60 | IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR | ||
61 | CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE | ||
62 | GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | ||
63 | ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, MODIFICATION AND/OR DISTRIBUTION | ||
64 | OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER UNDER THEORY OF CONTRACT, TORT | ||
65 | (INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN | ||
66 | ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
67 | |||
68 | Copyright © 2002-2004 Apple Computer, Inc., All Rights Reserved | ||
69 | */ | ||
70 | |||
71 | |||
72 | #ifndef __FSCOPYOBJECT_H__ | ||
73 | #define __FSCOPYOBJECT_H__ | ||
74 | |||
75 | #ifdef __cplusplus | ||
76 | extern "C" { | ||
77 | #endif | ||
78 | |||
79 | #if TARGET_API_MAC_OSX || defined( __APPLE_CC__ ) | ||
80 | #include <CoreServices/CoreServices.h> | ||
81 | #endif | ||
82 | |||
83 | #define DEBUG 1 /* set to zero if you don't want debug spew */ | ||
84 | |||
85 | #if DEBUG | ||
86 | #include <stdio.h> | ||
87 | |||
88 | #define QuoteExceptionString(x) #x | ||
89 | |||
90 | #define dwarning(s) do { printf s; fflush(stderr); } while( 0 ) | ||
91 | |||
92 | #define mycheck_noerr( error ) \ | ||
93 | do { \ | ||
94 | if( (OSErr) error != noErr ) { \ | ||
95 | dwarning((QuoteExceptionString(error) " != noErr in File: %s, Function: %s, Line: %d, Error: %d\n", \ | ||
96 | __FILE__, __FUNCTION__, __LINE__, (OSErr) error)); \ | ||
97 | } \ | ||
98 | } while( false ) | ||
99 | |||
100 | #define mycheck( assertion ) \ | ||
101 | do { \ | ||
102 | if( ! assertion ) { \ | ||
103 | dwarning((QuoteExceptionString(assertion) " failed in File: %s, Function: %s, Line: %d\n", \ | ||
104 | __FILE__, __FUNCTION__, __LINE__)); \ | ||
105 | } \ | ||
106 | } while( false ) | ||
107 | |||
108 | #define myverify(assertion) mycheck(assertion) | ||
109 | #define myverify_noerr(assertion) mycheck_noerr( (assertion) ) | ||
110 | #else | ||
111 | #define dwarning(s) | ||
112 | |||
113 | #define mycheck(assertion) | ||
114 | #define mycheck_noerr(err) | ||
115 | #define myverify(assertion) do { (void) (assertion); } while (0) | ||
116 | #define myverify_noerr(assertion) myverify(assertion) | ||
117 | #endif | ||
118 | |||
119 | /* | ||
120 | This code takes some tricks/techniques from MoreFilesX (by Jim Luther) and | ||
121 | MPFileCopy (by Quinn), wraps them all up into an easy to use API, and adds a bunch of | ||
122 | features and bug fixes. It will run on Mac OS 9.1 through 9.2.x and 10.1.x | ||
123 | and up (Classic, Carbon and Mach-O) | ||
124 | */ | ||
125 | |||
126 | /* Different options that FSCopyObject can take during a copy */ | ||
127 | typedef UInt32 DupeAction; | ||
128 | enum { | ||
129 | kDupeActionStandard, /* will do the copy with no frills */ | ||
130 | kDupeActionReplace, /* will delete the existing object and then copy over the new one */ | ||
131 | kDupeActionRename /* will rename the new object if an object of the same name exists */ | ||
132 | }; | ||
133 | |||
134 | /*****************************************************************************/ | ||
135 | |||
136 | #pragma mark CopyObjectFilterProcPtr | ||
137 | |||
138 | /* | ||
139 | This is the prototype for the CallCopyObjectFilterProc function which | ||
140 | is called once for each file and directory found by FSCopyObject. | ||
141 | The CallCopyObjectFilterProc can use the read-only data it receives for | ||
142 | whatever it wants. | ||
143 | |||
144 | The result of the CallCopyObjectFilterProc function indicates if | ||
145 | the copy should be stopped. To stop the copy, return an error; to continue | ||
146 | the copy, return noErr. | ||
147 | |||
148 | The yourDataPtr parameter can point to whatever data structure you might | ||
149 | want to access from within the CallCopyObjectFilterProc. | ||
150 | |||
151 | Note: If an error had occured during the copy of the current object | ||
152 | (currentOSErr != noErr) the FSRef etc might not be valid | ||
153 | |||
154 | containerChanged --> Set to true if the container's contents changed | ||
155 | during iteration. | ||
156 | currentLevel --> The current recursion level into the container. | ||
157 | 1 = the container, 2 = the container's immediate | ||
158 | subdirectories, etc. | ||
159 | currentOSErr --> The current error code, shows the results of the | ||
160 | copy of the current object (ref) | ||
161 | catalogInfo --> The catalog information for the current object. | ||
162 | Only the fields requested by the whichInfo | ||
163 | parameter passed to FSIterateContainer are valid. | ||
164 | ref --> The FSRef to the current object. | ||
165 | spec --> The FSSpec to the current object if the wantFSSpec | ||
166 | parameter passed to FSCopyObject is true. | ||
167 | name --> The name of the current object if the wantName | ||
168 | parameter passed to FSCopyObject is true. | ||
169 | yourDataPtr --> An optional pointer to whatever data structure you | ||
170 | might want to access from within the | ||
171 | CallCopyObjectFilterProc. | ||
172 | result <-- To continue the copy, return noErr | ||
173 | |||
174 | __________ | ||
175 | |||
176 | Also see: FSCopyObject | ||
177 | */ | ||
178 | |||
179 | typedef CALLBACK_API( OSErr , CopyObjectFilterProcPtr ) ( | ||
180 | Boolean containerChanged, | ||
181 | ItemCount currentLevel, | ||
182 | OSErr currentOSErr, | ||
183 | const FSCatalogInfo *catalogInfo, | ||
184 | const FSRef *ref, | ||
185 | const FSSpec *spec, | ||
186 | const HFSUniStr255 *name, | ||
187 | void *yourDataPtr); | ||
188 | |||
189 | |||
190 | /*****************************************************************************/ | ||
191 | |||
192 | #pragma mark CallCopyObjectFilterProc | ||
193 | |||
194 | #define CallCopyObjectFilterProc(userRoutine, containerChanged, currentLevel, currentOSErr, catalogInfo, ref, spec, name, yourDataPtr) \ | ||
195 | (*(userRoutine))((containerChanged), (currentLevel), (currentOSErr), (catalogInfo), (ref), (spec), (name), (yourDataPtr)) | ||
196 | |||
197 | /*****************************************************************************/ | ||
198 | |||
199 | #pragma mark FSCopyObject | ||
200 | |||
201 | /* | ||
202 | The FSCopyObject function takes a source object (can be a file or directory) | ||
203 | and copies it (and its contents if it's a directory) to the new destination | ||
204 | directory. | ||
205 | |||
206 | It will call your CopyObjectFilterProcPtr once for each object copied | ||
207 | |||
208 | The maxLevels parameter is only used when the object is a directory, | ||
209 | ignored otherwise. | ||
210 | It lets you control how deep the recursion goes. | ||
211 | If maxLevels is 1, FSCopyObject only scans the specified directory; | ||
212 | if maxLevels is 2, FSCopyObject scans the specified directory and | ||
213 | one subdirectory below the specified directory; etc. Set maxLevels to | ||
214 | zero to scan all levels. | ||
215 | |||
216 | The yourDataPtr parameter can point to whatever data structure you might | ||
217 | want to access from within your CopyObjectFilterProcPtr. | ||
218 | |||
219 | source --> The FSRef to the object you want to copy | ||
220 | destDir --> The FSRef to the directory you wish to copy source to | ||
221 | maxLevels --> Maximum number of directory levels to scan or | ||
222 | zero to scan all directory levels, ignored if the | ||
223 | object is a file | ||
224 | whichInfo --> The fields of the FSCatalogInfo you wish passed | ||
225 | to you in your CopyObjectFilterProc | ||
226 | dupeAction --> The action to take if an object of the same name exists | ||
227 | in the destination | ||
228 | newName --> The name you want the new object to have. If you pass | ||
229 | in NULL, the source object name will be used. | ||
230 | wantFSSpec --> Set to true if you want the FSSpec to each | ||
231 | object passed to your CopyObjectFilterProc. | ||
232 | wantName --> Set to true if you want the name of each | ||
233 | object passed to your CopyObjectFilterProc. | ||
234 | filterProcPtr --> A pointer to the CopyObjectFilterProc you | ||
235 | want called once for each object found | ||
236 | by FSCopyObject. | ||
237 | yourDataPtr --> An optional pointer to whatever data structure you | ||
238 | might want to access from within the | ||
239 | CopyObjectFilterProc. | ||
240 | newObjectRef --> An optional pointer to an FSRef that, on return, | ||
241 | references the new object. If you don't want this | ||
242 | info returned, pass in NULL | ||
243 | newObjectSpec --> An optional pointer to an FSSPec that, on return, | ||
244 | references the new object. If you don't want this | ||
245 | info returned, pass in NULL | ||
246 | */ | ||
247 | |||
248 | OSErr FSCopyObject( const FSRef *source, | ||
249 | const FSRef *destDir, | ||
250 | ItemCount maxLevels, | ||
251 | FSCatalogInfoBitmap whichInfo, | ||
252 | DupeAction dupeAction, | ||
253 | const HFSUniStr255 *newName, /* can be NULL */ | ||
254 | Boolean wantFSSpec, | ||
255 | Boolean wantName, | ||
256 | CopyObjectFilterProcPtr filterProcPtr, /* can be NULL */ | ||
257 | void *yourDataPtr, /* can be NULL */ | ||
258 | FSRef *newObjectRef, /* can be NULL */ | ||
259 | FSSpec *newObjectSpec); /* can be NULL */ | ||
260 | |||
261 | /*****************************************************************************/ | ||
262 | |||
263 | #pragma mark FSDeleteObjects | ||
264 | |||
265 | /* | ||
266 | The FSDeleteObjects function takes an FSRef to a file or directory | ||
267 | and attempts to delete it. If the object is a directory, all files | ||
268 | and subdirectories in the specified directory are deleted. If a | ||
269 | locked file or directory is encountered, it is unlocked and then | ||
270 | deleted. After deleting the directory's contents, the directory | ||
271 | is deleted. If any unexpected errors are encountered, | ||
272 | FSDeleteContainer quits and returns to the caller. | ||
273 | |||
274 | source --> FSRef to an object (can be file or directory). | ||
275 | |||
276 | __________ | ||
277 | */ | ||
278 | |||
279 | OSErr FSDeleteObjects( const FSRef *source ); | ||
280 | |||
281 | #ifdef __cplusplus | ||
282 | } | ||
283 | #endif | ||
284 | |||
285 | #endif | ||