There are two major categories of work that will happen here: active feature development and quality improvements. Some features are experimental. All submissions need to meet high quality and design expectations. Submissions adding new functionality require
extra analysis and design, and remember to always start a design discussion before spending significant effort.
- Performance-related changes, mostly around reducing allocations, as part of an effort to make typing in Visual Studio as pause-free as possible.
- Explore the use of an alternative PDB writer implementation that will allow more parallelism in the emit pipeline.
- Increase the test coverage provided by our open source test suites.
- Remove the core compiler's dependency on the full .NET framework allowing the use of the Compilation data type on platforms like WinRT.
- Flesh out the XML documentation comments on the public API.
- Confirm that the public API does appropriate argument validation.
- Ensure that the collection types used across the public API surface are rational.
- Refine the Diagnostics API, which provides live code analysis as you type.
- Improve the performance of running analyzers from the command-line and in Visual Studio.
- Write more of the FxCop rules as source-based diagnostic analyzers. There are 350+ FxCop rules – feedback is welcome to prioritize which of these should be implemented first.
- Develop flow analysis APIs and provide easy ways to write analyzers that can perform flow analysis.
Interactive (Scripting and REPL)
- Finishing the language semantics for various expressions at the top level.
- Review and refine the design of the REPL window.
- Review and refine the design of the scripting API.
- Find All References performance
- Rename conflict-detection improvements