]>
git.saurik.com Git - apple/copyfile.git/blob - copyfile.h
2 * Copyright (c) 2004-2010 Apple, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
23 #ifndef _COPYFILE_H_ /* version 0.1 */
27 * This API facilitates the copying of files and their associated
28 * metadata. There are several open source projects that need
29 * modifications to support preserving extended attributes and ACLs
30 * and this API collapses several hundred lines of modifications into
35 #include <sys/cdefs.h>
39 struct _copyfile_state
;
40 typedef struct _copyfile_state
* copyfile_state_t
;
41 typedef uint32_t copyfile_flags_t
;
46 * from path to source file system object
47 * to path to destination file system object
48 * state opaque blob for future extensibility
49 * Must be NULL in current implementation
50 * flags (described below)
52 * int negative for error
55 int copyfile(const char *from
, const char *to
, copyfile_state_t state
, copyfile_flags_t flags
);
56 int fcopyfile(int from_fd
, int to_fd
, copyfile_state_t
, copyfile_flags_t flags
);
58 int copyfile_state_free(copyfile_state_t
);
59 copyfile_state_t
copyfile_state_alloc(void);
62 int copyfile_state_get(copyfile_state_t s
, uint32_t flag
, void * dst
);
63 int copyfile_state_set(copyfile_state_t s
, uint32_t flag
, const void * src
);
65 typedef int (*copyfile_callback_t
)(int, int, copyfile_state_t
, const char *, const char *, void *);
67 #define COPYFILE_STATE_SRC_FD 1
68 #define COPYFILE_STATE_SRC_FILENAME 2
69 #define COPYFILE_STATE_DST_FD 3
70 #define COPYFILE_STATE_DST_FILENAME 4
71 #define COPYFILE_STATE_QUARANTINE 5
72 #define COPYFILE_STATE_STATUS_CB 6
73 #define COPYFILE_STATE_STATUS_CTX 7
74 #define COPYFILE_STATE_COPIED 8
75 #define COPYFILE_STATE_XATTRNAME 9
76 #define COPYFILE_STATE_WAS_CLONED 10
79 #define COPYFILE_DISABLE_VAR "COPYFILE_DISABLE"
81 /* flags for copyfile */
83 #define COPYFILE_ACL (1<<0)
84 #define COPYFILE_STAT (1<<1)
85 #define COPYFILE_XATTR (1<<2)
86 #define COPYFILE_DATA (1<<3)
88 #define COPYFILE_SECURITY (COPYFILE_STAT | COPYFILE_ACL)
89 #define COPYFILE_METADATA (COPYFILE_SECURITY | COPYFILE_XATTR)
90 #define COPYFILE_ALL (COPYFILE_METADATA | COPYFILE_DATA)
92 #define COPYFILE_RECURSIVE (1<<15) /* Descend into hierarchies */
93 #define COPYFILE_CHECK (1<<16) /* return flags for xattr or acls if set */
94 #define COPYFILE_EXCL (1<<17) /* fail if destination exists */
95 #define COPYFILE_NOFOLLOW_SRC (1<<18) /* don't follow if source is a symlink */
96 #define COPYFILE_NOFOLLOW_DST (1<<19) /* don't follow if dst is a symlink */
97 #define COPYFILE_MOVE (1<<20) /* unlink src after copy */
98 #define COPYFILE_UNLINK (1<<21) /* unlink dst before copy */
99 #define COPYFILE_NOFOLLOW (COPYFILE_NOFOLLOW_SRC | COPYFILE_NOFOLLOW_DST)
101 #define COPYFILE_PACK (1<<22)
102 #define COPYFILE_UNPACK (1<<23)
104 #define COPYFILE_CLONE (1<<24)
105 #define COPYFILE_CLONE_FORCE (1<<25)
107 #define COPYFILE_RUN_IN_PLACE (1<<26)
109 #define COPYFILE_DATA_SPARSE (1<<27)
111 #define COPYFILE_VERBOSE (1<<30)
113 #define COPYFILE_RECURSE_ERROR 0
114 #define COPYFILE_RECURSE_FILE 1
115 #define COPYFILE_RECURSE_DIR 2
116 #define COPYFILE_RECURSE_DIR_CLEANUP 3
117 #define COPYFILE_COPY_DATA 4
118 #define COPYFILE_COPY_XATTR 5
120 #define COPYFILE_START 1
121 #define COPYFILE_FINISH 2
122 #define COPYFILE_ERR 3
123 #define COPYFILE_PROGRESS 4
125 #define COPYFILE_CONTINUE 0
126 #define COPYFILE_SKIP 1
127 #define COPYFILE_QUIT 2
131 #endif /* _COPYFILE_H_ */