teach fsharp to dotnet new
- add --lang <LANG> [C#|F#] with alias (csharp/cs) - renamed template directories, format "LANGUAGE-TEMPLATE" - add --type <TYPE> default to first template of the language ( "Console" ) - show all avaiable types, if invalid argument --type ``` Unrecognized type: notexists Avaiable types for F# : - Console ```
This commit is contained in:
parent
231cc037fd
commit
91b37f82b4
9 changed files with 98 additions and 12 deletions
10
src/Microsoft.DotNet.Tools.New/FSharp_Console/NuGet.Config
Normal file
10
src/Microsoft.DotNet.Tools.New/FSharp_Console/NuGet.Config
Normal file
|
@ -0,0 +1,10 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<configuration>
|
||||
<packageSources>
|
||||
<!--To inherit the global NuGet package sources remove the <clear/> line below -->
|
||||
<clear />
|
||||
<add key="dotnet-core" value="https://www.myget.org/F/dotnet-core/api/v3/index.json" />
|
||||
<add key="api.nuget.org" value="https://api.nuget.org/v3/index.json" />
|
||||
<add key="fsharp-daily" value="https://www.myget.org/F/fsharp-daily/api/v3/index.json" />
|
||||
</packageSources>
|
||||
</configuration>
|
9
src/Microsoft.DotNet.Tools.New/FSharp_Console/Program.fs
Normal file
9
src/Microsoft.DotNet.Tools.New/FSharp_Console/Program.fs
Normal file
|
@ -0,0 +1,9 @@
|
|||
// Learn more about F# at http://fsharp.org
|
||||
|
||||
open System
|
||||
|
||||
[<EntryPoint>]
|
||||
let main argv =
|
||||
printfn "Hello World!"
|
||||
printfn "%A" argv
|
||||
0 // return an integer exit code
|
20
src/Microsoft.DotNet.Tools.New/FSharp_Console/project.json
Normal file
20
src/Microsoft.DotNet.Tools.New/FSharp_Console/project.json
Normal file
|
@ -0,0 +1,20 @@
|
|||
{
|
||||
"version": "1.0.0-*",
|
||||
"compilationOptions": {
|
||||
"emitEntryPoint": true
|
||||
},
|
||||
|
||||
"compilerName": "fsc",
|
||||
"compileFiles": [
|
||||
"Program.fs"
|
||||
],
|
||||
|
||||
"dependencies": {
|
||||
"Microsoft.FSharp.Core.netcore": "1.0.0-alpha-151221",
|
||||
"NETStandard.Library": "1.0.0-rc2-23704"
|
||||
},
|
||||
|
||||
"frameworks": {
|
||||
"dnxcore50": { }
|
||||
}
|
||||
}
|
|
@ -24,13 +24,11 @@ namespace Microsoft.DotNet.Tools.New
|
|||
return parts[parts.Length - 2] + "." + parts[parts.Length - 1];
|
||||
}
|
||||
|
||||
public int CreateEmptyProject()
|
||||
public int CreateEmptyProject(string languageName, string templateDir)
|
||||
{
|
||||
var thisAssembly = typeof(Program).GetTypeInfo().Assembly;
|
||||
var resources = from resourceName in thisAssembly.GetManifestResourceNames()
|
||||
where resourceName.ToLowerInvariant().EndsWith(".cs")
|
||||
|| resourceName.ToLowerInvariant().EndsWith(".json")
|
||||
|| resourceName.ToLowerInvariant().EndsWith(".config")
|
||||
where resourceName.Contains(templateDir)
|
||||
select resourceName;
|
||||
|
||||
var resourceNameToFileName = new Dictionary<string, string>();
|
||||
|
@ -42,14 +40,14 @@ namespace Microsoft.DotNet.Tools.New
|
|||
resourceNameToFileName.Add(resourceName, fileName);
|
||||
if (File.Exists(fileName))
|
||||
{
|
||||
Reporter.Error.WriteLine($"Creating new project would override file {fileName}.");
|
||||
Reporter.Error.WriteLine($"Creating new {languageName} project would override file {fileName}.");
|
||||
hasFilesToOverride = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (hasFilesToOverride)
|
||||
{
|
||||
Reporter.Error.WriteLine("Creating new project failed.");
|
||||
Reporter.Error.WriteLine($"Creating new {languageName} project failed.");
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -64,7 +62,7 @@ namespace Microsoft.DotNet.Tools.New
|
|||
}
|
||||
}
|
||||
|
||||
Reporter.Output.WriteLine($"Created new project in {Directory.GetCurrentDirectory()}.");
|
||||
Reporter.Output.WriteLine($"Created new {languageName} project in {Directory.GetCurrentDirectory()}.");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -79,8 +77,44 @@ namespace Microsoft.DotNet.Tools.New
|
|||
app.Description = "Initializes empty project for .NET Platform";
|
||||
app.HelpOption("-h|--help");
|
||||
|
||||
var lang = app.Option("-l|--lang <LANGUAGE>", "Language of project [C#|F#]", CommandOptionType.SingleValue);
|
||||
var type = app.Option("-t|--type <TYPE>", "Type of project", CommandOptionType.SingleValue);
|
||||
|
||||
var dotnetNew = new Program();
|
||||
app.OnExecute(() => dotnetNew.CreateEmptyProject());
|
||||
app.OnExecute(() => {
|
||||
|
||||
var csharp = new { Name = "C#", Alias = new[] { "c#", "cs", "csharp" }, TemplatePrefix = "CSharp", Templates = new[] { "Console" } };
|
||||
var fsharp = new { Name = "F#", Alias = new[] { "f#", "fs", "fsharp" }, TemplatePrefix = "FSharp", Templates = new[] { "Console" } };
|
||||
|
||||
string languageValue = lang.Value() ?? csharp.Name;
|
||||
|
||||
var language = new[] { csharp, fsharp }
|
||||
.FirstOrDefault(l => l.Alias.Contains(languageValue, StringComparer.OrdinalIgnoreCase));
|
||||
|
||||
if (language == null)
|
||||
{
|
||||
Reporter.Error.WriteLine($"Unrecognized language: {languageValue}".Red());
|
||||
return -1;
|
||||
}
|
||||
|
||||
string typeValue = type.Value() ?? language.Templates.First();
|
||||
|
||||
string templateName = language.Templates.FirstOrDefault(t => StringComparer.OrdinalIgnoreCase.Equals(typeValue, t));
|
||||
if (templateName == null)
|
||||
{
|
||||
Reporter.Error.WriteLine($"Unrecognized type: {typeValue}".Red());
|
||||
Reporter.Error.WriteLine($"Avaiable types for {language.Name} :".Red());
|
||||
foreach (var t in language.Templates)
|
||||
{
|
||||
Reporter.Error.WriteLine($"- {t}".Red());
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
string templateDir = $"{language.TemplatePrefix}_{templateName}";
|
||||
|
||||
return dotnetNew.CreateEmptyProject(language.Name, templateDir);
|
||||
});
|
||||
|
||||
try
|
||||
{
|
||||
|
|
|
@ -13,16 +13,29 @@ The new command provides a convenient way to initalize a valid .NET Core project
|
|||
|
||||
This command is invoked in the context of a directory. When invoked, the command will result in two main artifacts being dropped to the directory:
|
||||
|
||||
1. A sample "Hello World" program that exists in `Program.cs` file.
|
||||
1. A sample "Hello World" program that exists in `Program.cs` ( or `Program.fs` ) file.
|
||||
2. A valid `project.json` file
|
||||
|
||||
After this, the project is ready to be compiled and/or edited further.
|
||||
|
||||
# Options
|
||||
|
||||
`-l`, `--lang [C#|F#]`
|
||||
Language of project. Defaults to `C#`. Also `csharp` ( `fsharp` ) or `cs` ( `fs` ) works.
|
||||
|
||||
# EXAMPLES
|
||||
|
||||
`dotnet new`
|
||||
|
||||
Drops a sample in the current directory.
|
||||
Drops a sample C# project in the current directory.
|
||||
|
||||
`dotnet new --lang f#`
|
||||
|
||||
Drops a sample F# project in the current directory.
|
||||
|
||||
`dotnet new --lang c#`
|
||||
|
||||
Drops a sample C# project in the current directory.
|
||||
|
||||
# SEE ALSO
|
||||
dotnet-run(1)
|
||||
|
|
|
@ -14,8 +14,8 @@
|
|||
"version": "1.0.0-*"
|
||||
}
|
||||
},
|
||||
"compileExclude": [ "Template/**" ],
|
||||
"resource": [ "Template/**" ],
|
||||
"compileExclude": [ "CSharp_Console/**", "FSharp_Console/**" ],
|
||||
"resource": [ "CSharp_Console/**", "FSharp_Console/**" ],
|
||||
"frameworks": {
|
||||
"dnxcore50": { }
|
||||
},
|
||||
|
|
Loading…
Reference in a new issue