Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(124)

Unified Diff: src/heap.cc

Issue 11958040: Remove some unnecessary use of templates. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/api.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/heap.cc
diff --git a/src/heap.cc b/src/heap.cc
index 686f666e3b79ae909c5a18ba3d5b4db4d198bbd9..43522ab8edc57a9e695d8b6359b4c43ae6b3e353 100644
--- a/src/heap.cc
+++ b/src/heap.cc
@@ -4674,82 +4674,57 @@ Map* Heap::SymbolMapForString(String* string) {
}
-template<typename T>
-class AllocateInternalSymbolHelper {
- public:
- static void WriteOneByteData(T t, char* chars, int len);
- static void WriteTwoByteData(T t, uint16_t* chars, int len);
- private:
- DISALLOW_COPY_AND_ASSIGN(AllocateInternalSymbolHelper);
-};
-
-
-template<>
-class AllocateInternalSymbolHelper< Vector<const char> > {
- public:
- static inline void WriteOneByteData(Vector<const char> vector,
- uint8_t* chars,
- int len) {
- // Only works for ascii.
- ASSERT(vector.length() == len);
- memcpy(chars, vector.start(), len);
- }
-
- static inline void WriteTwoByteData(Vector<const char> vector,
- uint16_t* chars,
- int len) {
- const uint8_t* stream = reinterpret_cast<const uint8_t*>(vector.start());
- unsigned stream_length = vector.length();
- while (stream_length != 0) {
- unsigned consumed = 0;
- uint32_t c = unibrow::Utf8::ValueOf(stream, stream_length, &consumed);
- ASSERT(c != unibrow::Utf8::kBadChar);
- ASSERT(consumed <= stream_length);
- stream_length -= consumed;
- stream += consumed;
- if (c > unibrow::Utf16::kMaxNonSurrogateCharCode) {
- len -= 2;
- if (len < 0) break;
- *chars++ = unibrow::Utf16::LeadSurrogate(c);
- *chars++ = unibrow::Utf16::TrailSurrogate(c);
- } else {
- len -= 1;
- if (len < 0) break;
- *chars++ = c;
- }
+static inline void WriteOneByteData(Vector<const char> vector,
+ uint8_t* chars,
+ int len) {
+ // Only works for ascii.
+ ASSERT(vector.length() == len);
+ memcpy(chars, vector.start(), len);
+}
+
+static inline void WriteTwoByteData(Vector<const char> vector,
+ uint16_t* chars,
+ int len) {
+ const uint8_t* stream = reinterpret_cast<const uint8_t*>(vector.start());
+ unsigned stream_length = vector.length();
+ while (stream_length != 0) {
+ unsigned consumed = 0;
+ uint32_t c = unibrow::Utf8::ValueOf(stream, stream_length, &consumed);
+ ASSERT(c != unibrow::Utf8::kBadChar);
+ ASSERT(consumed <= stream_length);
+ stream_length -= consumed;
+ stream += consumed;
+ if (c > unibrow::Utf16::kMaxNonSurrogateCharCode) {
+ len -= 2;
+ if (len < 0) break;
+ *chars++ = unibrow::Utf16::LeadSurrogate(c);
+ *chars++ = unibrow::Utf16::TrailSurrogate(c);
+ } else {
+ len -= 1;
+ if (len < 0) break;
+ *chars++ = c;
}
- ASSERT(stream_length == 0);
- ASSERT(len == 0);
}
+ ASSERT(stream_length == 0);
+ ASSERT(len == 0);
+}
- private:
- DISALLOW_COPY_AND_ASSIGN(AllocateInternalSymbolHelper);
-};
-
-
-template<>
-class AllocateInternalSymbolHelper<String*> {
- public:
- static inline void WriteOneByteData(String* s, uint8_t* chars, int len) {
- ASSERT(s->length() == len);
- String::WriteToFlat(s, chars, 0, len);
- }
- static inline void WriteTwoByteData(String* s, uint16_t* chars, int len) {
- ASSERT(s->length() == len);
- String::WriteToFlat(s, chars, 0, len);
- }
+static inline void WriteOneByteData(String* s, uint8_t* chars, int len) {
+ ASSERT(s->length() == len);
+ String::WriteToFlat(s, chars, 0, len);
+}
- private:
- DISALLOW_COPY_AND_ASSIGN(AllocateInternalSymbolHelper<String*>);
-};
+static inline void WriteTwoByteData(String* s, uint16_t* chars, int len) {
+ ASSERT(s->length() == len);
+ String::WriteToFlat(s, chars, 0, len);
+}
template<bool is_one_byte, typename T>
MaybeObject* Heap::AllocateInternalSymbol(T t,
int chars,
uint32_t hash_field) {
- typedef AllocateInternalSymbolHelper<T> H;
ASSERT(chars >= 0);
// Compute map and object size.
int size;
@@ -4786,9 +4761,9 @@ MaybeObject* Heap::AllocateInternalSymbol(T t,
ASSERT_EQ(size, answer->Size());
if (is_one_byte) {
- H::WriteOneByteData(t, SeqOneByteString::cast(answer)->GetChars(), chars);
+ WriteOneByteData(t, SeqOneByteString::cast(answer)->GetChars(), chars);
} else {
- H::WriteTwoByteData(t, SeqTwoByteString::cast(answer)->GetChars(), chars);
+ WriteTwoByteData(t, SeqTwoByteString::cast(answer)->GetChars(), chars);
}
return answer;
}
« no previous file with comments | « src/api.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698