blob: 5d881f5624f585d1eed0e9de5b303671ccae64a5 [file] [log] [blame]
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -08001/*
2 * Copyright (C) 2007 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef MINZIP_DIRUTIL_H_
18#define MINZIP_DIRUTIL_H_
19
20#include <stdbool.h>
21#include <utime.h>
22
23/* Like "mkdir -p", try to guarantee that all directories
24 * specified in path are present, creating as many directories
25 * as necessary. The specified mode is passed to all mkdir
26 * calls; no modifications are made to umask.
27 *
28 * If stripFileName is set, everything after the final '/'
29 * is stripped before creating the directory hierarchy.
30 *
31 * If timestamp is non-NULL, new directories will be timestamped accordingly.
32 *
33 * Returns 0 on success; returns -1 (and sets errno) on failure
34 * (usually if some element of path is not a directory).
35 */
36int dirCreateHierarchy(const char *path, int mode,
37 const struct utimbuf *timestamp, bool stripFileName);
38
39/* rm -rf <path>
40 */
41int dirUnlinkHierarchy(const char *path);
42
43/* chown -R <uid>:<gid> <path>
44 * chmod -R <mode> <path>
45 *
46 * Sets directories to <dirMode> and files to <fileMode>. Skips symlinks.
47 */
48int dirSetHierarchyPermissions(const char *path,
49 int uid, int gid, int dirMode, int fileMode);
50
51#endif // MINZIP_DIRUTIL_H_