The opinions expressed in these materials are my own and are not necessarily those of Microsoft.
Copyright © Microsoft Corporation. All rights reserved. Unless otherwise indicated, all source code provided is licensed under the Microsoft Public License (Ms-PL).
Quick Housekeeping Note: I’ve deprecated the old Visual Studio Tips extension and have tried to get it removed from the gallery so it isn’t available anymore but have had little success. I am currently not planning to replace the tool with a new version but am open to suggestions as to a viable alternative. For now I suggest you use your favorite RSS feeder or visit the blog directly. Now on with the post…
With the BUILD conference (http://www.buildwindows.com/) just around the corner and lots of announcements coming I thought now would be a good time to pause the usual posts and talk about the next version of Visual Studio (vNext) and how you can prepare for some of the goodness to come. This is a high-level look at what is coming and I will be blogging in much more detail on the features throughout the vNext cycle. With that said, I’ve intentionally left out any images of the IDE for this post in favor of brief feature descriptions. Additionally, I will be blogging and tweeting directly from the BUILD conference while I am there to keep you up to date on the latest revelations that are coming out. To get a sneak preview of some of the features make sure to see the following video:
Visual Studio 2010 introduced a great new extensibility model that made custom additions very easy to make. You can find these extensions at the Visual Studio Gallery (http://visualstudiogallery.msdn.microsoft.com/) and, if you haven’t explored some of these great additions, I suggest you browse through the gallery to see the items there. When asked which extension I suggest everyone download the number one answer I give is always been the Productivity Power Tools (http://visualstudiogallery.msdn.microsoft.com/d0d33361-18e2-46c0-8ff2-4adea1e34fef?SRC=Home). Download it now. Seriously. Now.
We have (and will going forward) use extensions to field test new features that will be included in future versions of Visual Studio and it is a safe bet that some of the Power Tools will find their way into the vNext. If you watched the video mentioned above you will hear Weston Hutchins mention this as well. What better way to see what people want than to let them vote by actually downloading and using a feature? Granted it’s a little harder to focus on individual features when a lot are packed together but, even then, we get plenty of feedback on what people like and don’t like.
Once we get beyond VS2010 then we can start looking at the new features that have been publicly revealed so far. Here is a list of things you can expect in the next version:
One of the bigger pains in prior versions of Visual Studio is moving a project between versions. It was an all-or-nothing proposition typically due to schema changes to the proj files. If you opened a VS2008 project in VS2010 and converted it to the new project format then that project could no longer be opened in the prior version. For those that have experienced this you know this wasn’t entirely true and you could do a little proj file hacking to go back but it wasn’t fun or intuitive to do so. Visual Studio vNext will solve that issue. You will now have the ability to open a project in the new version of Visual Studio and still go back to prior versions. The net effect is you can have different teams on different versions of Visual Studio but still able to share projects with each other!
With the dizzying array of menu items, toolbar buttons, options, files, etc… it is often difficult to remember where a particular item exists. VS vNext adds the ability to quickly search the IDE for these things. A good analogy would be to compare it to the ability to search programs and files when you click on the start button in Windows. I don’t know about you but I don’t look for files anymore for the most part, I just hit my Windows key then type in what I am looking for then select what I want. Imagine that level of functionality inside the Visual Studio IDE and you have an idea of what this new feature does.
vNext supports creating new instances of Solution Explorer so you can have focused areas (one project in one instance and another project in a second instance) for working on multiple monitors. Additionally these instances can be nested inside windows that have been pulled outside the IDE for use on other monitors.
In the Productivity Power Tools we introduced the Solution Navigator with some cool new features that have found their way into the new IDE. The ability to drill down into the classes then members from Solution Explorer now exists. You can right-click, say, a method in Solution Explorer and see some new terminology: Calls, Is Called By, and Is Used By. Calls represents the call hierarchy for the method; Is Called By represents a list of methods that call the current method; and Is Used By represents all the specific file, line, and column positions where the method is mentioned.
Much like the new search for the IDE, we now have a new search for just the items in Solution Explorer. You can quickly type in a file, class, reference, etc… and see a filtered list in Solution Explorer of the items you are looking for.
A long-awaited feature that will collapse everything in Solution Explorer so you can expand items “fresh” as you navigate though the various hierarchies.
Another feature introduced in the Productivity Power Tools, this feature will let you keep interesting tabs surfaced on the left of the tab well while non-pinned tabs get pushed out of the visible area based on usage.
You can now rip off documents from the IDE and have multiple tabs grouped together in one or more floating tab wells. This is great for multi-monitor situations where you want groups of related files on separate monitors.
There is now a dedicated search box for the Toolbox window so you can quickly filter items to find the controls you want.
The most notable change to the Add Reference dialog is speed. It is way, waaaaay faster to add a reference with the new dialog than ever before. Also, a search box has been added to allow quick filtering of assemblies.
The Quick Find / Replace has been cleaned up and streamlined to make using the experience easier overall.
As with many other tool windows, the Error List window now sports a search box you can use to filter the list of errors, warnings, and information messages.
The Error List window also now supports a scope filter that lets you show only those items in Open Documents, the Current Project, or the Current Document.
Probably one of the coolest new changes is the Preview Tab. Essentially it allows you to look at a preview of a file and decide if you want that file to be opened up in the tab well. I’ll show much more on this feature later but wanted to mention it here to round out the list of items I will be covering in the short-term.
There are a lot of very cool changes coming in Visual Studio vNext. This post is meant to make you aware of the coming changes at a high-level to prepare you for a deeper discussion of each of these features in future posts.
Continuing on our odyssey of exploring the features in vNext, I thought we would look at some of the performance enhancements that have been publicly announced. Naturally, at this time, I can’t go very deep into the inner-workings of the improvements but will endeavor to list them out and explain somewhat based on information currently available. Also, be aware that this is a very early look at these features so there will be many improvements made as the product gets closer to RTM. I’m actually running two versions of vNext currently; the one that will be made available to the public as a pre-release at some point and the one we build internally so I have a pretty good handle on what you will see and what is coming out. I can say that there are some great things that are being done with the product you will definitely enjoy. With that said let’s take a look at some of the things we have revealed so far…
First off, if you haven’t seen it yet, most everything I mention comes from the great TechEd session done by Weston Hutchins that can be found here:
For vNext we are focused on four areas of investment to improve the product:
As I review the areas of improvement expect a great deal of overlap as many of the improvements fall into multiple categories. With that said, this area is pretty self-explanatory: We want vNext to enable users to quickly go about their work without waiting on the IDE. These improvements manifest themselves in a variety of ways but all have the singular goal of making the product more responsive. Below are some of the areas that address this goal that we have made public so far.
One of the IDE enhancements revealed so far is Add Reference dialog box. First and foremost it has been supercharged to load almost instantaneously. How? We index the assemblies beforehand to have a ready-made list on demand. We haven’t gone into detail yet on what exactly is being done but expect that revelation in due course. Also, as with most of the IDE, we have added the ability to search/filter the list so you don’t spend a billion years looking for the assembly you want.
We have moved some activities out-of-process to give control back to the IDE quickly. See Memory Utilization.
vNext will take advantage of multi-core systems much better than VS2010 which will result in more overall responsiveness. See Long Running Operations.
Building and debugging are examples of a long-running operations that we are addressing. For example, Visual Studio 2010, while a great improvement over previous versions, really doesn’t take full advantage of multi-processor machines. Our goal is to speed things up so you can get your work done faster with less time spent waiting.
Build operations have now been moved to background threads so you can actually do other things in Visual Studio while a build is happening.
Another great new feature is the ability to build projects in parallel. vNext comes with an option to have parallel project builds based on the number of cores your system has. In fact, the default value is automatically set to the max cores on your system. You can reduce this value if you want.
Responsiveness also includes the overall efficiency of Visual Studio. We are working on reducing the memory utilization overall based on usage.
vNext uses much less virtual memory internally. Much of this is due to running builds out-of-process (see below) as well as other enhancements we have made that haven’t been released yet.
C++ has had this feature for a while and we are now brining it to C# and, in a future release sometime after vNext, VB as well. We now perform builds outside the Visual Studio process. Instead of loading numerous referenced assemblies inside the VS process they are now loaded into an external process then discarded when we are done. This results in significantly less memory usage inside Visual Studio which results in a more responsive, stable product.
This one is really simple. How do we get the best information possible when there are issues with the product so we can continuously improve it for you? Solving for this question is never easy but we have devised ways of obtaining performance data from your actual use of the product to help strengthen our knowledge of areas that need to be addressed.
The number one tool you can download TODAY to give us feedback on VS2010 and vNext is PerfWatson. You can get it from the Visual Studio Gallery here:
This tool allows us to get up-to-date, immediate information on the issues that are impacting performance. This tool is currently built into the pre-release version of vNext and, I suspect, we will include it in the RTM version as well with an option for you to turn it off if you don’t want it.
If you haven’t gone to http://connect.microsoft.com/VisualStudio/ yet then you need to. This is one of the main ways we have been getting directed feedback from you for some time now. It’s a great way to get to see what others are saying and to communicate directly with the VS team.
The original Code Map was introduced in the product with Visual Studio 2012 Update 1. You need to read my original post before moving on:
My assessment at the time was that it was a good feature but had poor performance and didn’t really add much value relative to Dependency Graphs. With debugger integration however Code Maps have definitely come into their own and the performance is very good.
Note: Code Map Debugger Integration is a feature in the Ultimate edition of Visual Studio.
Assuming you have a handle on Code Maps now let’s see how the debugger integration works. First, I’ll take the TailSpin Toys sample code and set a breakpoint within the code base (ShoppingCart.cs, line 61):
I’ll press F5 and add an item to my cart to trigger the debugger:
Ordinarily, we would step though the code and hope we remember how we got to a particular place. Those days are gone! Now we can turn on the Code Map feature while debugging:
You can also find this on the Menu Bar at Debug | Show Call Stack on Code Map:
If we take a closer look at the current map, we can see that it shows how we arrived at the current call (the squares above the last AddItem call) and our current location (yellow arrow). Although the current location indicator is partially covering it, you can also see the breakpoint indicator:
Stepping through the code we see the map keeps updating so we don’t have to keep the path in our heads:
The Code Map will continue to update for our debugging session showing where we have been and where we currently are in the call stack:
The graphs can get quite large:
For this reason it’s important to use the map tools at your disposal. The context menu items when you Right Click any node are a great example of common tools:
You can Double Click any node to view the code from that location in the stack. A green arrow will indicate your current position:
If you happen to choose a node that isn’t part of the current active call stack then you will get a slightly different indicator:
When you stop debugging the Code Map will be preserved so you can save it if desired and keep a map of the code base you just went through. I think this is an exceptional addition to the debugging experience!
Welcome to the Launch Landing Page on my blog! Here you will find all kinds of launch-related coolness for your use.
Visual Studio Team System 2008 Virtual PC Images
Hands-On-Labs -- These things rock they are the harcore labs that you can do to get up so speed with the products.
[UPDATE: apparently there are source files missing from the hands on labs above so they are basically PDFs that suck. You can grab them as a nice overview but use the link below for labs with source files you can actually use:
And here you can find related webcast/podcasts/etc...: http://www.microsoft.com/events/series/msdnvs2008.aspx?tab=virtuallabs ]
Now to the good stuff! here are the links to videos from the Dallas Launch. Enjoy!
Links to Session Videos:
Ø Keynote, Chris Sakolosky, Jon Roskill
Ø Virtualization and your Infrastructure, John Weston
Ø Exploring Windows Server 2008 Web and Application Technologies, John Weston
Ø Optimizing your IT Infrastructure with Windows Server 2008, Stephanie Doakes
Ø What is New in Windows Server 2008, John Weston
Ø Securing your IT Infrastructure with Windows Server 2008, John Weston
Ø Enabling Dynamic IT and Optimizing your infrastructure processes and people, Stephanie Doakes
Ø The Application Platform: Where IT meets business, Stephanie Doakes
Ø Exploring Business Intelligence and SQL Server 2008, Brad Nelson
US Premier Launch Dallas MSDN Event Page:
Ø Simplify Management of Data Infrastructure, Sri Sridharan
Ø Breakthrough Challenges with Visual Studio 2008, Chris Koenig
Ø Creating Instantly Familiar Applications with Office System, Zain Naboulsi
Ø Mission Critical Application in SQL Server 2008, Sri Sidharan
Ø Next Generation Data Applications, Jonathan Swartz
Ø Reach end Users with Next Generation Web Applications, Chris Koenig
Ø Defy Occasionally Connected Challenges with Smart Client Applications, Zain Naboulsi
Yep, it's that time again. I feel the urge to purge some swag and what better way to do it than with a contest?
(Seriously cool image from http://www.techshout.com/)
To celebrate the coolness of Vista and Office 2007, I have decided do something around these products...but what?
I think it would be cool to have YOU decide what the contest should be. Hit me with YOUR suggestions for a contest that would be challenging yet fun to do.
[update 10/27/2008: we have finally decided on what the contest will be and the details can be found here http://blogs.msdn.com/zainnab/archive/2008/10/27/contest-phase-ii-begins.aspx you have until Nov. 21st to submit your entry]
The prizes will be:
1st Place: 4 vouchers for 50% off MS exams
2nd Place: 2 vouchers for 50% off MS exams
3rd Place: 1 voucher for 50% off MS exam
Combined with the goodness I announced earlier (http://blogs.msdn.com/zainnab/archive/2008/10/15/microsoft-learning-love-get-your-test-on.aspx) I think this will be a VERY cool deal for some folks.
So, the first phase is, based on your suggestions, I will create a contest and then the winners of that contest get the prizes listed above. Sound cool? Then get me some contest suggestions!!
So, someone thought it would be a good idea to give me some money for SWAG to give to my readers. Naturally, I loved the idea! So I went and bought a whole bunch of $100 ThinkGeek gift certificates. The problem is how to give them away? After much thought (about 10 minutes, at least), I figured the best way was to give them away whenever I felt like it.
Okay so there you have it. Beginning April 12th (Visual Studio 2010 Launch Day) I will be giving away ThinkGeek gift certificates. I’ll be picking people who show love for the Visual Studio Tips and Tricks blog. There are some basic ways you can do this:
Feel free to get creative and let me know about it. That’s pretty much it. Very simple really. Look for the fun to begin on Launch Day.
Keyboard: CTRL + WCommand: Edit.SelectCurrentWordVersions: 2008,2010Published: 4/5/2010Code: vstipEdit0039
Download the seriously cool Tip of the Day Extension to get the daily tips delivered to your Start Page!
You can easily select the current word in Visual Studio by simply putting your cursor in the word to select:
Then press CTRL + W and it will automatically select the current word:
Menu: Window -> Split Command: Windows.SplitVersions: 2008,2010Published: 3/5/2010Code: vstipEnv0004
Did you know you can split your windows? This feature has been available in a lot of Microsoft products for some time. You can simply go to Window -> Split on the Menu Bar or you can use this mouse technique:
Keyboard: CTRL + ALT + K (anywhere); CTRL + K,T (cursor must be on a member name) Menu: View -> Call Hierarchy Command: View.CallHierarchy; EditorContextMenus.CodeWindow.ViewCallHierarchyVersions: 2010Published: 1/19/2010Code: vstipTool0005
For the C# folks this is one heck of a great feature: The Call Hierarchy. It allows you to visualize all calls to and from a selected method, property, or constructor. To see how it works just right-click on any method, property, or constructor in the Editor and select View Call Hierarchy:
You should get a window similar to this one (amount of information will vary):
Notice there are "Calls To" and "Calls From" areas related to your selection. You can expand them out:
When you click on a node in the tree, the Call Sites window updates so you can visit the call if you want to:
You can continue expanding the hierarchy to see more "Calls To" and "Calls From" information:
The best part is you can right-click on a symbol and get all kinds of options:
Here are some options you may come across:
Context Menu Item
Add As New Root
Adds the selected node to the tree view pane as a new root node.
Removes the selected root node from the tree view pane. This option is available only from a root node.
You can also use the Remove Root toolbar button to remove the selected root node.
Go To Definition
Runs the Go To Definition command on the selected node. This navigates to the original definition for a method call or variable definition.
You can also press F12 to run the Go To Definition command on the selected node.
Find All References
Runs the Find All References command on the selected node. This finds all the lines of code in your project that reference a class or member.
You can also use SHIFT+F12 to run the Find All References command on the selected node.
Copies the contents of the selected node (but not its subnodes).
Collapses the selected node so that re-expanding it displays current information.
Versions: 2010Published: 1/29/2010Code: vstipDebug0004
For those not familiar with WPF Trees, check out this article: http://msdn.microsoft.com/en-us/library/ms753391(VS.100).aspx
Now. For those that ARE familiar with them have we got something for you: WPF Tree Visualizer. Yes, it started out as a CodePlex project and ended up in the product itself as a visualizer. But how do you use it?