Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Commit6cc3227

Browse files
committed
Do not generate logical type names like "MyNamespace.Test,"
1 parentb40d937 commit6cc3227

File tree

2 files changed

+13
-4
lines changed

2 files changed

+13
-4
lines changed

‎src/fsharp/FSharp.Compiler.Unittests/ManglingNameOfProvidedTypes.fs‎

Lines changed: 8 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,7 @@ type ManglingNamesOfProvidedTypesWithSingleParameter() =
1919
memberthis.MangleWithDefaultValue()=
2020
letmangled=
2121
PrettyNaming.computeMangledNameWithoutDefaultArgValues("MyNamespace.Test",[|"xyz"|],[|"Foo", Some"xyz"|])
22-
Assert.AreEqual("MyNamespace.Test,", mangled)
22+
Assert.AreEqual("MyNamespace.Test", mangled)
2323

2424
[<Test>]
2525
memberthis.DemangleNonDefaultValue()=
@@ -29,11 +29,16 @@ type ManglingNamesOfProvidedTypesWithSingleParameter() =
2929

3030
[<Test>]
3131
memberthis.DemangleDefaultValue()=
32-
// If all provided parameters are the default value demangling fails - see #98
3332
letname,parameters= PrettyNaming.demangleProvidedTypeName"MyNamespace.Test,"
3433
Assert.AreEqual("MyNamespace.Test", name)
3534
Assert.AreEqual([||], parameters)
3635

36+
[<Test>]
37+
memberthis.DemangleNewDefaultValue()=
38+
letname,parameters= PrettyNaming.demangleProvidedTypeName"MyNamespace.Test"
39+
Assert.AreEqual("MyNamespace.Test", name)
40+
Assert.AreEqual([||], parameters)
41+
3742
[<TestFixture>]
3843
typeManglingNamesOfProvidedTypesWithMultipleParameter()=
3944

@@ -53,7 +58,7 @@ type ManglingNamesOfProvidedTypesWithMultipleParameter() =
5358
("MyNamespace.Test",[|"xyz";"abc"|],
5459
[|"Foo", Some"xyz"
5560
"Foo2", Some"abc"|])
56-
Assert.AreEqual("MyNamespace.Test,", mangled)
61+
Assert.AreEqual("MyNamespace.Test", mangled)
5762

5863
[<Test>]
5964
memberthis.DemangleMultiParameter()=

‎src/fsharp/PrettyNaming.fs‎

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -462,7 +462,11 @@ module internal Microsoft.FSharp.Compiler.PrettyNaming
462462
nonDefaultArgs
463463
|> Array.map mangleStaticStringArg
464464
|> String.concat","
465-
typeLogicalName+","+nonDefaultArgsText
465+
466+
if nonDefaultArgsText=""then
467+
typeLogicalName
468+
else
469+
typeLogicalName+","+ nonDefaultArgsText
466470

467471

468472
letcomputeMangledNameWithoutDefaultArgValues(nm,staticArgs,defaultArgValues)=

0 commit comments

Comments
 (0)

[8]ページ先頭

©2009-2025 Movatter.jp