OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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 #ifndef V8_FACTORY_H_ | 5 #ifndef V8_FACTORY_H_ |
6 #define V8_FACTORY_H_ | 6 #define V8_FACTORY_H_ |
7 | 7 |
8 #include "src/isolate.h" | 8 #include "src/isolate.h" |
9 #include "src/messages.h" | 9 #include "src/messages.h" |
10 | 10 |
(...skipping 519 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
530 Handle<Code> CopyCode(Handle<Code> code, Vector<byte> reloc_info); | 530 Handle<Code> CopyCode(Handle<Code> code, Vector<byte> reloc_info); |
531 | 531 |
532 // Interface for creating error objects. | 532 // Interface for creating error objects. |
533 | 533 |
534 Handle<Object> NewError(const char* maker, const char* message, | 534 Handle<Object> NewError(const char* maker, const char* message, |
535 Handle<JSArray> args); | 535 Handle<JSArray> args); |
536 Handle<String> EmergencyNewError(const char* message, Handle<JSArray> args); | 536 Handle<String> EmergencyNewError(const char* message, Handle<JSArray> args); |
537 Handle<Object> NewError(const char* maker, const char* message, | 537 Handle<Object> NewError(const char* maker, const char* message, |
538 Vector<Handle<Object> > args); | 538 Vector<Handle<Object> > args); |
539 Handle<Object> NewError(const char* message, Vector<Handle<Object> > args); | 539 Handle<Object> NewError(const char* message, Vector<Handle<Object> > args); |
| 540 Handle<Object> NewError(const char* maker, |
| 541 MessageTemplate::Template template_index, |
| 542 Handle<Object> arg0, Handle<Object> arg1, |
| 543 Handle<Object> arg2); |
540 | 544 |
541 Handle<Object> NewError(Handle<String> message); | 545 Handle<Object> NewError(Handle<String> message); |
542 Handle<Object> NewError(const char* constructor, Handle<String> message); | 546 Handle<Object> NewError(const char* constructor, Handle<String> message); |
543 | 547 |
544 Handle<Object> NewTypeError(const char* message, | 548 Handle<Object> NewTypeError(const char* message, |
545 Vector<Handle<Object> > args); | 549 Vector<Handle<Object> > args); |
| 550 Handle<Object> NewTypeError(MessageTemplate::Template template_index, |
| 551 Handle<Object> arg0 = Handle<Object>(), |
| 552 Handle<Object> arg1 = Handle<Object>(), |
| 553 Handle<Object> arg2 = Handle<Object>()); |
546 Handle<Object> NewTypeError(Handle<String> message); | 554 Handle<Object> NewTypeError(Handle<String> message); |
547 | 555 |
548 Handle<Object> NewRangeError(const char* message, | 556 Handle<Object> NewRangeError(const char* message, |
549 Vector<Handle<Object> > args); | 557 Vector<Handle<Object> > args); |
550 Handle<Object> NewRangeError(Handle<String> message); | 558 Handle<Object> NewRangeError(Handle<String> message); |
551 | 559 |
552 Handle<Object> NewInvalidStringLengthError() { | 560 Handle<Object> NewInvalidStringLengthError() { |
553 return NewRangeError("invalid_string_length", | 561 return NewRangeError("invalid_string_length", |
554 HandleVector<Object>(NULL, 0)); | 562 HandleVector<Object>(NULL, 0)); |
555 } | 563 } |
556 | 564 |
557 Handle<Object> NewSyntaxError(const char* message, Handle<JSArray> args); | 565 Handle<Object> NewSyntaxError(const char* message, Handle<JSArray> args); |
558 Handle<Object> NewSyntaxError(Handle<String> message); | 566 Handle<Object> NewSyntaxError(Handle<String> message); |
559 | 567 |
560 Handle<Object> NewReferenceError(const char* message, | 568 Handle<Object> NewReferenceError(const char* message, |
561 Vector<Handle<Object> > args); | 569 Vector<Handle<Object> > args); |
562 Handle<Object> NewReferenceError(const char* message, Handle<JSArray> args); | 570 Handle<Object> NewReferenceError(const char* message, Handle<JSArray> args); |
563 Handle<Object> NewReferenceError(Handle<String> message); | 571 Handle<Object> NewReferenceError(Handle<String> message); |
564 | 572 |
565 Handle<Object> NewEvalError(const char* message, | 573 Handle<Object> NewEvalError(const char* message, |
566 Vector<Handle<Object> > args); | 574 Vector<Handle<Object> > args); |
567 | 575 |
568 Handle<Object> NewError(const char* maker, | |
569 MessageTemplate::Template template_index, | |
570 Handle<Object> arg0, Handle<Object> arg1, | |
571 Handle<Object> arg2); | |
572 | |
573 Handle<Object> NewError(MessageTemplate::Template template_index, | |
574 Handle<Object> arg0 = Handle<Object>(), | |
575 Handle<Object> arg1 = Handle<Object>(), | |
576 Handle<Object> arg2 = Handle<Object>()); | |
577 | |
578 Handle<Object> NewTypeError(MessageTemplate::Template template_index, | |
579 Handle<Object> arg0 = Handle<Object>(), | |
580 Handle<Object> arg1 = Handle<Object>(), | |
581 Handle<Object> arg2 = Handle<Object>()); | |
582 | |
583 Handle<Object> NewEvalError(MessageTemplate::Template template_index, | |
584 Handle<Object> arg0 = Handle<Object>(), | |
585 Handle<Object> arg1 = Handle<Object>(), | |
586 Handle<Object> arg2 = Handle<Object>()); | |
587 | |
588 Handle<String> NumberToString(Handle<Object> number, | 576 Handle<String> NumberToString(Handle<Object> number, |
589 bool check_number_string_cache = true); | 577 bool check_number_string_cache = true); |
590 | 578 |
591 Handle<String> Uint32ToString(uint32_t value) { | 579 Handle<String> Uint32ToString(uint32_t value) { |
592 return NumberToString(NewNumberFromUint(value)); | 580 return NumberToString(NewNumberFromUint(value)); |
593 } | 581 } |
594 | 582 |
595 Handle<JSFunction> InstallMembers(Handle<JSFunction> function); | 583 Handle<JSFunction> InstallMembers(Handle<JSFunction> function); |
596 | 584 |
597 #define ROOT_ACCESSOR(type, name, camel_name) \ | 585 #define ROOT_ACCESSOR(type, name, camel_name) \ |
(...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
740 // Reinitialize a JSProxy into an (empty) JS object of respective type and | 728 // Reinitialize a JSProxy into an (empty) JS object of respective type and |
741 // size, but keeping the original prototype. The receiver must have at least | 729 // size, but keeping the original prototype. The receiver must have at least |
742 // the size of the new object. The object is reinitialized and behaves as an | 730 // the size of the new object. The object is reinitialized and behaves as an |
743 // object that has been freshly allocated. | 731 // object that has been freshly allocated. |
744 void ReinitializeJSProxy(Handle<JSProxy> proxy, InstanceType type, int size); | 732 void ReinitializeJSProxy(Handle<JSProxy> proxy, InstanceType type, int size); |
745 }; | 733 }; |
746 | 734 |
747 } } // namespace v8::internal | 735 } } // namespace v8::internal |
748 | 736 |
749 #endif // V8_FACTORY_H_ | 737 #endif // V8_FACTORY_H_ |
OLD | NEW |