11 August, 2010

Some nice code editor features provided by the VS 2010 Power Tool Extensions

Some nice code editor features provided by the VS 2010 Power Tool Extensions: "

Ctrl+Click “Go to Definition”

One of the small, but useful, features that I find myself using a lot with the extensions is the "Ctrl + Click” go to definition feature.
For those of you who haven’t tried it, it enables you to quickly navigate to the definition of a member or type within your code. You can accomplish the same behavior out of the box with Visual Studio by right-clicking on a member/type and then choosing the “Go to Definition” context menu item – or by moving your cursor over a type/member and then pressing the F12 key. But for some reason I’ve found the Ctrl+Click gesture provided by the VS 2010 Power Tool Extensions more natural and faster to use (since for my keyboard the F12 key requires a split-second extra finger move to use – whereas the control key is always in easy reach).
To try out the “Ctrl+Click” behavior, just hold down the “Ctrl” key and use your mouse to hover over a type or member in your code. When the extension is enabled you’ll find that this causes a hyperlink to appear under each type/member you hover over:
image
Clicking the hyperlink will immediately navigate you to the definition of the type/member within your code:
image
Note that the “go-to-definition” feature in VS can also be used on a type that you don’t have source access to. For example, like with the DbSet<T> collection I used in my EF “code-first” blog post yesterday:
image
When you click a type referenced from a binary library, VS will automatically generate a class definition based on the signature compiled into the assembly:
image

Triple Click Selection

Another one of the “small but useful” features provided with the power tool extensions that I find myself using a lot is the “triple click” feature.
Today with VS you can double-click on a word to automatically select it:
image
When the “Triple Click” extension is enabled you can now also triple-click on a line to automatically select the entire line:
image
This behavior has been supported in Word for awhile. Until I saw that there was a power tools extension for it I didn’t actually realize that VS didn’t already do it by default. Well – now you can.

“Alt Up/Down Arrow” Line Movement

Another “small but useful” feature provided by the power tool extensions is the ability to easily move lines of code up/down within the editor.
Simply select either a single line of code, or a block of multiple lines of code, within the editor:
image
Then hold down the “alt” key, and press either the up or down arrow on your keyboard. This will cause the editor to move the selected code up or down within the editor (without you having to copy/paste or move anything around manually):
image
This is another one of those features that Word has had for awhile – and which is nice to now have in VS.

Column Guides

Column guidelines allow you display a vertical band within the code editor. This is useful to help identify the maximum size a single line of text should be within your code (for example: to avoid wrapping when printing it out).
The power tool extensions enable you to add a column guide pretty easily. Just cursor over in your code editor to where you want the guideline to be (note: you can see the exact line column count at the bottom of the editor):
image
Then right-click and choose the “Guidelines->Add Guideline” menu command:
image
This will then cause VS to show a column guide-line in all code editor windows at that column width – making it easier to see when you’ve written code or a comment that wraps beyond that:
image
If you want to remove a guideline, you need to move your editor cursor to be at the same column width as the guideline. You can then right-click and use the “Guidelines->Remove Guideline” command to remove it.

Extensions Update

In case you missed it, the Visual Studio team last week made a minor update to the VS 2010 Productivity Power Tool Extensions to fix a few bugs and performance issues that people reported with the last release.
Sean has a blog post with more details about the update here. The update included fixes for:
  • Poor performance with Solution Navigator searches on large projects. In this revision, we've made some optimizations to the search algorithm. Search will also now only be initiated after two characters are typed in the search box.
  • Items in Solution Folders were not sorted. In this revision, they are sorted alphabetically.
  • Invoking Quick Access could cause a crash on some machine configurations. This issue has been resolved in the current revision.
  • Ctrl+1 & Ctrl+2 were not configurable in the Solution Navigator, which blocked the ability to type @ on some keyboards. This revision provides the Edit.ShowSolutionNavigatorPopupForSelection & Edit.ShowSolutionNavigatorPopupForFile commands which can be rebound using Tools => Options => Environment => Keyboard.
If you have a previous build of the Power Tool Extensions installed you use the “Tools->Extension Manager” menu command, select the power tools extension and then click the “update” button to upgrade to the latest build.

Summary

If you haven’t tried out the VS 2010 Productivity Power Tool Extensions yet, I’d encourage you to give it a try. It includes some nice additional functionality which can help save you keystrokes and time as you work within Visual Studio. I’ve only covered a few of the features in this post and my previous two posts – there are a lot more cool things in there that I haven’t blogged about yet.
You can also now enable/disable each individual feature within the extensions pack – allowing you to selectively choose what you want to use. Use the “Tools->Options” menu command, and navigate to the “Power Productivity Tools” tree-view item to enable/disable individual features.
Hope this helps,
Scott

Different ways to get Identity of New Inserted Rows in SQL Server

There are different methods to know the Identity Value of a newly added row.
Let us consider the following example:

--Create a Table
CREATE TABLE table1
(
id int identity(1,1),
Employee varchar(100)
)

--Insert Data
INSERT INTO table1(Employee) SELECT 'Amit'

--Get Identity Value of the Current Scope
SELECT scope_identity()


--Get Identity value of the Current Session
SELECT @@identity

--Get Identity value of the Table
--Regardless of Scope and Session
SELECT ident_current('table1')
Note that first two methods wont give correct values if data are added to the ‘different tables’.

OUTPUT

How to redesign a website in 5 weeks

How to redesign a website in 5 weeks: "
You will need:
  • A dedicated room - a usability lab or 'war room' if you like
  • A dithering of designers. Pick and mix any five or six from:
    • Information architect
    • Interaction designer
    • Usability engineer
    • User interface designer
    • User researcher
    • Any other title using one or more of the above terms
  • Reams of paper, pens, pencils, crayons, glue, pipe cleaners and felt (glitter optional)
  • A Spotify playlist with at least 500 songs, none of which shall be by Maroon 5
Step One - Review the internets
Be exhaustive in your research. Critiquing everything from the International Association of Time Travellers member's forum through to People of Walmart. Oh, and probably some competitor sites. Like Fail blog.
Step Two - Inspiration wall Print out the best elements then get an adult to cut them out. Next, stick them on the walls and windows. Look at them often for inspiration. Try and work a silverback gorilla into all of your designs.

Step Three - Early prototyping
Sketch out some designs. For websites, start by drawing an empty rectangle on the page. This represents the web page.

Step Four - User feedback
Show your early prototypes to people whose profile closely matches that of your websites key personas. Failing that, show them to the stakeholders who're lining up to kick your ass should the project fail.

You: 'What are you thinking?'
Them: 'Does that rectangle represent the webpage?'
You: 'Mmmmaybe...'
Them: 'But the piece of paper itself is a rectangle. Why draw a rectangle on it?'
You: 'I would explain, but I don't want to bias your feedback.'
Step Five - Iterate the designs
You'll now spend the following weeks in a cyclical design process which goes something like Sketching > Feedback > Swearing > Sketching > Feedback > Arguing > Coffee > Sketching > Beer At some point you will want to move away from the sketches and create designs with higher fidelity. We use Balsamiq because it makes your higher fidelity designs look like sketches.

Step Six - Plan B
By this point it's week 5 and you've already known for four weeks that you'd never get it done in five. Take a holiday and delay your return by encouraging the French to strike (easy). Have a 'day out' at the company's expense. Undergo root canal treatment. Anything that will persuade the stakeholders to give you more time... Suggest another 12 weeks. When they agree and leave the room, high-fives all round and bring out the 12 year old malt whiskey.

To be continued... (hic)
Post by: Adam Walker
"