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

Unified Diff: src/regexp-stack.cc

Issue 1285163003: Move regexp implementation into its own folder. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: addressed comment Created 5 years, 4 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/regexp-stack.h ('k') | src/regexp/OWNERS » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/regexp-stack.cc
diff --git a/src/regexp-stack.cc b/src/regexp-stack.cc
deleted file mode 100644
index 0ef4942048b8fd1a91352af9664fdb955c311d9f..0000000000000000000000000000000000000000
--- a/src/regexp-stack.cc
+++ /dev/null
@@ -1,88 +0,0 @@
-// Copyright 2009 the V8 project authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "src/v8.h"
-
-#include "src/regexp-stack.h"
-
-namespace v8 {
-namespace internal {
-
-RegExpStackScope::RegExpStackScope(Isolate* isolate)
- : regexp_stack_(isolate->regexp_stack()) {
- // Initialize, if not already initialized.
- regexp_stack_->EnsureCapacity(0);
-}
-
-
-RegExpStackScope::~RegExpStackScope() {
- // Reset the buffer if it has grown.
- regexp_stack_->Reset();
-}
-
-
-RegExpStack::RegExpStack()
- : isolate_(NULL) {
-}
-
-
-RegExpStack::~RegExpStack() {
- thread_local_.Free();
-}
-
-
-char* RegExpStack::ArchiveStack(char* to) {
- size_t size = sizeof(thread_local_);
- MemCopy(reinterpret_cast<void*>(to), &thread_local_, size);
- thread_local_ = ThreadLocal();
- return to + size;
-}
-
-
-char* RegExpStack::RestoreStack(char* from) {
- size_t size = sizeof(thread_local_);
- MemCopy(&thread_local_, reinterpret_cast<void*>(from), size);
- return from + size;
-}
-
-
-void RegExpStack::Reset() {
- if (thread_local_.memory_size_ > kMinimumStackSize) {
- DeleteArray(thread_local_.memory_);
- thread_local_ = ThreadLocal();
- }
-}
-
-
-void RegExpStack::ThreadLocal::Free() {
- if (memory_size_ > 0) {
- DeleteArray(memory_);
- Clear();
- }
-}
-
-
-Address RegExpStack::EnsureCapacity(size_t size) {
- if (size > kMaximumStackSize) return NULL;
- if (size < kMinimumStackSize) size = kMinimumStackSize;
- if (thread_local_.memory_size_ < size) {
- Address new_memory = NewArray<byte>(static_cast<int>(size));
- if (thread_local_.memory_size_ > 0) {
- // Copy original memory into top of new memory.
- MemCopy(reinterpret_cast<void*>(new_memory + size -
- thread_local_.memory_size_),
- reinterpret_cast<void*>(thread_local_.memory_),
- thread_local_.memory_size_);
- DeleteArray(thread_local_.memory_);
- }
- thread_local_.memory_ = new_memory;
- thread_local_.memory_size_ = size;
- thread_local_.limit_ = new_memory + kStackLimitSlack * kPointerSize;
- }
- return thread_local_.memory_ + thread_local_.memory_size_;
-}
-
-
-} // namespace internal
-} // namespace v8
« no previous file with comments | « src/regexp-stack.h ('k') | src/regexp/OWNERS » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698