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

Side by Side Diff: src/regexp.js

Issue 351853005: Split SetProperty(...attributes, strictmode) into AddProperty(...attributes) and SetProperty(...… (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Created 6 years, 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // This file relies on the fact that the following declaration has been made 5 // This file relies on the fact that the following declaration has been made
6 // in runtime.js: 6 // in runtime.js:
7 // var $Object = global.Object; 7 // var $Object = global.Object;
8 // var $Array = global.Array; 8 // var $Array = global.Array;
9 9
10 var $RegExp = global.RegExp; 10 var $RegExp = global.RegExp;
(...skipping 363 matching lines...) Expand 10 before | Expand all | Expand 10 after
374 // Used internally by replace regexp with function. 374 // Used internally by replace regexp with function.
375 // The array has the format of an "apply" argument for a replacement 375 // The array has the format of an "apply" argument for a replacement
376 // function. 376 // function.
377 var lastMatchInfoOverride = null; 377 var lastMatchInfoOverride = null;
378 378
379 // ------------------------------------------------------------------- 379 // -------------------------------------------------------------------
380 380
381 function SetUpRegExp() { 381 function SetUpRegExp() {
382 %CheckIsBootstrapping(); 382 %CheckIsBootstrapping();
383 %FunctionSetInstanceClassName($RegExp, 'RegExp'); 383 %FunctionSetInstanceClassName($RegExp, 'RegExp');
384 %SetProperty($RegExp.prototype, 'constructor', $RegExp, DONT_ENUM); 384 %DefineProperty($RegExp.prototype, 'constructor', $RegExp, DONT_ENUM);
385 %SetCode($RegExp, RegExpConstructor); 385 %SetCode($RegExp, RegExpConstructor);
386 386
387 InstallFunctions($RegExp.prototype, DONT_ENUM, $Array( 387 InstallFunctions($RegExp.prototype, DONT_ENUM, $Array(
388 "exec", RegExpExec, 388 "exec", RegExpExec,
389 "test", RegExpTest, 389 "test", RegExpTest,
390 "toString", RegExpToString, 390 "toString", RegExpToString,
391 "compile", RegExpCompileJS 391 "compile", RegExpCompileJS
392 )); 392 ));
393 393
394 // The length of compile is 1 in SpiderMonkey. 394 // The length of compile is 1 in SpiderMonkey.
395 %FunctionSetLength($RegExp.prototype.compile, 1); 395 %FunctionSetLength($RegExp.prototype.compile, 1);
396 396
397 // The properties input, $input, and $_ are aliases for each other. When this 397 // The properties input, $input, and $_ are aliases for each other. When this
398 // value is set the value it is set to is coerced to a string. 398 // value is set the value it is set to is coerced to a string.
399 // Getter and setter for the input. 399 // Getter and setter for the input.
400 var RegExpGetInput = function() { 400 var RegExpGetInput = function() {
401 var regExpInput = LAST_INPUT(lastMatchInfo); 401 var regExpInput = LAST_INPUT(lastMatchInfo);
402 return IS_UNDEFINED(regExpInput) ? "" : regExpInput; 402 return IS_UNDEFINED(regExpInput) ? "" : regExpInput;
403 }; 403 };
404 var RegExpSetInput = function(string) { 404 var RegExpSetInput = function(string) {
405 LAST_INPUT(lastMatchInfo) = ToString(string); 405 LAST_INPUT(lastMatchInfo) = ToString(string);
406 }; 406 };
407 407
408 %OptimizeObjectForAddingMultipleProperties($RegExp, 22); 408 %OptimizeObjectForAddingMultipleProperties($RegExp, 22);
409 %DefineOrRedefineAccessorProperty($RegExp, 'input', RegExpGetInput, 409 %DefineOrRedefineAccessorProperty($RegExp, 'input', RegExpGetInput,
rossberg 2014/06/27 09:47:30 Can't these simply be %DefineAccessorProperty now?
Toon Verwaest 2014/06/27 13:16:22 Done.
410 RegExpSetInput, DONT_DELETE); 410 RegExpSetInput, DONT_DELETE);
411 %DefineOrRedefineAccessorProperty($RegExp, '$_', RegExpGetInput, 411 %DefineOrRedefineAccessorProperty($RegExp, '$_', RegExpGetInput,
412 RegExpSetInput, DONT_ENUM | DONT_DELETE); 412 RegExpSetInput, DONT_ENUM | DONT_DELETE);
413 %DefineOrRedefineAccessorProperty($RegExp, '$input', RegExpGetInput, 413 %DefineOrRedefineAccessorProperty($RegExp, '$input', RegExpGetInput,
414 RegExpSetInput, DONT_ENUM | DONT_DELETE); 414 RegExpSetInput, DONT_ENUM | DONT_DELETE);
415 415
416 // The properties multiline and $* are aliases for each other. When this 416 // The properties multiline and $* are aliases for each other. When this
417 // value is set in SpiderMonkey, the value it is set to is coerced to a 417 // value is set in SpiderMonkey, the value it is set to is coerced to a
418 // boolean. We mimic that behavior with a slight difference: in SpiderMonkey 418 // boolean. We mimic that behavior with a slight difference: in SpiderMonkey
419 // the value of the expression 'RegExp.multiline = null' (for instance) is the 419 // the value of the expression 'RegExp.multiline = null' (for instance) is the
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
457 457
458 for (var i = 1; i < 10; ++i) { 458 for (var i = 1; i < 10; ++i) {
459 %DefineOrRedefineAccessorProperty($RegExp, '$' + i, 459 %DefineOrRedefineAccessorProperty($RegExp, '$' + i,
460 RegExpMakeCaptureGetter(i), NoOpSetter, 460 RegExpMakeCaptureGetter(i), NoOpSetter,
461 DONT_DELETE); 461 DONT_DELETE);
462 } 462 }
463 %ToFastProperties($RegExp); 463 %ToFastProperties($RegExp);
464 } 464 }
465 465
466 SetUpRegExp(); 466 SetUpRegExp();
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698