Commit a07b99f3 authored by dcarney@chromium.org's avatar dcarney@chromium.org

build fix for d8-readline for 15142

R=svenpanne@chromium.org
BUG=

Review URL: https://codereview.chromium.org/17028013

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@15151 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 7d535460
...@@ -150,18 +150,19 @@ char* ReadLineEditor::CompletionGenerator(const char* text, int state) { ...@@ -150,18 +150,19 @@ char* ReadLineEditor::CompletionGenerator(const char* text, int state) {
static Persistent<Array> current_completions; static Persistent<Array> current_completions;
Isolate* isolate = read_line_editor.isolate_; Isolate* isolate = read_line_editor.isolate_;
Locker lock(isolate); Locker lock(isolate);
HandleScope scope;
Handle<Array> completions;
if (state == 0) { if (state == 0) {
HandleScope scope;
Local<String> full_text = String::New(rl_line_buffer, rl_point); Local<String> full_text = String::New(rl_line_buffer, rl_point);
Handle<Array> completions = completions = Shell::GetCompletions(isolate, String::New(text), full_text);
Shell::GetCompletions(isolate, String::New(text), full_text); current_completions.Reset(isolate, completions);
current_completions = Persistent<Array>::New(isolate, completions);
current_index = 0; current_index = 0;
} else {
completions = Local<Array>::New(isolate, current_completions);
} }
if (current_index < current_completions->Length()) { if (current_index < completions->Length()) {
HandleScope scope;
Handle<Integer> index = Integer::New(current_index); Handle<Integer> index = Integer::New(current_index);
Handle<Value> str_obj = current_completions->Get(index); Handle<Value> str_obj = completions->Get(index);
current_index++; current_index++;
String::Utf8Value str(str_obj); String::Utf8Value str(str_obj);
return strdup(*str); return strdup(*str);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment