This article applies to Visual Studio 2015. If you're looking for the latest Visual Studio documentation, use the version selector at the top left. We recommend upgrading to Visual Studio 2019. Download it here
Custom tools let you associate a tool with an item in a project and run that tool whenever the file is saved. Certain custom tools, sometimes referred to as single-file generators, are frequently used to implement translators that generate code from data and vice versa. For example, single-file generators create Visual C# and Visual Basic source code out of the .settings and .resx files. The generated source code provides strongly-typed access to the data in the .settings and .resx files. The Visual C# and Visual Basic project types support custom tools; Visual C++ project types do not. Your own project types can also support custom tools.
Custom tools are registered components that implement the
Custom tools are associated with a
ProjectItem interface object, and are like designers and editors. A custom tool takes the file represented by a
ProjectItem as input and writes a new file whose file name is provided by the
In This Section
Determining the Default Namespace of a Project
Describes how to determine the correct namespace based on the language being used.
Registering Single File Generators
Provides descriptions for all the registry entries for a custom tool.
Exposing Types to Visual Designers
Explains how project systems provide support for visual designers to access generated classes and types through temporary portable executable (PE) files.
Persisting the Property of a Project Item
Shows how to persist a project item property, such as the author of a source file, in the project file.
ProjectItem interface, which represents an item in a project.
Provides details about the
DefaultExtension method, which retrieves the file name extension that is given to the output file name.
Describes how to use Visual Studio projects and solutions to organize code files and resource files, and how to implement source control.