|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | Windows doesn't have roots, so I think this test doesn't make sense
there.
llvm-svn: 284386 | 
| | 
| 
| 
| 
| 
| 
| | /../foo is still a proper path after removing the dotdot. This should
now finally match https://9p.io/sys/doc/lexnames.html [Cleaning names].
llvm-svn: 284384 | 
| | 
| 
| 
| 
| 
| 
| 
| | Ideally these would actually check that the results are reasonable,
but given that we're looping over so many different kinds of path that
isn't really practical.
llvm-svn: 284350 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Reviewers: bkramer
Subscribers: llvm-commits
Differential Revision: https://reviews.llvm.org/D25561
llvm-svn: 284129 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | If we failed to commit the buffer but did not die to a signal, the temp
file would remain on disk on Windows. Having an open file mapping and
file handle prevents the file from being deleted. I am choosing not to
add an assertion of success on the temp file removal, since virus
scanners and other environmental things can often cause removal to fail
in real world tools.
Also fix more temp file leaks in unit tests.
llvm-svn: 280445 | 
| | 
| 
| 
| | llvm-svn: 280443 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | If the result of the find is only used to compare against end(), just
use is_contained instead.
No functionality change is intended.
llvm-svn: 278433 | 
| | 
| 
| 
| | llvm-svn: 273262 | 
| | 
| 
| 
| 
| 
| | GetFinalPathNameByHandle API does not behave as documented; if given a buffer that has enough space for the path but not the null terminator, the call will return the number of characters required *without* the null terminator (despite being documented otherwise) and it will not set GetLastError(). The result was that this function would return a bogus path and no error. Instead, ensure there is sufficient space for a null terminator (we already strip it off manually for compatibility with older versions of Windows).
llvm-svn: 273195 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | including case -- so that clang can later warn about non-portable #include and #import directives.
Differential Revision: http://reviews.llvm.org/D19842
Corresponding clang patch: http://reviews.llvm.org/D19843
Re-commit after addressing issues with of generating too many warnings for Windows and asan test failures
Patch by Eric Niebler
llvm-svn: 272555 | 
| | 
| 
| 
| 
| 
| | #include and #import paths (Corresponding clang patch has been reverted by r271761). Patches are reverted because they generate lots of unadressable warnings for windows and fail tests under ASAN.
llvm-svn: 271764 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | including case -- so that clang can later warn about non-portable #include and #import directives.
Differential Revision: http://reviews.llvm.org/D19842
Patch by Eric Niebler
llvm-svn: 271704 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Add support to control where files for a distributed backend (the
individual index files and optional imports files) are created.
This is invoked with a new thinlto-prefix-replace option in the gold
plugin and llvm-lto. If specified, expects a string of the form
"oldprefix:newprefix", and instead of generating these files in the
same directory path as the corresponding bitcode file, will use a path
formed by replacing the bitcode file's path prefix matching oldprefix
with newprefix.
Also add a new replace_path_prefix helper to Path.h in libSupport.
Depends on D19636.
Reviewers: joker.eph
Subscribers: llvm-commits, joker.eph
Differential Revision: http://reviews.llvm.org/D19644
llvm-svn: 269771 | 
| | 
| 
| 
| | llvm-svn: 269488 | 
| | 
| 
| 
| | llvm-svn: 266614 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
A character within a string literal is not escaped correctly.
In this case, there is no semantic change because the invalid character turn out to be NUL anyway.
note: "\0x12" is equivalent to {0, 'x', '1', '2'} and not { 12 }.
This issue was found by clang-tidy.
Reviewers: rnk
Subscribers: cfe-commits
Differential Revision: http://reviews.llvm.org/D18747
llvm-svn: 265376 | 
| | 
| 
| 
| | llvm-svn: 260418 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | at least as big as the mach header to be identified as a Mach-O file and
make sure smaller files are not identified as a Mach-O files but as
unknown files. Also fix identify_magic() so it looks at all 4 bytes of
the filetype field when determining the type of the Mach-O file.
Then fix the macho-invalid-header test case to check that it is an
unknown file and make sure it does not get the error for
object_error::parse_failed.  And also update the unit tests.
llvm-svn: 258883 | 
| | 
| 
| 
| | llvm-svn: 253373 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
This patch changes the behavior of path::system_temp_directory() on Windows to be closer to GetTempPath Windows API call. Enforces path separator to be the native one, makes path absolute, etc. GetTempPath is not used directly because of limitations/implementation bugs on Windows 7.
Windows specific unit tests are added. Most of them runs in separated process with modified environment variables.
This change fixes FileSystemTest.CreateDir unittest that had been failing when run from Unix-like shell on Windows (Unix-like path separator (/) used in env variables).
Reviewers: chapuni, rafael, aaron.ballman
Subscribers: rafael, llvm-commits
Differential Revision: http://reviews.llvm.org/D14231
llvm-svn: 253345 | 
| | 
| 
| 
| 
| 
| | Differential Revision: http://reviews.llvm.org/D14503
llvm-svn: 252504 | 
| | 
| 
| 
| 
| 
| | Differential Revision: http://reviews.llvm.org/D14393
llvm-svn: 252499 | 
| | 
| 
| 
| 
| 
| | Windows.
llvm-svn: 252367 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
In general GetTempDir follows the same logic as the replaced code: checks env variables TMP, TEMP, USERPROFILE in order. However, it also perform other checks like making separators native (\), making the path absolute, etc.
This change fixes FileSystemTest.CreateDir unittest that had been failing when run from Unix-like shell on Windows (Unix-like path separator (/) used in env variables).
Reviewers: chapuni, rafael, aaron.ballman
Subscribers: rafael, llvm-commits
Differential Revision: http://reviews.llvm.org/D14231
llvm-svn: 252366 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
The new function sys::path::user_cache_directory tries to discover
a directory suitable for cache storage for current system user.
On Windows and Darwin it returns a path to system-specific user cache directory.
On Linux it follows XDG Base Directory Specification, what is:
- use non-empty $XDG_CACHE_HOME env var,
- use $HOME/.cache.
Reviewers: chapuni, aaron.ballman, rafael
Subscribers: rafael, aaron.ballman, llvm-commits
Differential Revision: http://reviews.llvm.org/D13801
llvm-svn: 251784 | 
| | 
| 
| 
| 
| 
| | It turns out that constructing std::string from null pointer is not the very best idea.
llvm-svn: 250506 | 
| | 
| 
| 
| 
| 
| | Lit sanitizes env vars. $HOME is not exported in Lit tests.
llvm-svn: 250505 | 
| | 
| 
| 
| | llvm-svn: 250504 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: This patch replaces usage of deprecated SHGetFolderPathW with SHGetKnownFolderPath. The usage of SHGetKnownFolderPath is wrapped to allow queries for other "known" folders in the near future.
Reviewers: aaron.ballman, gbedwell
Subscribers: chapuni, llvm-commits
Differential Revision: http://reviews.llvm.org/D13753
llvm-svn: 250501 | 
| | 
| 
| 
| | llvm-svn: 249320 | 
| | 
| 
| 
| 
| 
| | This will be used soon from clang.
llvm-svn: 249309 | 
| | 
| 
| 
| 
| 
| 
| | splits to actually use the single character split routine which does
less work, and in a debug build is *substantially* faster.
llvm-svn: 247245 | 
| | 
| 
| 
| 
| 
| | And make it more robust in the edge case of exactly "./" as input.
llvm-svn: 246711 | 
| | 
| 
| 
| | llvm-svn: 244268 | 
| | 
| 
| 
| | llvm-svn: 239804 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The patch is generated using clang-tidy misc-use-override check.
This command was used:
  tools/clang/tools/extra/clang-tidy/tool/run-clang-tidy.py \
    -checks='-*,misc-use-override' -header-filter='llvm|clang' \
    -j=32 -fix -format
