/* * Copyright (C) 2007 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef MINZIP_DIRUTIL_H_ #define MINZIP_DIRUTIL_H_ #include <stdbool.h> #include <utime.h> #ifdef __cplusplus extern "C" { #endif #ifdef HAVE_SELINUX #include <selinux/selinux.h> #include <selinux/label.h> #else struct selabel_handle; #endif /* Like "mkdir -p", try to guarantee that all directories * specified in path are present, creating as many directories * as necessary. The specified mode is passed to all mkdir * calls; no modifications are made to umask. * * If stripFileName is set, everything after the final '/' * is stripped before creating the directory hierarchy. * * If timestamp is non-NULL, new directories will be timestamped accordingly. * * Returns 0 on success; returns -1 (and sets errno) on failure * (usually if some element of path is not a directory). */ int dirCreateHierarchy(const char *path, int mode, const struct utimbuf *timestamp, bool stripFileName, struct selabel_handle* sehnd); /* rm -rf <path> */ int dirUnlinkHierarchy(const char *path); /* chown -R <uid>:<gid> <path> * chmod -R <mode> <path> * * Sets directories to <dirMode> and files to <fileMode>. Skips symlinks. */ int dirSetHierarchyPermissions(const char *path, int uid, int gid, int dirMode, int fileMode); #ifdef __cplusplus } #endif #endif // MINZIP_DIRUTIL_H_