data:image/s3,"s3://crabby-images/f9239/f9239057920875a3e01c200fe17ccc83c6c8ab5a" alt="ASP.NET Core MVC 2.0 Cookbook"
上QQ阅读APP看书,第一时间看更新
How to do it...
- Let's download the SDK and extend the compiler, installing the VS extension, .NET Compiler Platform SDK, by going through the Tools | Extensions and Updates menu, searching for Roslyn SDK:
data:image/s3,"s3://crabby-images/8d199/8d1996a00ba74436bb195fa34565ccfed47e2105" alt=""
- We can now download the .NET Compiler Platform SDK templates as a .vsix file, which gives us all the available project templates to create an analyzer:
data:image/s3,"s3://crabby-images/87d99/87d9939aaac72ef921786bdb54c17e35efea2946" alt=""
- We can now use the template projects in New Project | Visual C# | Extensibility | Stand-Alone Code Analysis Tool.
- Let's open a new console application for an Extensibility project:
data:image/s3,"s3://crabby-images/e8788/e8788be39680b462787a1a8eaf905e8df63fc3f3" alt=""
This console application will access the Roslyn API, with which we will be able to use the Syntax Tree API.
- Let's now create a SyntaxTree, which is simply a class represented by a tree structure of elements using the SyntaxTree type:
data:image/s3,"s3://crabby-images/69630/696306ad60e15f2161e67b61f8ff4103771e3f30" alt=""
This type has a method named ParseText, which will parse a string where a class is written:
data:image/s3,"s3://crabby-images/c6bed/c6bed6d708d57064a7b8878ae1e8ca9968230716" alt=""
- Let's write this piece of code:
data:image/s3,"s3://crabby-images/38562/3856292862fba57139e52f0b92638d8cb3d781ef" alt=""
The GetRoot method will give us the root of the tree.
- Using Ctrl + F5, we see the result.
- Now, thanks to the SyntaxFactory type, let's create the same class by creating a SyntaxTree with the Syntax API:
data:image/s3,"s3://crabby-images/4b53c/4b53c6d21d321cf1be357ddf5d25517faae07214" alt=""
- With the SyntaxFactory.ClassDeclaration method, we create the class name:
data:image/s3,"s3://crabby-images/7a66e/7a66e6783c22fc7ad28047a6617e6608116001d8" alt=""
- The WithMembers method allows us to create members of this class:
data:image/s3,"s3://crabby-images/ee4fe/ee4fe5b8c6b1d894c0e0afa91073715724845fdb" alt=""
- Now we create a method named Bar with void as the return type.
- The WithBody method and its SyntaxFactory.Block parameter help us to add an empty block to the Bar method:
data:image/s3,"s3://crabby-images/5fe0f/5fe0f805c1183908babf539077489191972b896e" alt=""
- The NormalizeWithespace method will add indentation and spaces to make this class more readable:
data:image/s3,"s3://crabby-images/58e50/58e50b0b610605e066ae0689c2f1ab6b1c9b7dd1" alt=""
- Let's press Ctrl + F5 to see the result of our code, putting the variable representing the Syntax Tree as the parameter of Console.WriteLine:
data:image/s3,"s3://crabby-images/96ca8/96ca8c1bbf1ce44346e4115c683d5401664595cf" alt=""