From e00bf96705f79325556b0fcd137ec6422b9f2b5a Mon Sep 17 00:00:00 2001 From: "Stefan J. Wernli" Date: Fri, 6 Dec 2024 11:39:23 -0800 Subject: [PATCH] Use `` for auto-generated name It's come up a few times that having an easy way to differentiate lambdas would be helpful, and this change updates the name the we use for auto-generated items from lambdas to use a name that can't normally be created in Q# so we know for a fact it won't overlap with any other items. --- compiler/qsc_frontend/src/closure.rs | 2 +- compiler/qsc_frontend/src/lower/tests.rs | 32 +++++++++++------------ compiler/qsc_passes/src/spec_gen/tests.rs | 6 ++--- 3 files changed, 20 insertions(+), 20 deletions(-) diff --git a/compiler/qsc_frontend/src/closure.rs b/compiler/qsc_frontend/src/closure.rs index 62bd69b1fb..98bbb0f8aa 100644 --- a/compiler/qsc_frontend/src/closure.rs +++ b/compiler/qsc_frontend/src/closure.rs @@ -125,7 +125,7 @@ pub(super) fn lift( name: Ident { id: assigner.next_node(), span, - name: "lambda".into(), + name: "".into(), }, generics: Vec::new(), input, diff --git a/compiler/qsc_frontend/src/lower/tests.rs b/compiler/qsc_frontend/src/lower/tests.rs index 408fb42c7e..f69873a75c 100644 --- a/compiler/qsc_frontend/src/lower/tests.rs +++ b/compiler/qsc_frontend/src/lower/tests.rs @@ -963,7 +963,7 @@ fn lambda_function_empty_closure() { Item 2 [57-67] (Internal): Parent: 1 Callable 15 [57-67] (function): - name: Ident 16 [57-67] "lambda" + name: Ident 16 [57-67] "" input: Pat 14 [57-67] [Type (Int,)]: Tuple: Pat 9 [57-58] [Type Int]: Bind: Ident 10 [57-58] "x" output: Int @@ -1025,7 +1025,7 @@ fn lambda_function_empty_closure_passed() { Item 3 [93-103] (Internal): Parent: 2 Callable 25 [93-103] (function): - name: Ident 26 [93-103] "lambda" + name: Ident 26 [93-103] "" input: Pat 24 [93-103] [Type (Int,)]: Tuple: Pat 19 [93-94] [Type Int]: Bind: Ident 20 [93-94] "x" output: Int @@ -1081,7 +1081,7 @@ fn lambda_function_closure() { Item 2 [76-86] (Internal): Parent: 1 Callable 21 [76-86] (function): - name: Ident 22 [76-86] "lambda" + name: Ident 22 [76-86] "" input: Pat 19 [76-86] [Type (Int, Int)]: Tuple: Pat 20 [53-54] [Type Int]: Bind: Ident 18 [53-54] "x" Pat 13 [76-77] [Type Int]: Bind: Ident 14 [76-77] "y" @@ -1138,7 +1138,7 @@ fn lambda_function_closure_repeated_var() { Item 2 [76-90] (Internal): Parent: 1 Callable 23 [76-90] (function): - name: Ident 24 [76-90] "lambda" + name: Ident 24 [76-90] "" input: Pat 21 [76-90] [Type (Int, Int)]: Tuple: Pat 22 [53-54] [Type Int]: Bind: Ident 20 [53-54] "x" Pat 13 [76-77] [Type Int]: Bind: Ident 14 [76-77] "y" @@ -1209,7 +1209,7 @@ fn lambda_function_closure_passed() { Item 3 [120-130] (Internal): Parent: 2 Callable 31 [120-130] (function): - name: Ident 32 [120-130] "lambda" + name: Ident 32 [120-130] "" input: Pat 29 [120-130] [Type (Int, Int)]: Tuple: Pat 30 [101-102] [Type Int]: Bind: Ident 28 [101-102] "x" Pat 23 [120-121] [Type Int]: Bind: Ident 24 [120-121] "y" @@ -1283,7 +1283,7 @@ fn lambda_function_nested_closure() { Item 3 [172-190] (Internal): Parent: 2 Callable 51 [172-190] (function): - name: Ident 52 [172-190] "lambda" + name: Ident 52 [172-190] "" input: Pat 47 [172-190] [Type (Int, Int, Int, Int)]: Tuple: Pat 48 [111-112] [Type Int]: Bind: Ident 44 [111-112] "a" Pat 49 [130-131] [Type Int]: Bind: Ident 45 [130-131] "b" @@ -1306,7 +1306,7 @@ fn lambda_function_nested_closure() { Item 4 [130-200] (Internal): Parent: 2 Callable 59 [130-200] (function): - name: Ident 60 [130-200] "lambda" + name: Ident 60 [130-200] "" input: Pat 57 [130-200] [Type (Int, Int)]: Tuple: Pat 58 [111-112] [Type Int]: Bind: Ident 56 [111-112] "a" Pat 25 [130-131] [Type Int]: Bind: Ident 26 [130-131] "b" @@ -1382,7 +1382,7 @@ fn lambda_operation_empty_closure() { Item 3 [137-144] (Internal): Parent: 2 Callable 27 [137-144] (operation): - name: Ident 28 [137-144] "lambda" + name: Ident 28 [137-144] "" input: Pat 26 [137-144] [Type (Qubit,)]: Tuple: Pat 23 [137-138] [Type Qubit]: Bind: Ident 24 [137-138] "q" output: Unit @@ -1465,7 +1465,7 @@ fn lambda_operation_closure() { Item 4 [199-215] (Internal): Parent: 3 Callable 35 [199-215] (operation): - name: Ident 36 [199-215] "lambda" + name: Ident 36 [199-215] "" input: Pat 33 [199-215] [Type (Qubit, Unit)]: Tuple: Pat 34 [174-175] [Type Qubit]: Bind: Ident 32 [174-175] "q" Pat 28 [199-201] [Type Unit]: Unit @@ -1543,7 +1543,7 @@ fn lambda_adj() { Item 4 [138-147] (Internal): Parent: 3 Callable 27 [138-147] (operation): - name: Ident 28 [138-147] "lambda" + name: Ident 28 [138-147] "" input: Pat 26 [138-147] [Type (Qubit,)]: Tuple: Pat 21 [138-139] [Type Qubit]: Bind: Ident 22 [138-139] "q" output: Unit @@ -1611,7 +1611,7 @@ fn partial_app_one_hole() { Item 3 [99-108] (Internal): Parent: 2 Callable 37 [99-108] (function): - name: Ident 38 [99-108] "lambda" + name: Ident 38 [99-108] "" input: Pat 35 [99-108] [Type (Int, Int)]: Tuple: Pat 36 [106-107] [Type Int]: Bind: Ident 34 [106-107] "arg" Pat 24 [103-104] [Type Int]: Bind: Ident 23 [103-104] "hole" @@ -1679,7 +1679,7 @@ fn partial_app_two_holes() { Item 3 [99-108] (Internal): Parent: 2 Callable 33 [99-108] (function): - name: Ident 34 [99-108] "lambda" + name: Ident 34 [99-108] "" input: Pat 32 [99-108] [Type ((Int, Int),)]: Tuple: Pat 30 [102-108] [Type (Int, Int)]: Tuple: Pat 24 [103-104] [Type Int]: Bind: Ident 23 [103-104] "hole" @@ -1752,7 +1752,7 @@ fn partial_app_nested_tuple() { Item 3 [130-152] (Internal): Parent: 2 Callable 52 [130-152] (function): - name: Ident 53 [130-152] "lambda" + name: Ident 53 [130-152] "" input: Pat 50 [130-152] [Type (Double, (Int, (Bool, String), Result))]: Tuple: Pat 51 [141-144] [Type Double]: Bind: Ident 49 [141-144] "arg" Pat 47 [133-152] [Type (Int, (Bool, String), Result)]: Tuple: @@ -1836,7 +1836,7 @@ fn partial_app_nested_tuple_singleton_unwrap() { Item 3 [130-155] (Internal): Parent: 2 Callable 56 [130-155] (function): - name: Ident 57 [130-155] "lambda" + name: Ident 57 [130-155] "" input: Pat 53 [130-155] [Type (Bool, Double, (Int, String, Result))]: Tuple: Pat 54 [138-142] [Type Bool]: Bind: Ident 51 [138-142] "arg" Pat 55 [144-147] [Type Double]: Bind: Ident 52 [144-147] "arg" @@ -2091,7 +2091,7 @@ fn partial_app_bound_to_non_arrow_ty() { Item 3 [113-122] (Internal): Parent: 2 Callable 37 [113-122] (function): - name: Ident 38 [113-122] "lambda" + name: Ident 38 [113-122] "" input: Pat 35 [113-122] [Type (Int, Int)]: Tuple: Pat 36 [117-118] [Type Int]: Bind: Ident 34 [117-118] "arg" Pat 30 [120-121] [Type Int]: Bind: Ident 29 [120-121] "hole" @@ -2366,7 +2366,7 @@ fn lambda_with_invalid_free_variable() { Item 2 [52-67] (Internal): Parent: 1 Callable 12 [52-67] (operation): - name: Ident 13 [52-67] "lambda" + name: Ident 13 [52-67] "" input: Pat 11 [52-67] [Type (Unit,)]: Tuple: Pat 7 [52-54] [Type Unit]: Unit output: Unit diff --git a/compiler/qsc_passes/src/spec_gen/tests.rs b/compiler/qsc_passes/src/spec_gen/tests.rs index 63d7bf9799..b215033b71 100644 --- a/compiler/qsc_passes/src/spec_gen/tests.rs +++ b/compiler/qsc_passes/src/spec_gen/tests.rs @@ -1906,7 +1906,7 @@ fn lambda_adj_calls_adj() { Item 4 [138-147] (Internal): Parent: 3 Callable 27 [138-147] (operation): - name: Ident 28 [138-147] "lambda" + name: Ident 28 [138-147] "" input: Pat 26 [138-147] [Type (Qubit,)]: Tuple: Pat 21 [138-139] [Type Qubit]: Bind: Ident 22 [138-139] "q" output: Unit @@ -2032,7 +2032,7 @@ fn op_array_forget_functors_with_lambdas() { Item 5 [270-281] (Internal): Parent: 4 Callable 35 [270-281] (operation): - name: Ident 36 [270-281] "lambda" + name: Ident 36 [270-281] "" input: Pat 34 [270-281] [Type (Qubit,)]: Tuple: Pat 29 [270-271] [Type Qubit]: Bind: Ident 30 [270-271] "q" output: Unit @@ -2048,7 +2048,7 @@ fn op_array_forget_functors_with_lambdas() { Item 6 [283-294] (Internal): Parent: 4 Callable 47 [283-294] (operation): - name: Ident 48 [283-294] "lambda" + name: Ident 48 [283-294] "" input: Pat 46 [283-294] [Type (Qubit,)]: Tuple: Pat 41 [283-284] [Type Qubit]: Bind: Ident 42 [283-284] "q" output: Unit