I’ve updated the documentation for building a Docker container image for Visual Studio Build tools based on recent feedback that managed code may fail to run. In the case of MSBuild, you might see an error like,
Use Visual Studio for Mac to build apps for mobile, web, and the cloud with Xamarin and.NET Core, as well as games with Unity. Download the Current Release of Visual Studio for Mac To learn more about Visual Studio for Mac, see Mac System Requirements and Mac Platform Targeting and Compatibility.
C:BuildToolsMSBuild15.0binRoslynMicrosoft.CSharp.Core.targets(84,5): error MSB6003: The specified task executable “csc.exe” could not be run. Could not load file or assembly ‘System.IO.FileSystem, Version=4.0.1.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a’ or one of its dependencies. The system cannot find the file specified.
To resolve this, base your image on microsoft/dotnet-framework:4.7.1 so that it does not need to be installed. The image documentation has more details about how its various tags related to microsoft/windowsservercore if you intend to target a specific version of Windows Server Core.
The examples have also been updated to better collect and copy setup logs from a container should an error occur using a separate script file to handle install failures.
-->Developer Community |System Requirements |Compatibility |Distributable Code |Xamarin |Blogs |Servicing |
Note
If you are accessing this page from a non-English language version, and want to see the most up-to-date content, visit this Release Notes page in English. You can change the language of this page by clicking the globe icon in the page footer and selecting your desired language.
Use Visual Studio for Mac to build apps for mobile, web, and the cloud with Xamarin and .NET Core, as well as games with Unity.
Download the Current Release of Visual Studio for Mac
To learn more about Visual Studio for Mac, see Mac System Requirementsand Mac Platform Targeting and Compatibility.
To learn more about other related downloads, see the Downloads page.
Feedback
We would love to hear from you! You can report a problem through the Report a Problem option the Visual Studio for Mac IDE and track your feedback in the Developer Community portal. For suggestions,let us know through UserVoice.
Known Issues
Refer to the Known Issues section.
Release History
- July 23, 2018 – Visual Studio for Mac version 7.5.4
- June 19, 2018 – Visual Studio for Mac version 7.5.3
- May 30, 2018 – Visual Studio for Mac version 7.5.2
- May 15, 2018 – Visual Studio for Mac version 7.5.1
- May 7, 2018 – Visual Studio for Mac version 7.5 -- Read the blog post
Release Highlights
- We have continued to improve performance and stability in Visual Studio for Mac.
- Support for .editorconfig files has been added.
- We added new editor support for Razor, JavaScript, and TypeScript.
- We added support for the latest releases of .NET Core and C#, with .NET Core 2.1 Preview and C# version 7.2.
- It is now easier for Xamarin.Forms developers to build apps using .NET Standard.
- Includes support for Xcode 9.3.
- We added a new Android Device Manager.
- Azure Functions development has improved. We've introduced new Azure Function templates and we now have support for the .NET Core Preview SDK when using Azure Functions.
Visual Studio for Mac version 7.5 (7.5.0.1254)
released May 7, 2018
Top Issues Fixed in this Release
- New projects are now created using the .NET 4.7.1 framework.
- We fixed an issue that was causing VS 2017 for Mac to crash when quitting.
- We have fixed a number of Editor related issues.
Release in Detail
Installation and Setup
- Updated to use native networking APIs which should improve download success rate and speed, and work behind a proxy.
- Improved workflow for fixing Android home permissions.
- Improved accessibility with higher contrast and better VoiceOver navigation.
- Fixed an issue where download speed and progress did not reflect accurate status.
- Fixed an issue where Android components are not displayed, even if components are installed.
- Fixed an issue where the Android SDK Location was missing in Preferences after installation.
Performance
We are continuing our push to improve performance and reliability in the IDE. This release focuses on improving IDE startup time, which has decreased by as much as 50% for some users.
We're also fixing top issues and crashes as they come into the Developer Community site – please keep the feedback coming!
Performance fixes in this release include:
- Enabled concurrent execution of analyzers across the board, allowing for faster diagnostic squiggles reporting.
- Improved IDE startup timing by deferring shared template engine loading. This fixes issue #3492.
- Statically link in libxammac-system.a, instead of using the dylib, improving startup performance.
Source Code Editor
We've continued our effort on improving the C# source editor. This includes the following:
- We switched the code fixes, refactorings, and compiler errors backend to use the Roslyn engine. This improves the time it takes for the Quick Fix menu to popup and improves performance on typing.
- 'Generate overrides' option is now working as expected.
- Fixed an issue where characters are 'invisible' with line highlighting turned on, and hard to see when highlighting is off.
- Fixed an issue for users of certain languages, including Chinese and Japanese, where clicking away from the current line before committing the current preedit buffer would cause the line to unexpectedly un-indent.
- Fixed multi-line comment classifications are not working properly.
- Improved the visibility of search highlights in the text editor.
- Fixed an issue with Quick Info windows when you switch away from the current document.
- Fixed an issue with Intellisense for #if preprocessor directive.
- Fixed an issue where the syntax colorization of Enums was incorrect in the Monokai theme.
- Fixed a crash in the F# unused code highlighter.
- Fixed an issue where the text marker grays out code after repeated comment / uncomment actions.
- We have fixed an issue where the cursor position is shifted because of the bar with project name, opened file name and Visual Studio IDE type.
- Fixed an issue where Intellisense in Shared Projects seems to be broken.
- Fixed an issue where Find Reference would stop working in some classes.
- Global search is now initiated with selected text from the editor.
- Fixed Monokai color theme.
- The shortcuts for the document switcher are now configurable.
- The types from generated C# files are now available to the type system when installing a NuGet package that uses a package.config file.
- Fixed the document switcher if no documents or pads were open.
- We now use the cross platform menu for the Error and Task pad context menus.
Project System
- Updated the templating engine to fix problems with '@' characters in file names that are incorrectly encoded when creating the project.
- Support new lines in descriptions for templates using new templating engine.
- Allow the following options to be configured from a project template wizard:
- gitignore
- Create project directory
- Fixed an issue where saving a project with a file wildcard that had a Link that used MSBuild item metadata, as shown below, would result in the wildcard being removed and replaced with MSBuild items for each file included by the wildcard.
- Fixed an issue where project references would be not saved when adding or removing NuGet references.This would manifest as unpredictable build errors when creating new projects with NuGet packages in them, particularly Xamarin.Forms projects.
- We've fixed issues when overriding globs.
- We have fixed issues with projects that include files using wildcards will expand (and remove) wildcards upon save.
- We've fixed an issue that caused the incorrect Android target framework version to be stored in project.assets.json. If an Android project uses PackageReferences and the target framework is changed to 'Use Latest', it might result in the wrong MonoAndroid version being saved in the project.assets.json file. This could cause the build to fail after restoring with an error indicating the MonoAndroid version not being referenced.
- We fixed an issue where opening a solution with NetStandard library throws System.ArgumentNullException in Ide.Log.
- Fixed an issue when opening a solution, the last open files are not re-opened correctly.
NuGet
- We fixed an issue that was stopping users from expanding SDK and NuGet dependencies folder and viewing child dependencies.
- PackageReference projects will now restore after the target framework has changed.
Azure Functions
Azure Functions is now integrated into Visual Studio for Mac. We now have a New Function template dialog (Figure 1), along with support for the .NET Core Preview SDK for Azure Functions.
Function Templates enable you to quickly create new functions using the most common triggers and templates. When a new Azure Functions project is created, it includes an HttpTrigger function.
You can access these by creating a new Azure Functions project, right-clicking on your project, and choosing the Add > Add Function… menu.
.editorconfig
You can add an .editorconfig file to your project or codebase to enforce consistent coding styles for everyone that works in the codebase. These settings take precedence over global Visual Studio text editor settings. This means that you can tailor each codebase to use text editor settings that are specific to that project.
Web Development
Editor support for Razor, JavaScript, and TypeScript have been some of the top web developer requests we have heard. In this release, we are introducing new editors for each of these languages.
Razor
With official support for Razor, you now have syntax highlighting and IntelliSense while editing your C# in .cshtml files (Figure 2):
JavaScript and TypeScript
The JavaScript editor has been rewritten, and now provides the core editor experience, including smarter colorization, IntelliSense, and brace completion.
Support has also been added for TypeScript editing (Figure 3); providing the same colorization, IntelliSense, and editor experience as JavaScript.
.NET Core
Visual Studio for Mac version 7.5 will be the first official release supporting the .NET Core 2.1 Preview SDK. You can read all about the .NET Core 2.1 Preview release in the announcement blog post.
Some of the top improvements include: faster build performance, closing gaps in ASP.NET Core and EF Core, improving compatibility with .NET Framework, GDPR and Security, microservices, and Azure. We've also added support for C# 7.2 in this release.
- Visual Studio for Mac no longer installs the dev-tools tool as it is now included with the .NET Core 2.1 SDK, starting with Preview 2.
- We have fixed an issue that caused the browser not to open when running or debugging an ASP.NET Core 2.1 project if the .NET Core 2.1 Preview 2 SDK is installed. The ASP.NET Core 2.1 preview 2 project templates define multiple urls in the
applicationUrl
property in the launchSettings.json file. This was not handled by Visual Studio for Mac, preventing the browser from opening. - You are now prompted to install .NET Core 2.1 SDK if a .NET Core 2.1 project is opened and the SDK is not installed.
- In Preferences, there is now a Projects > SDK Locations > .NET Core section (Figure 4) that can be used to configure the location of the .NET Core command line tool (dotnet). This can be used to point to a different non-standard install location of the .NET Core SDK.
- If the .NET Core SDK 2.1 preview is installed then project templates for .NET Core 2.1 will be available in the New Project dialog.
- Improved project load performance when a .NET Core project contains thousands of files.
- Fixed an issue where the TargetFramework short name format would change on save. Adding a file to a .NET Core project that targetsTizen 4.0 would result in the TargetFramework changing from
tizen40
totizen4.0
. Now the original framework identifier name isnot modified and if the version of the framework changes then the version uses the format that was originally used in the project.
ASP.NET Core
- Running an ASP.NET Core 2.1 app that uses HTTPS will prompt you to install and trust the HTTPS development certificate so that HTTPS can be used when testing the site locally.
- Fixed an issue when publishing of ASP.NET Core web apps where existing web apps were not being shown.
- Fixed an issue where adding new .cshtml files from a template would add MSBuild items to the project file when the project file should not be modified.
Accessibility
The text editor margins have been made keyboard accessible.
- Pressing Alt+Tab when the text editor is focused will move the focus to the margins, which can then be moved between using Tab, Shift + Tab, and the cursor keys.
- Pressing Shift will activate the margin item that has focus.
This fixes bug #53722.
Xamarin
Xamarin.Forms
This release brings numerous bug fixes to improve the .NET Standard developer experience.
- Updated Xamarin.Forms to use shared .NET Core Templating Engine so that the templates are now consistent with Visual Studio (Windows).
- The C# Xamarin.Forms project templates (Blank Forms App, Forms App, and Class Library) have been updated and now include a .NET Standard project instead of a Portable Class Library project.
We've fixed the following problems when using Xamarin.Forms in a .NET Standard project:
- Changing the build action to None for a ContentPage XAML file would not add a None MSBuild item to the project.
- Remove item not added to project when XAML or xaml.cs file excluded from project.
- Fixed XAML and xaml.cs file not nested after removing Remove items from the project file in the text editor.
- Moving/copying XAML files from existing PCL/shared project to .NET Standard project would cause the .NET Standard project to no longer compile.
- Dependent xaml.cs files are now renamed on renaming the parent XAML file in Solution window.
- Prevent renaming of xaml.cs file independent of the XAML file since different names are not supported by Xamarin.Forms in a .NET Standard project.
We've fixed the following problems with code completion of XAML files:
- Fixed issues with emojis in XAML files break the editor and lead to a fatal error.
- Inconsistent completion for end of self-closing tag.
- Added code completion inside DataTemplate and ControlTemplate elements.
- Issue when ending attribute with
=
which would add a duplicate='
when='
already existed. - Added StyleSheet and other XAML extensions to code completion list.
- FontSize value code completion now offers named sizes.
- Starting code completion in middle of markup extension didn't show correct list.
Xamarin.Android
Android Device Manager
We have further integrated the Xamarin Android Device Manager (Figure 5) into Visual Studio for Mac. This feature is still in Beta and is available as a replacement for the Android AVD Manager which was deprecated by Google in favor of a command line tool with the release of SDK Tools 26. The Device Manager allows you to quickly and easily create emulators and edit their configuration using the built-in property editor. It supports the latest emulators from Google and is able to download and install missing dependencies for you, so you don't have to switch to the SDK manager to install new system images. Emulators by default use quick boot for faster startup times (Figure 6).
This release features significant UX and UI improvements over the web preview version, and we've addressed many user-reported bugs.
You can launch the Device Manager by choosing Tools > Device Manager.
Android SDK Manager
This release of the SDK manager (Figure 7) includes numerous improvements to reliability and performance, as well as some visual improvements. In addition, we've added support for a 'Recommended' Microsoft manifest, which contained verified versions of components that work with Xamarin applications. Components will only be offered for download when we support them.
- We improved the experience with detecting HAXM on High Sierra. High Sierra and Android SDK Tools v27+ provide support for accelerated emulators without the need to haveHAXM installed. Previously, Visual Studio for Mac would attempt to check for HAXM in these cases when it did not need to.
- We've updated templates to use API 27
Xamarin.Android.Support.*
packages.
We've fixed the following problems with Android:
- You can now add a new Android layout file to a project from the New Project dialog.
- Optimized Xamarin.Android analyzers to not run on Generated Code.
- Fixed an issue when publishing Android packages.
- Fixed Android emulator launcher issues affecting users with parallel installations of Visual Studio for Mac.
- Fixed an issue when publishing to the Google Play Store with Rollout option.
- Fixed an issue that made it not possible to add a new Android layout file to a project from the New File dialog.
- Fixed an issue where Android attributes would be rendered duplicate in the text editor.
- Improved support for how Android versions and codenames are discovered, giving better support for preview SDKs.
- Updated the label of the default TLS option to reflect the changes in Xamarin.Android SDK, which will be Native TLS 1.2+.
- Fixed an issue with projects that have AfterBuild targets when archiving for publishing.
- Fixed an issue for F# Android apps where UI tests would crash on device.
For more information, see the Xamarin.Android release notes.
Xamarin.iOS
- Includes support for Xcode 9.3.
- Fixed an issue with Intellisense when completing an iOS event on UIButton.
- Updated the Asset Catalog editor's 'Import' context menu command to allow for importing multiple assets at the same time. This fixes bug #60781.
- Update iOS automatic provisioning algorithm to support more entitlements:
- Data Protection
- Wallet
- Associated Domains
- Near-field communication Fixes some devcomm issues
- Fixed a UI issue in which it appeared 'Generic Simulator' was a valid deployment target when no were simulators available.
- Fixed an issue with missing IntelliSense.
- Fixed an issue when migrating from monotouch based projects to Classic and then to Unified projects.
- We have removed the old 'HeapShot' memory profiling option for iOS projects. Memory profiling is possible with the Xamarin Profiler.
Registrar Optimizations
This is a set of optimizations that makes the dynamic registrar removable by the linker (under most circumstances). This results in:
- Smaller applications: The linked Xamarin.iOS.dll is now 30-50% smaller. Information needed only at build time, such as custom attributes, can be safely removed. With less code being referenced, the linker is able to remove more code than in previous versions.
- Faster application startup: More registration work is being done at build time instead of at runtime. This removes, for example, the need for slow reflection on custom attributes to register types and methods.
- Reduced memory usage: The avoided work also reduces the memory required for applications. Initial (startup) memory requirement is down 30% for a minimal application and 20% for extensions. This makes it easier to create some type of extensions where iOS imposes memory limits (e.g. 16MB for Today extensions).
For more information, see the Xamarin.iOS release notes.
Visual Designers
iOS Designer
- Drag and Drop in Document Outline: It's now possible to drag items in the Document Outline to affect their z-order within their container, or to move them to a different container.
- Document Breadcrumb Bar: A new breadcrumb bar in the top toolbar of the designer shows the selected view's parent hierarchy. Click on a parent view in the breadcrumb bar to select it on the design surface.
- Xcode 9.3 Support:
- Updated the iOS designer to work correctly with the latest version of Xcode 9.3.
- Added missing Xcode 9 properties.
- Fixed layoutGuides creation.
- Added support for latest watchOS views and gestures, including:
- SCNScene
- SKScene
- HomeKit Camera
- Payment Button
- Gestures
Install Msbuild Without Visual Studio
Android Designer
- More reliable resource processing.
- Improved behavior for multi-select.
Xamarin.Mac
- We fixed an issue that was making it possible to run an app whose minimum OS version is greater than the current OS.
- We fixed an issue where the editor would highlight every usage of NetStandard references, even though the project builds and runs fine.
For more information, see the Xamarin.Mac release notes.
Live Player
- We fixed issues where Visual Studio for Mac would try to build the project before deploying to Live Player.
- We fixed issues where Live Player devices were not visible when you selected simulator build configuration.
Xamarin Profiler
- Improved light allocations mode.
- Improved snapshots comparison.
- Performance improvements.
For more information, see the Profiler release notes.
App Center Test
The New Project dialog templates and categories now refer to App Center Test instead of Xamarin Test Cloud. The final configuration page of the New Project dialog shows App Center Test and the 'Learn more' link opens the App Center Test website. Getting started pages now show App Center Test and the link goes to the App Center Test website.
Other fixes
- Fixed issues with MSTest tests in a .NET Framework library project.
- Fixed an issue debugging with Unity.
- Fixed an issue setting breakpoint on non-existing C# functions.
- Fixed duplicate key error when restoring NuGet packages if duplicate files are in the project.
- Fixed an issue with incorrect F# function keyword highlighting.
- Fixed a possible crasher in the subversion backend.
- We corrected a problem with Russian localization.
- We fixed an issue where pricing options were not populating when creating Azure app services.
Visual Studio for Mac 7.5.1 (7.5.1.22)
released May 15, 2018
- We fixed a fatal error that was caused when opening a solution created in Visual Studio on Windows in Visual Studio for Mac.
- We fixed an issue that caused Monodevelop to crash.
- We fixed an issue where tabs were not replaced with spaces.
- We fixed an issue where a new
Reference
is added to the .csproj file on every Release build. This fixes the following reported issues: - We fixed the cause of a crash when the UILabel Text property was changed from Plain to Attribute in the iOS Designer.
- You can now select a device that includes special characters
- We fixed an issue causing the
NavigateTo
type filter not to work. - We fixed a threading issue with the IntelliSense window.
Visual Studio for Mac 7.5.2 (7.5.2.40)
released May 30, 2018
This release provides support for Apple Xcode 9.4.
In this release we fixed the following issues:
- Using Go to Definition would not work reliably when navigating to the assembly browser.
- Creating a new Azure Functions project would result in IntelliSense errors until the project was closed and reopened.
- Collapsed regions would auto expand.
- When the system language is changed to Chinese, it is not reflected in Visual Studio for Mac.
- Fatal error occurs when editing
appsettings.json
in a new ASP.NET Core Web App created from template. - C# classification doesn't update when compilation changes.
- The pin icon in the Welcome Page is too smal.
- Visual Studio for Mac code snippets cursor location problem.
- Xamarin.Forms - SomePage.xaml.cs -> InitializeComponent() says it's ambiguous.
- Ambiguity between same members using a linked XAML file.
- Moving the main Android SDK Manager window was not possible during downloads or installs on slower machines.
We also fixed the following issues with the new Android Device Manager:
- AVD not created,
Error code 1 thrown
. - Slow loading of devices.
- Asking for permissions to be fixed several times a session.
- Emulator name does not properly show up in 'Name' section of the editor for existing emulators.
- Queued text is displayed as truncated when there are items in queue.
- AVD deletion issues.We now also set the default API level for new AVDs to API 27.
Visual Studio for Mac 7.5.3 (7.5.3.07)
released June 19, 2018
This release brings Xamarin.iOS support for ClassKit entitlements. For more information about ClassKit, see Apple's ClassKit guide.
In addition to ClassKit support, we resolved the following issues:
Msbuild Fail Visual Studio For Mac Unknown
- Fixed an issue where the gutter on the left corrupts when you hover over the '...' associated with a compile error.
- Fixed an issue where Visual Studio for Mac freezes when saving a file.
Visual Studio for Mac 7.5.4 (7.5.4.3)
released July 23, 2018
This release addresses the following issues:
- Fixed an issue where Visual Studio for Mac appears to offer no updates.
- Fixed an issue with Korean language input where the final character is not highlighted when selecting from end of line to beginning of line.
- Fixed an issue with Korean language input where characters are transposed during selection/highlight (e.g. to copy + paste).
- Improved navigation and flow of feedback survey.
Known Issues
Visual Studio For Mac Os
The following is a list of all existing known issues in Visual Studio for Mac version 7.5.
- Already installed Android SDK is not being detected in the installer (if installed through Android Studio).
- Code in indented @{} block jumps up a line when committed.
- Razor TagHelpers in project are not refreshed on build.
- CSS Class IntelliSense in _Layout.cshtml, but not in views.
- In Razor, toggle comments does not work in HTML.
- In Razor, indented
<environment>
tag content indentation bad. - Completion does not commit if the caret is immediately followed by
}
. - Typing a
<text>
tag in a for loop is changed to textarea.