mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 02:12:07 +00:00 
			
		
		
		
	 0255c8d976
			
		
	
	
		0255c8d976
		
	
	
	
	
		
			
			The auto naming of function expressions is a purely syntactic decision, so shouldn't be decided based on the dynamic type of an assignment. This moves the decision making into the parser. One icky hack is that we add a field to FunctionExpression to indicate whether we can autoname. The real solution is to actually generate a CompoundExpression node so that the parser can make the correct decision, however this would have a potentially significant run time cost. This does not correct the behaviour for class expressions. Patch from Anonymous.
		
			
				
	
	
		
			64 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| test("basic functionality", () => {
 | |
|     expect(function () {}.name).toBe("");
 | |
| 
 | |
|     function bar() {}
 | |
|     expect(bar.name).toBe("bar");
 | |
|     expect((bar.name = "baz")).toBe("baz");
 | |
|     expect(bar.name).toBe("bar");
 | |
| });
 | |
| 
 | |
| test("function assigned to variable", () => {
 | |
|     let foo = function () {};
 | |
|     expect(foo.name).toBe("foo");
 | |
|     expect((foo.name = "bar")).toBe("bar");
 | |
|     expect(foo.name).toBe("foo");
 | |
| 
 | |
|     let a, b;
 | |
|     a = b = function () {};
 | |
|     expect(a.name).toBe("b");
 | |
|     expect(b.name).toBe("b");
 | |
| });
 | |
| 
 | |
| test("functions in array assigned to variable", () => {
 | |
|     const arr = [function () {}, function () {}, function () {}];
 | |
|     expect(arr[0].name).toBe("");
 | |
|     expect(arr[1].name).toBe("");
 | |
|     expect(arr[2].name).toBe("");
 | |
| });
 | |
| 
 | |
| test("functions in objects", () => {
 | |
|     let f;
 | |
|     let o = { a: function () {} };
 | |
| 
 | |
|     expect(o.a.name).toBe("a");
 | |
|     f = o.a;
 | |
|     expect(f.name).toBe("a");
 | |
|     expect(o.a.name).toBe("a");
 | |
| 
 | |
|     o = { ...o, b: f };
 | |
|     expect(o.a.name).toBe("a");
 | |
|     expect(o.b.name).toBe("a");
 | |
| 
 | |
|     o.c = function () {};
 | |
|     expect(o.c.name).toBe("c");
 | |
| });
 | |
| 
 | |
| test("names of native functions", () => {
 | |
|     expect(console.debug.name).toBe("debug");
 | |
|     expect((console.debug.name = "warn")).toBe("warn");
 | |
|     expect(console.debug.name).toBe("debug");
 | |
| });
 | |
| 
 | |
| test("no invalid autonaming of anonymous functions", () => {
 | |
|     // prettier-ignore
 | |
|     let f1 = (function () {});
 | |
|     expect(f1.name).toBe("");
 | |
|     let f2 = f1;
 | |
|     expect(f2.name).toBe("");
 | |
|     let f3;
 | |
|     f3 = false || f2;
 | |
|     expect(f3.name).toBe("");
 | |
|     let f4 = false;
 | |
|     f4 ||= function () {};
 | |
|     expect(f4.name).toBe("");
 | |
| });
 |