Chromium Code Reviews| Index: lib/regexp.cc |
| =================================================================== |
| --- lib/regexp.cc (revision 713) |
| +++ lib/regexp.cc (working copy) |
| @@ -5,6 +5,7 @@ |
| #include "vm/bootstrap_natives.h" |
| #include "vm/assert.h" |
| +#include "vm/dart_entry.h" |
| #include "vm/exceptions.h" |
| #include "vm/native_entry.h" |
| #include "vm/object.h" |
| @@ -13,9 +14,18 @@ |
| namespace dart { |
| +static void CheckAndThrowExceptionIfNull(const Instance& obj) { |
| + if (obj.IsNull()) { |
| + GrowableArray<const Object*> args; |
| + Exceptions::ThrowByType(Exceptions::kNullPointer, args); |
| + } |
| +} |
| + |
| + |
| DEFINE_NATIVE_ENTRY(JSSyntaxRegExp_factory, 4) { |
| ASSERT(TypeArguments::CheckedHandle(arguments->At(0)).IsNull()); |
| const String& pattern = String::CheckedHandle(arguments->At(1)); |
| + CheckAndThrowExceptionIfNull(pattern); |
| const Instance& handle_multi_line = Instance::CheckedHandle(arguments->At(2)); |
| const Instance& handle_ignore_case = |
| Instance::CheckedHandle(arguments->At(3)); |
| @@ -29,6 +39,7 @@ |
| DEFINE_NATIVE_ENTRY(JSSyntaxRegExp_getPattern, 1) { |
| const JSRegExp& regexp = JSRegExp::CheckedHandle(arguments->At(0)); |
| + ASSERT(!regexp.IsNull()); |
| const String& result = String::Handle(regexp.pattern()); |
| arguments->SetReturn(result); |
| } |
| @@ -36,6 +47,7 @@ |
| DEFINE_NATIVE_ENTRY(JSSyntaxRegExp_multiLine, 1) { |
| const JSRegExp& regexp = JSRegExp::CheckedHandle(arguments->At(0)); |
| + ASSERT(!regexp.IsNull()); |
| const Bool& result = Bool::Handle(Bool::Get(regexp.is_multi_line())); |
| arguments->SetReturn(result); |
| } |
| @@ -43,6 +55,7 @@ |
| DEFINE_NATIVE_ENTRY(JSSyntaxRegExp_ignoreCase, 1) { |
| const JSRegExp& regexp = JSRegExp::CheckedHandle(arguments->At(0)); |
| + ASSERT(!regexp.IsNull()); |
| const Bool& result = Bool::Handle(Bool::Get(regexp.is_ignore_case())); |
| arguments->SetReturn(result); |
| } |
| @@ -50,6 +63,7 @@ |
| DEFINE_NATIVE_ENTRY(JSSyntaxRegExp_getGroupCount, 1) { |
| const JSRegExp& regexp = JSRegExp::CheckedHandle(arguments->At(0)); |
| + ASSERT(!regexp.IsNull()); |
| if (regexp.is_initialized()) { |
| const Smi& result = Smi::Handle(regexp.num_bracket_expressions()); |
| arguments->SetReturn(result); |
| @@ -67,7 +81,9 @@ |
| DEFINE_NATIVE_ENTRY(JSSyntaxRegExp_ExecuteMatch, 3) { |
| const JSRegExp& regexp = JSRegExp::CheckedHandle(arguments->At(0)); |
| + ASSERT(!regexp.IsNull()); |
| const String& str = String::CheckedHandle(arguments->At(1)); |
| + CheckAndThrowExceptionIfNull(str); |
|
turnidge
2011/10/27 17:08:19
I just wanted to point out that by putting the che
siva
2011/10/28 06:14:43
Doing null pointer checks and throwing NullPointer
|
| const Smi& start_index = Smi::CheckedHandle(arguments->At(2)); |
| const Array& result = |
| Array::Handle(Jscre::Execute(regexp, str, start_index.Value())); |