|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and tremendously less reliant on the optimizer to fix things.
The code is always necessarily looking for the entire length of the
string when doing the equality tests in this find implementation, but it
previously was needlessly re-checking the size each time among other
annoyances.
By writing this so simply an ddirectly in terms of memcmp, it also is
about 8x faster in a debug build, which in turn makes FileCheck about 2x
faster in 'ninja check-llvm'. This saves about 8% of the time for
FileCheck-heavy parts of the test suite like the x86 backend tests.
llvm-svn: 247269 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | with the StringRef::split method when used with a MaxSplit argument
other than '-1' (which nobody really does today, but which should
actually work).
The spec claimed both to split up to MaxSplit times, but also to append
<= MaxSplit strings to the vector. One of these doesn't make sense.
Given the name "MaxSplit", let's go with it being a max over how many
*splits* occur, which means the max on how many strings get appended is
MaxSplit+1. I'm not actually sure the implementation correctly provided
this logic either, as it used a really opaque loop structure.
The implementation was also playing weird games with nullptr in the data
field to try to rely on a totally opaque hidden property of the split
method that returns a pair. Nasty IMO.
Replace all of this with what is (IMO) simpler code that doesn't use the
pair returning split method, and instead just finds each separator and
appends directly. I think this is a lot easier to read, and it most
definitely matches the spec. Added some tests that exercise the corner
cases around StringRef() and StringRef("") that all now pass.
I'll start using this in code in the next commit.
llvm-svn: 247249 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | on StringRef. Finding and splitting on a single character is
substantially faster than doing it on even a single character StringRef
-- we immediately get to a *very* tuned memchr call this way.
Even nicer, we get to this even in a debug build, shaving 18% off the
runtime of TripleTest.Normalization, helping PR23676 some more.
llvm-svn: 247244 | 
| | 
| 
| 
| 
| 
| | just letting them be implicitly created.
llvm-svn: 216525 | 
| | 
| 
| 
| 
| 
| | added to work an old gcc bug. I believe its been fixed by now.
llvm-svn: 216156 | 
| | 
| 
| 
| | llvm-svn: 205697 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This compiles with no changes to clang/lld/lldb with MSVC and includes
overloads to various functions which are used by those projects and llvm
which have OwningPtr's as parameters. This should allow out of tree
projects some time to move. There are also no changes to libs/Target,
which should help out of tree targets have time to move, if necessary.
llvm-svn: 203083 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | startswith_lower is ocassionally useful and I think worth adding.
endwith_lower is added for completeness.
Differential Revision: http://llvm-reviews.chandlerc.com/D2041
llvm-svn: 193706 | 
| | 
| 
| 
| 
| 
| | Patch by Ismail Pazarbasi.
llvm-svn: 189162 | 
| | 
| 
| 
| | llvm-svn: 185861 | 
| | 
| 
| 
| 
| 
| 
| 
| | Remove the implementation in include/llvm/Support/YAMLTraits.h.
Added a DenseMap type DITypeHashMap in DebugInfo.h:
  DenseMap<std::pair<StringRef, unsigned>, MDNode*>
