2 * Copyright (c) 2017 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@
34 #include <unordered_map>
35 #include <unordered_set>
36 #include <dispatch/dispatch.h>
38 #include "DyldSharedCache.h"
43 #if BUILDING_CACHE_BUILDER
46 std::pair
<uint8_t*, struct stat
> cacheLoad(Diagnostics
& diags
, const std::string path
);
49 std::pair
<uint8_t*, struct stat
> fill(Diagnostics
& diags
, const std::string
& path
);
51 std::unordered_map
<std::string
, std::pair
<uint8_t*, struct stat
>> entries
;
52 dispatch_queue_t cache_queue
;
55 extern FileCache fileCache
;
59 // recursively walk all files in a directory tree
60 // symlinks are ignored
61 // dirFilter should return true on directories which should not be recursed into
62 // callback is called on each regular file found with stat() info about the file
64 void iterateDirectoryTree(const std::string
& pathPrefix
, const std::string
& path
, bool (^dirFilter
)(const std::string
& dirPath
),
65 void (^callback
)(const std::string
& path
, const struct stat
& statBuf
), bool processFiles
=true, bool recurse
=true);
69 // writes the buffer to a temp file, then renames the file to the final path
70 // returns true on success
72 bool safeSave(const void* buffer
, size_t bufferLen
, const std::string
& path
);
75 const void* mapFileReadOnly(const char* path
, size_t& mappedSize
);
77 bool fileExists(const std::string
& path
);
79 std::unordered_map
<std::string
, uint32_t> parseOrderFile(const std::string
& orderFileData
);
80 std::string
loadOrderFile(const std::string
& orderFilePath
);
82 std::string
normalize_absolute_file_path(std::string path
);
83 std::string
basePath(const std::string
& path
);
84 std::string
dirPath(const std::string
& path
);
85 std::string
realPath(const std::string
& path
);
86 std::string
realFilePath(const std::string
& path
);
88 std::string
toolDir();
90 #if BUILDING_CACHE_BUILDER
91 class SymlinkResolver
{
95 void addFile(Diagnostics
& diags
, std::string path
);
97 void addSymlink(Diagnostics
& diags
, std::string fromPath
, std::string toPath
);
99 std::string
realPath(Diagnostics
& diags
, const std::string
& path
) const;
101 std::vector
<DyldSharedCache::FileAlias
> getResolvedSymlinks(Diagnostics
& diags
);
104 std::set
<std::string
> filePaths
;
105 std::map
<std::string
, std::string
> symlinks
;
107 #endif // BUILDING_CACHE_BUILDER
110 #endif // FileUtils_h