blob: 3e12a0bf5a5731888ce6f26049a206aaccd3be6c [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#include <selinux/selinux.h>
28#include <selinux/label.h>
Stephen Smalley779701d2012-02-09 14:13:23 -050029
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080030/* Like "mkdir -p", try to guarantee that all directories
31 * specified in path are present, creating as many directories
32 * as necessary. The specified mode is passed to all mkdir
33 * calls; no modifications are made to umask.
34 *
35 * If stripFileName is set, everything after the final '/'
36 * is stripped before creating the directory hierarchy.
37 *
38 * If timestamp is non-NULL, new directories will be timestamped accordingly.
39 *
40 * Returns 0 on success; returns -1 (and sets errno) on failure
41 * (usually if some element of path is not a directory).
42 */
43int dirCreateHierarchy(const char *path, int mode,
Stephen Smalley779701d2012-02-09 14:13:23 -050044 const struct utimbuf *timestamp, bool stripFileName,
45 struct selabel_handle* sehnd);
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080046
47/* rm -rf <path>
48 */
49int dirUnlinkHierarchy(const char *path);
50
51/* chown -R <uid>:<gid> <path>
52 * chmod -R <mode> <path>
53 *
54 * Sets directories to <dirMode> and files to <fileMode>. Skips symlinks.
55 */
56int dirSetHierarchyPermissions(const char *path,
Nick Kralevich627eb302013-07-17 19:01:37 -070057 int uid, int gid, int dirMode, int fileMode, const char* secontext);
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080058
Doug Zongker28ce47c2011-10-28 10:33:05 -070059#ifdef __cplusplus
60}
61#endif
62
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080063#endif // MINZIP_DIRUTIL_H_