llvm-svn: 185852 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sooooo many of these had incorrect or strange main module includes.
I have manually inspected all of these, and fixed the main module
include to be the nearest plausible thing I could find. If you own or
care about any of these source files, I encourage you to take some time
and check that these edits were sensible. I can't have broken anything
(I strictly added headers, and reordered them, never removed), but they
may not be the headers you'd really like to identify as containing the
API being implemented.
Many forward declarations and missing includes were added to a header
files to allow them to parse cleanly when included first. The main
module rule does in fact have its merits. =]
llvm-svn: 169131 | 
| | 
| 
| 
| | llvm-svn: 165038 | 
| | 
| 
| 
| | llvm-svn: 156652 | 
| | 
| 
| 
| 
| 
| | fixes an assert reading "1239123123123123" when the result is already 64-bit.
llvm-svn: 155329 | 
| | 
| 
| 
| 
| 
| | StringRef::getAsInteger
llvm-svn: 155298 | 
| | 
| 
| 
| 
| 
| 
| 
| | it would fail with {,u}int64_t on x86-64 Linux.
This also removes code duplication.
llvm-svn: 152517 | 
| | 
| 
| 
| | llvm-svn: 152003 | 
| | 
| 
| 
| 
| 
| | of the StringRef.Split2 unittest on 32 bit machines.
llvm-svn: 151358 | 
| | 
| 
| 
| 
| 
| | and into StringRef.cpp, which is where the other StringRef stuff is.
llvm-svn: 151054 | 
| | 
| 
| 
| 
| 
| 
| 
| | Accomplished by moving the body of StringRef::edit_distance into
a separate function that accepts two ArrayRefs, and making
StringRef::edit_distance a wrapper around the new function.
llvm-svn: 150621 | 
| | 
| 
| 
| | llvm-svn: 143890 | 
| | 
| 
| 
| | llvm-svn: 143880 | 
| | 
| 
| 
| 
| 
| | Enable bounds checking to catch this kind of bug earlier.
llvm-svn: 142247 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Based on Horspool's simplified version of Boyer-Moore. We use a constant-sized table of
uint8_ts to keep cache thrashing low, needles bigger than 255 bytes are uncommon anyways.
The worst case is still O(n*m) but we do a lot better on the average case now.
llvm-svn: 142061 | 
| | 
| 
| 
| 
| 
| | Thanks to Alexandru Dura and Jonas Paulsson for finding it.
llvm-svn: 140859 | 
| | 
| 
| 
| 
| 
| | and it is just as easy to use StringRef::substr() preceding StringRef::compare() to achieve the same thing.
llvm-svn: 130430 | 
| | 
| 
| 
| 
| 
| | strncmp(). Unit tests also included.
llvm-svn: 129582 | 
| | 
| 
| 
| 
| 
| | Luis Felipe Strano Moraes!
llvm-svn: 129558 | 
| | 
| 
| 
| 
| 
| 
| 
| | zextOrTrunc(), and APSInt methods extend(), extOrTrunc() and new method
trunc(), to be const and to return a new value instead of modifying the
object in place.
llvm-svn: 121120 | 
| | 
| 
| 
| | llvm-svn: 120495 | 
| | 
| 
| 
| | llvm-svn: 120166 | 
| | 
| 
| 
| 
| 
| | on an early return.
llvm-svn: 118370 | 
| | 
| 
| 
| 
| 
| | allowed edit distance
llvm-svn: 116867 | 
| | 
| 
| 
| 
| 
| | characters > 127.
llvm-svn: 112189 | 
| | 
| 
| 
| 
| 
| | consistent with compare in corner cases.
llvm-svn: 112185 | 
| | 
| 
| 
| 
| 
| 
| 
| | - Cache used characters in a bitset to reduce memory overhead to just 32 bytes.
- On my core2 this code is faster except when the checked string was very short
  (smaller than the list of delimiters).
llvm-svn: 111817 | 
| | 
| 
| 
| 
| 
| 
| | This means that our Registers are now ordered R7, R8, R9, R10, R12, ...
Not R1, R10, R11, R12, R2, R3, ...
llvm-svn: 104745 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | It gets its own implementation totally divorced from the (presumably
performance-sensitive) routines which parse into a uint64_t.
Add APInt::operator|=(uint64_t), which is situationally much better than
using a full APInt.
llvm-svn: 97381 | 
| | 
| 
| 
| | llvm-svn: 92896 | 
| | 
| 
| 
| 
| 
| 
| | std::vector and llvm::SmallVector have annoying performance
tradeoffs. No, I don't expect this to matter, and now it won't.
llvm-svn: 92884 | 
| | 
| 
| 
| 
| 
| | to SmallVector, and add a unit test.
llvm-svn: 92340 | 
| | 
| 
| 
| | llvm-svn: 92309 | 
| | 
| 
| 
| | llvm-svn: 89372 | 
| | 
| 
| 
| 
| 
| | StringsEqualNoCase (from StringExtras.h) to it.
llvm-svn: 87020 | 
| | 
| 
| 
| 
| 
| | Also, add unittests for find_first_of and find_first_not_of.
llvm-svn: 86770 | 
| | 
| 
| 
| | llvm-svn: 86251 | 
| | 
| 
| 
| 
| 
| 
| 
| | static const class member into each translation unit, with external linkage???
 - If someone understands this issue better, please clue me in, I haven't
   consulted the standard yet.
llvm-svn: 82516 | 
| | 
| 
| 
| | llvm-svn: 82415 | 
| | 
| 
| 
| 
| 
| | find_first_of/find_first_of methods.
llvm-svn: 82347 |