|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | const from some other StringRefs since its implicitly const already.
llvm-svn: 216820 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We had two functions for finding the temp or cache directory. Each had a
different set of smarts about OS specific APIs.
With this patch system_temp_directory becomes the only way to do it.
llvm-svn: 216460 | 
| | 
| 
| 
| 
| 
| | This reverts commit r216360.
llvm-svn: 216428 | 
| | 
| 
| 
| | llvm-svn: 216360 | 
| | 
| 
| 
| 
| 
| | Sorry for the noise.
llvm-svn: 215249 | 
| | 
| 
| 
| 
| 
| | Part of pr20544. Test to follow in a second.
llvm-svn: 215241 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | path::const_iterator claims that it's a bidirectional iterator, but it
doesn't satisfy all of the contracts for a bidirectional iterator.
For example, n3376 24.2.5 p6 says "If a and b are both dereferenceable,
then a == b if and only if *a and *b are bound to the same object",
but this doesn't work with how we stash and recreate Components.
This means that our use of reverse_iterator on this type is invalid
and leads to many of the valgrind errors we're hitting, as explained
by Tilmann Scheller here:
    http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20140728/228654.html
Instead, we admit that path::const_iterator is only an input_iterator,
and implement a second input_iterator for path::reverse_iterator (by
changing const_iterator::operator-- to reverse_iterator::operator++).
All of the uses of this just traverse once over the path in one
direction or the other anyway.
llvm-svn: 214737 | 
| | 
| 
| 
| | llvm-svn: 211699 | 
| | 
| 
| 
| | llvm-svn: 211697 | 
| | 
| 
| 
| 
| 
| | A function to copy one file's contents to another.
llvm-svn: 211302 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | While std::error_code itself seems to work OK in all platforms, there
are few annoying differences with regards to the std::errc enumeration.
This patch adds a simple llvm enumeration, which will hopefully avoid build
breakages in other platforms and surprises as we get more uses of
std::error_code.
llvm-svn: 210920 | 
| | 
| 
| 
| | llvm-svn: 210871 | 
| | 
| 
| 
| 
| 
| | This should make sure that most new uses use the std prefix.
llvm-svn: 210835 | 
| | 
| 
| 
| | llvm-svn: 210737 | 
| | 
| 
| 
| | llvm-svn: 210716 | 
| | 
| 
| 
| 
| 
| 
| | This will allow inlining get_magic, which should in turn fix one of the mingw
build problems after the switch to std::error_code.
llvm-svn: 210712 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The idea of this patch is to turn llvm/Support/system_error.h into a
transitional header that just brings in the erorr_code api to the llvm
namespace. I will remove it shortly afterwards.
The cases where the general idea needed some tweaking:
* std::errc is a namespace in msvc, so we cannot use "using std::errc". I could
add an #ifdef, but there were not that many uses, so I just added std:: to
them in this patch.
* Template specialization had to be moved to the std namespace in this
patch set already.
* The msvc implementation of default_error_condition doesn't seem to
provide the same transformations as we need. Not too surprising since
the standard doesn't actually say what "equivalent" means. I fixed the
problem by keeping our old mapping and using it at error_code
construction time.
Despite these shortcomings I think this is still a good thing. Some reasons:
* The different implementations of system_error might improve over time.
* It removes 925 lines of code from llvm already.
* It removes 6313 bytes from the text segment of the clang binary when
it is built with gcc and 2816 bytes when building with clang and
libstdc++.
llvm-svn: 210687 | 
| | 
| 
| 
| 
| 
| 
| | There is no std::error_code::success, so this removes much of the noise
in transitioning to std::error_code.
llvm-svn: 209952 | 
| | 
| 
| 
| 
| 
| 
| 
| | llvm::sys::path.
http://reviews.llvm.org/D3687
llvm-svn: 208980 | 
| | 
| 
| 
| | llvm-svn: 205697 | 
| | 
| 
| 
| 
| 
| | is_symlink was always false since it was using stat instead of lstat.
llvm-svn: 204361 | 
| | 
| 
| 
| 
| 
| 
| | Add the Windows COFF ARM object file magic.  This enables the LLVM tools to
interact with COFF object files for Windows on ARM.
llvm-svn: 203761 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | When using a //net/ path, we were transforming the trailing / into a '.'
when the path was just the root path and we were iterating backwards.
Forwards iteration and other kinds of root path (C:\, /) were already
correct.
llvm-svn: 202999 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | After this I will set the default back to F_None. The advantage is that
before this patch forgetting to set F_Binary would corrupt a file on windows.
Forgetting to set F_Text produces one that cannot be read in notepad, which
is a better failure mode :-)
llvm-svn: 202052 | 
| | 
| 
| 
| 
| 
| 
| | The only extra bit of functionality that had to be exposed for this be be
implemented in Path.cpp is opening a file in rw mode.
llvm-svn: 202005 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Before this patch they would take an boolean argument to say if the path
already existed. This was redundant with the returned error_code which is able
to represent that. This allowed for callers to incorrectly check only the
existed flag instead of first checking the error code.
Instead, pass in a boolean flag to say if the previous (non-)existence should be
an error or not.
Callers of the of the old simple versions are not affected. They still ignore
the previous (non-)existence as they did before.
llvm-svn: 201979 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is an optimistic version of create_diretories: it tries to create the
directory first and looks at the parent only if that fails.
Running strace on "mkdir -p" shows that it is pessimistic, calling mkdir on
every element of the path. We could implement that if needed.
In any case, with both strategies there is no reason to call stat, just check
the return of mkdir.
llvm-svn: 201347 | 
| | 
| 
| 
| | llvm-svn: 201255 | 
| | 
| 
| 
| | llvm-svn: 201125 | 
| | 
| 
| 
| 
| 
| 
| | Sweep the codebase for common typos. Includes some changes to visible function
names that were misspelt.
llvm-svn: 200018 | 
| | 
| 
| 
| | llvm-svn: 198955 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary: Make identify_magic to recognize COFF import file.
Reviewers: Bigcheese
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D2165
llvm-svn: 194852 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
Some machine-type-neutral object files containing only undefined symbols
actually do exist in the Windows standard library. Need to recognize them
as COFF files.
Reviewers: Bigcheese
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D2164
llvm-svn: 194734 | 
| | 
| 
| 
| 
| 
| | The magic bytes should not include the trailing NUL byte.
llvm-svn: 192769 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Some background: One can pass compiled resource files (.res files) directly
to the linker on Windows. If a resource file is given, the linker will run
"cvtres" command in background to convert the resource file to a COFF file
to link it.
What I'm trying to do with this patch is to make the linker to recognize
the resource file by file magic, so that it can run cvtres command.
Differential Revision: http://llvm-reviews.chandlerc.com/D1943
llvm-svn: 192742 | 
| | 
| 
| 
| 
| 
| 
| 
| | This reflects the common use case of nativizing a prepared path. The existing
version invokes undefined behavior if input = output, add an assert to catch
that case.
llvm-svn: 190510 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This fixes the incorrect implementation of iterating on file/directory
paths.
Differential Review: http://llvm-reviews.chandlerc.com/D1277
llvm-svn: 188183 | 
| | 
| 
| 
| 
| 
| | This will let us use getUniqueID instead of st_dev directly on clang.
llvm-svn: 187378 | 
| | 
| 
| 
| | llvm-svn: 187124 | 
| | 
| 
| 
| 
| 
| | It is similar to 186511, but for creating files for writing.
llvm-svn: 186679 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This has some advantages:
* Lets us use native, utf16 windows functions.
* Easy to produce good errors on windows about trying to use a
directory when we want a file.
* Simplifies the unix version a bit.
llvm-svn: 186511 | 
| | 
| 
| 
| 
| 
| 
| | This centralizes the handling of O_BINARY and opens the way for hiding more
differences (like how open behaves with directories).
llvm-svn: 186447 | 
| | 
| 
| 
| | llvm-svn: 185728 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This function is complementary to createTemporaryFile. It handles the case were
the unique file is *not* temporary: we will rename it in the end. Since we
will rename it, the file has to be in the same filesystem as the final
destination and we don't prepend the system temporary directory.
This has a small semantic difference from unique_file: the default mode is 0666.
This matches the behavior of most unix tools. For example, with this change
lld now produces files with the same permissions as ld. I will add a test
of this change when I port clang over to createUniqueFile (next commit).
llvm-svn: 185726 | 
| | 
| 
| 
| 
| 
| 
| 
| | This function is inspired by clang's Driver::GetTemporaryPath. It hides the
pattern used for uniquing and requires simple file names that are always
placed in the system temporary directory.
llvm-svn: 185716 | 
| | 
| 
| 
| | llvm-svn: 185141 |