2017-05-28 00:38:50 +02:00
|
|
|
'use strict';
|
|
|
|
require('./es6.regexp.flags');
|
2017-08-14 05:01:11 +02:00
|
|
|
var anObject = require('./_an-object');
|
|
|
|
var $flags = require('./_flags');
|
|
|
|
var DESCRIPTORS = require('./_descriptors');
|
|
|
|
var TO_STRING = 'toString';
|
|
|
|
var $toString = /./[TO_STRING];
|
2017-05-28 00:38:50 +02:00
|
|
|
|
2017-08-14 05:01:11 +02:00
|
|
|
var define = function (fn) {
|
2017-05-28 00:38:50 +02:00
|
|
|
require('./_redefine')(RegExp.prototype, TO_STRING, fn, true);
|
|
|
|
};
|
|
|
|
|
|
|
|
// 21.2.5.14 RegExp.prototype.toString()
|
2017-08-14 05:01:11 +02:00
|
|
|
if (require('./_fails')(function () { return $toString.call({ source: 'a', flags: 'b' }) != '/a/b'; })) {
|
|
|
|
define(function toString() {
|
2017-05-28 00:38:50 +02:00
|
|
|
var R = anObject(this);
|
|
|
|
return '/'.concat(R.source, '/',
|
|
|
|
'flags' in R ? R.flags : !DESCRIPTORS && R instanceof RegExp ? $flags.call(R) : undefined);
|
|
|
|
});
|
|
|
|
// FF44- RegExp#toString has a wrong name
|
2017-08-14 05:01:11 +02:00
|
|
|
} else if ($toString.name != TO_STRING) {
|
|
|
|
define(function toString() {
|
2017-05-28 00:38:50 +02:00
|
|
|
return $toString.call(this);
|
|
|
|
});
|
2017-08-14 05:01:11 +02:00
|
|
|
}
|