mirror of
				https://github.com/tc39/test262.git
				synced 2025-10-26 17:23:54 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			72 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // This file was procedurally generated from the following sources:
 | |
| // - src/class-elements/private-static-method-name.case
 | |
| // - src/class-elements/default/cls-expr.template
 | |
| /*---
 | |
| description: Private static methods have name property properly configured (field definitions in a class expression)
 | |
| esid: prod-FieldDefinition
 | |
| features: [class-static-methods-private, class]
 | |
| flags: [generated]
 | |
| info: |
 | |
|     Updated Productions
 | |
| 
 | |
|     ClassElement : MethodDefinition
 | |
|       1. Return ClassElementEvaluation of MethodDefinition with arguments ! Get(homeObject, "prototype"),enumerable, and "prototype".
 | |
| 
 | |
|     ClassElement : static MethodDefinition
 | |
|       1. Return ClassElementEvaluation of MethodDefinition with arguments homeObject, enumerable and "static".
 | |
| 
 | |
|     MethodDefinition : ClassElementName( UniqueFormalParameters ) { FunctionBody }
 | |
|       1. Let methodDef be DefineMethod of MethodDefinition with argument homeObject.
 | |
|       2. ReturnIfAbrupt(methodDef).
 | |
|       3. Perform ? DefineOrdinaryMethod(methodDef.[[Key]], homeObject, methodDef.[[Closure]], _enumerable).
 | |
| 
 | |
|     ClassElement : MethodDefinition
 | |
|     ClassElement : static MethodDefinition
 | |
|       1. Perform ? PropertyDefinitionEvaluation with parameters object and enumerable.
 | |
|       2. Return empty.
 | |
| 
 | |
|     MethodDefinition : ClassElementName (UniqueFormalParameters) { FunctionBody }
 | |
|       1. Let propKey be the result of evaluating ClassElementName.
 | |
|       ...
 | |
|       8. Let closure be FunctionCreate(kind, UniqueFormalParameters, FunctionBody, scope, privateScope, strict, prototype).
 | |
|       9. Perform MakeMethod(closure, object).
 | |
|       10. Return the Record{[[Key]]: propKey, [[Closure]]: closure}.
 | |
| 
 | |
|     ClassElementName : PrivateIdentifier
 | |
|       1. Let bindingName be StringValue of PrivateIdentifier.
 | |
|       ...
 | |
|       5. If scopeEnvRec's binding for bindingName is uninitialized,
 | |
|         a. Let field be NewPrivateName(bindingName).
 | |
|         b. Perform ! scopeEnvRec.InitializeBinding(bindingName, field).
 | |
|       6. Otherwise,
 | |
|         a. Let field be scopeEnvRec.GetBindingValue(bindingName).
 | |
|       7. Assert: field.[[Description]] is bindingName.
 | |
|       8. Return field.
 | |
| 
 | |
|     DefineOrdinaryMethod(key, homeObject, closure, enumerable)
 | |
|       1. Perform SetFunctionName(closure, key).
 | |
|       2. If key is a Private Name,
 | |
|         a. Assert: key does not have a [[Kind]] field.
 | |
|         b. Set key.[[Kind]] to "method".
 | |
|         c. Set key.[[Value]] to closure.
 | |
|         d. Set key.[[Brand]] to homeObject.
 | |
|       3. Else,
 | |
|         a. Let desc be the PropertyDescriptor{[[Value]]: closure, [[Writable]]: true, [[Enumerable]]: enumerable, [[Configurable]]: true}.
 | |
|         b. Perform ? DefinePropertyOrThrow(homeObject, key, desc).
 | |
| 
 | |
| ---*/
 | |
| 
 | |
| 
 | |
| var C = class {
 | |
|   static #method() {
 | |
|     return 'Test262';
 | |
|   };
 | |
| 
 | |
|   static getPrivateMethod() {
 | |
|     return this.#method;
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| assert.sameValue(C.getPrivateMethod().name, "#method");
 |