|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The needed lld matching changes to be submitted immediately next,
but this revision will cause lld failures with this alone which is expected.
This removes the eating of the error in Archive::Child::getSize() when the characters
in the size field in the archive header for the member is not a number.  To do this we
have all of the needed methods return ErrorOr to push them up until we get out of lib.
Then the tools and can handle the error in whatever way is appropriate for that tool.
So the solution is to plumb all the ErrorOr stuff through everything that touches archives.
This include its iterators as one can create an Archive object but the first or any other
Child object may fail to be created due to a bad size field in its header.
Thanks to Lang Hames on the changes making child_iterator contain an
ErrorOr<Child> instead of a Child and the needed changes to ErrorOr.h to add
operator overloading for * and -> .
We don’t want to use llvm_unreachable() as it calls abort() and is produces a “crash”
and using report_fatal_error() to move the error checking will cause the program to
stop, neither of which are really correct in library code. There are still some uses of
these that should be cleaned up in this library code for other than the size field.
The test cases use archives with text files so one can see the non-digit character,
in this case a ‘%’, in the size field.
These changes will require corresponding changes to the lld project.  That will be
committed immediately after this change.  But this revision will cause lld failures
with this alone which is expected.
llvm-svn: 252192 | 
| | 
| 
| 
| | llvm-svn: 251794 | 
| | 
| 
| 
| 
| 
| 
| | We never need to pass end(). This will also remove some complication
once we start adding error checking.
llvm-svn: 251758 | 
| | 
| 
| 
| | llvm-svn: 250908 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | characters
in the size field in the archive header for the member is not a number.  To do this we
have all of the needed methods return ErrorOr to push them up until we get out of lib.
Then the tools and can handle the error in whatever way is appropriate for that tool.
So the solution is to plumb all the ErrorOr stuff through everything that touches archives.
This include its iterators as one can create an Archive object but the first or any other
Child object may fail to be created due to a bad size field in its header.
Thanks to Lang Hames on the changes making child_iterator contain an
ErrorOr<Child> instead of a Child and the needed changes to ErrorOr.h to add
operator overloading for * and -> .
We don’t want to use llvm_unreachable() as it calls abort() and is produces a “crash”
and using report_fatal_error() to move the error checking will cause the program to
stop, neither of which are really correct in library code. There are still some uses of
these that should be cleaned up in this library code for other than the size field.
Also corrected the code where the size gets us to the “at the end of the archive”
which is OK but past the end of the archive will return object_error::parse_failed now.
The test cases use archives with text files so one can see the non-digit character,
in this case a ‘%’, in the size field.
llvm-svn: 250906 | 
| | 
| 
| 
| | llvm-svn: 248264 | 
| | 
| 
| 
| 
| 
| | The member has to end up with a path relative to the archive.
llvm-svn: 242362 | 
| | 
| 
| 
| 
| 
| 
| | We were already doing the right thing for short file names, but not long
ones.
llvm-svn: 242354 | 
| | 
| 
| 
| | llvm-svn: 242348 | 
| | 
| 
| 
| 
| 
| 
| | We were storing both the path and the file name, which was redundant
and easy to get confused up with.
llvm-svn: 242347 | 
| | 
| 
| 
| 
| 
| | While at it, test that we can add to a thin archive.
llvm-svn: 242330 | 
| | 
| 
| 
| | llvm-svn: 242269 | 
| | 
| 
| 
| | llvm-svn: 242250 | 
| | 
| 
| 
| | llvm-svn: 242061 | 
| | 
| 
| 
| 
| 
| 
| | It looks like ld64 requires it. With this we seem to be able to bootstrap using
llvm-ar+/usr/bin/true instead of ar+ranlib (currently on stage2).
llvm-svn: 241842 | 
| | 
| 
| 
| 
| 
| 
| | This could be optimized and for now we only produce __.SYMDEF
and not "__.SYMDEF SORTED".
llvm-svn: 241814 | 
| | 
| 
| 
| | llvm-svn: 241810 | 
| | 
| 
| 
| 
| 
| 
| | The gnu ar format uses BE numbers. The BSD one uses LE. Add a helper for one or the
other. NFC for now, just removes some noise from the following patch.
llvm-svn: 241808 | 
| | 
| 
| 
| 
| 
| 
| | It will get another use in the following patch. Also rename the other helper to
printGNUSmallMemberHeader for consistency.
llvm-svn: 241805 | 
| | 
| 
| 
| 
| 
| | NFC, just less error prone.
llvm-svn: 241747 | 
| | 
| 
| 
| | llvm-svn: 241727 | 
| | 
| 
| 
| 
| 
| 
| 
| | No support for the symbol table yet (but will hopefully add it today).
We always use the long filename format so that we can align the member,
which is an advantage of the BSD format.
llvm-svn: 241721 | 
| | 
| 
| 
| | llvm-svn: 241692 | 
| | 
| 
| 
| | llvm-svn: 241691 | 
| | 
| 
| 
| | llvm-svn: 241685 | 
| | 
| 
| 
| | llvm-svn: 239913 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | As noted on Errc.h:
// * std::errc is just marked with is_error_condition_enum. This means that
//   common patters like AnErrorCode == errc::no_such_file_or_directory take
//   4 virtual calls instead of two comparisons.
And on some libstdc++ those virtual functions conclude that
------------------------
int main() {
  std::error_code foo = std::make_error_code(std::errc::no_such_file_or_directory);
  return foo == std::errc::no_such_file_or_directory;
}
-------------------------
should exit with 0.
llvm-svn: 239683 | 
| | 
| 
| 
| | llvm-svn: 239279 | 
|  | No functional change intended, other than some minor changes to certain
diagnostics.
Differential Revision: http://reviews.llvm.org/D10296
llvm-svn: 239278 |