Problem
You are lazy.
Solution
Templates!
- Let’s start with creating a project structure we are happy with. You can either use your own, or use Company.Service
data:image/s3,"s3://crabby-images/66355/6635540ed2587b633eb218ad6ad4a6753f6121ee" alt=""
- Add the .template.config folder in the directory where you placed your solution, and inside that folder, add the template.json file. If you cloned repository, it’s already there
- NOTE: You have to use those exact names
- If you switch to folder view in your visual studio, you will see something like this:
data:image/s3,"s3://crabby-images/45abe/45abecefcb80a75b422d45351ebde1ec866b6af7" alt=""
- Modify template.json
{
"$schema": "http://json.schemastore.org/template",
"author": "Mario Grd",
"classifications": [ "Web" ],
"identity": "Company.Service",
"name": "Company.Service",
"shortName": "company-service",
"preferNameDirectory": true,
"sourceName": "Company.Service",
"tags": {
"language": "C#",
"type": "solution"
}
}
- This is the minimum information required for template.json. More information about json fields.
- The most important parts are:
- shortName -> name we are going to use to generate our projects
- sourceName -> this is what will be replaced in template. For example, if you have Company.Service.sln and when you generate new project named Company.Cars – solution file will be now named Company.Cars.sln. This applies across whole project
- preferNameDirectory -> will create folder for you where solution will be placed
- Open your terminal in a folder where you placed your solution.
data:image/s3,"s3://crabby-images/9e49b/9e49b0761918520d071b032217eec35f6db0f47f" alt=""
- I’m using Powershell inside windows terminal.
data:image/s3,"s3://crabby-images/9d337/9d33725bd2443bb4dc65530e39c96a1fb1338128" alt=""
- OH MY POSH! It looks sooo nice!
- First, let’s see what templates we have
dotnet new --list
data:image/s3,"s3://crabby-images/af535/af53566dfc87b400543629a2a1a95ce792d636f8" alt=""
- Now, lets try to install our custom template.
dotnet new -i .
- This command will look for the .template.config folder and look for the template.json inside it.
- Don’t forget the dot at the end!
- After running command, you should see something like this
data:image/s3,"s3://crabby-images/eab7c/eab7c41e0d89acfb28eeb9230b897015afb58478" alt=""
- Now, let’s double check if there is our new template in that list
dotnet new --list
data:image/s3,"s3://crabby-images/bd291/bd291f13421db5e40185c45cbe616c03b6dcec08" alt=""
- Alright, it’s here. Now lets try to generate project with name Company.Success
- Move to a folder where you usually keep your projects, for me, it’s:
data:image/s3,"s3://crabby-images/9d048/9d048021f3877166773178dcb29a8bb498b4c863" alt=""
- Open terminal and run:
dotnet new company-service --name Company.Success
- Do you remember sourceName from template.json? That value will be used as placeholder that will be replaced with anything that is after the –name parameter (Company.Success)
data:image/s3,"s3://crabby-images/2be07/2be07bce2d20a7b62782eee1d1f116c92dfdb667" alt=""
- Let’s look at our new generated project. Go to Company.Success folder and open it in Visual Studio
data:image/s3,"s3://crabby-images/2389a/2389a0207fd5549bf6d333c3775d91accfe649e1" alt=""
- That’s it. You can now set up Company.Success as your startup project and run it.
Benefits?
- You can remain being lazy.