http://reviews.llvm.org/D8925
llvm-svn: 234679 | 
| | 
| 
| 
| 
| 
| 
| | We were treating '/.foo' as ['/', '.', 'foo'] instead of ['/', '.foo'],
which lead to insanity.  Same for '..'.
llvm-svn: 231727 | 
| | 
| 
| 
| 
| 
| | This particular subtype of Mach-O was missing. Add it.
llvm-svn: 230567 | 
| | 
| 
| 
| 
| 
| | This removes a duplicated stat on every file that llvm-ar looks at.
llvm-svn: 224138 | 
| | 
| 
| 
| 
| 
| | I will add a real use in another commit.
llvm-svn: 224136 | 
| | 
| 
| 
| 
| 
| | As a bonus we can actually check the return value.
llvm-svn: 224046 | 
| | 
| 
| 
| | llvm-svn: 224029 | 
| | 
| 
| 
| | llvm-svn: 221887 | 
| | 
| 
| 
| | llvm-svn: 221845 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Windows normally limits the length of an absolute path name to 260
characters; directories can have lower limits.  These limits increase
to about 32K if you use absolute paths with the special '\\?\'
prefix. Teach Support\Windows\Path.inc to use that prefix as needed.
TODO: Other parts of Support could also learn to use this prefix.
llvm-svn: 221841 | 
| | 
| 
| 
| 
| 
| | The wrong value was returned and the unittest did not cover the stub dylib case.
llvm-svn: 217933 | 
| | 
| 
| 
| 
| 
| 
| | Use llvm::COFF::BigObjMagic insetad of the string literal.
Also checks the version number.
llvm-svn: 217633 | 
| | 
| 
| 
| 
| 
| 
| | identify_magic recognized a COFF bigobj as an import library file.
This patch fixes that.
llvm-svn: 217627 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The main difference is the removal of
std::error_code exists(const Twine &path, bool &result);
It was an horribly redundant interface since a file not existing is also a valid
error_code. Now we have an access function that returns just an error_code. This
is the only function that has to be implemented for Unix and Windows. The
functions can_write, exists and can_execute an now just wrappers.
One still has to be very careful using these function to avoid introducing
race conditions (Time of check to time of use).
llvm-svn: 217625 | 
| | 
| 
| 
| | llvm-svn: 217618 |