blob: f8be64026b6aaf0d020dcd2afd7588cfa3a6bf9e [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
Doug Zongker28ce47c2011-10-28 10:33:05 -070023#ifdef __cplusplus
24extern "C" {
25#endif
26
Stephen Smalley779701d2012-02-09 14:13:23 -050027#ifdef HAVE_SELINUX
28#include <selinux/selinux.h>
29#include <selinux/label.h>
30#else
31struct selabel_handle;
32#endif
33
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080034/* Like "mkdir -p", try to guarantee that all directories
35 * specified in path are present, creating as many directories
36 * as necessary. The specified mode is passed to all mkdir
37 * calls; no modifications are made to umask.
38 *
39 * If stripFileName is set, everything after the final '/'
40 * is stripped before creating the directory hierarchy.
41 *
42 * If timestamp is non-NULL, new directories will be timestamped accordingly.
43 *
44 * Returns 0 on success; returns -1 (and sets errno) on failure
45 * (usually if some element of path is not a directory).
46 */
47int dirCreateHierarchy(const char *path, int mode,
Stephen Smalley779701d2012-02-09 14:13:23 -050048 const struct utimbuf *timestamp, bool stripFileName,
49 struct selabel_handle* sehnd);
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080050
51/* rm -rf <path>
52 */
53int dirUnlinkHierarchy(const char *path);
54
55/* chown -R <uid>:<gid> <path>
56 * chmod -R <mode> <path>
57 *
58 * Sets directories to <dirMode> and files to <fileMode>. Skips symlinks.
59 */
60int dirSetHierarchyPermissions(const char *path,
61 int uid, int gid, int dirMode, int fileMode);
62
Doug Zongker28ce47c2011-10-28 10:33:05 -070063#ifdef __cplusplus
64}
65#endif
66
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080067#endif // MINZIP_DIRUTIL_H_