| Index: src/compiler/typer.cc
|
| diff --git a/src/compiler/typer.cc b/src/compiler/typer.cc
|
| index e33b7764567881f149e760262b26a9a58f2b1f87..a56f36c92b777a1aaa4916120858ba8a5b2bb519 100644
|
| --- a/src/compiler/typer.cc
|
| +++ b/src/compiler/typer.cc
|
| @@ -295,6 +295,7 @@ class Typer::Visitor : public Reducer {
|
|
|
| static Type* ReferenceEqualTyper(Type*, Type*, Typer*);
|
| static Type* StringFromCharCodeTyper(Type*, Typer*);
|
| + static Type* StringFromCodePointTyper(Type*, Typer*);
|
|
|
| Reduction UpdateType(Node* node, Type* current) {
|
| if (NodeProperties::IsTyped(node)) {
|
| @@ -1551,6 +1552,19 @@ Type* Typer::Visitor::StringFromCharCodeTyper(Type* type, Typer* t) {
|
| return Type::String();
|
| }
|
|
|
| +Type* Typer::Visitor::StringFromCodePointTyper(Type* type, Typer* t) {
|
| + type = NumberToUint32(ToNumber(type, t), t);
|
| + Factory* f = t->isolate()->factory();
|
| + double min = type->Min();
|
| + double max = type->Max();
|
| + if (min == max) {
|
| + uint32_t code = static_cast<uint32_t>(min) & String::kMaxUtf16CodeUnitU;
|
| + Handle<String> string = f->LookupSingleCharacterStringFromCode(code);
|
| + return Type::Constant(string, t->zone());
|
| + }
|
| + return Type::String();
|
| +}
|
| +
|
| Type* Typer::Visitor::TypeStringCharCodeAt(Node* node) {
|
| // TODO(bmeurer): We could do better here based on inputs.
|
| return Type::Range(0, kMaxUInt16, zone());
|
| @@ -1560,6 +1574,10 @@ Type* Typer::Visitor::TypeStringFromCharCode(Node* node) {
|
| return TypeUnaryOp(node, StringFromCharCodeTyper);
|
| }
|
|
|
| +Type* Typer::Visitor::TypeStringFromCodePoint(Node* node) {
|
| + return TypeUnaryOp(node, StringFromCodePointTyper);
|
| +}
|
| +
|
| Type* Typer::Visitor::TypeCheckBounds(Node* node) {
|
| Type* index = Operand(node, 0);
|
| Type* length = Operand(node, 1);
|
|
|