.NET 3.5 sp 1 beta is sexy
/Half way down - see the script combining feature.
I really like how this will optimise the number of network traffic, but I think it can make debugging scripts slightly harder if the lines change between postbacks.
jliu
Code zealot in a connected world
Half way down - see the script combining feature.
I really like how this will optimise the number of network traffic, but I think it can make debugging scripts slightly harder if the lines change between postbacks.
jliu
Premium service
The company will be called "5 Minutes to Beach Paradise"
I'm a pretty strong believer that anything related to the development should go on the project Wiki.
Most people will agree on a few obvious topics:
I prefer if the Wiki was more a 'place for everybody'. Because the goal is that you want to drive your team to firstly Read the Wiki and then secondly to Update the Wiki.
This means it needs topics that are less hardcore and has a more personal touch:
When someone on the team has a problem, what do they do
On most projects, #1 happens all the time, and #2 pretty much never happens. Which is a pity.
I received an email reminder from the client recently.
"Please don't plug external/personal laptops into the corporate network, this is against the enterprise security policy".
This blog is not a criticism of this security policy. In fact, I tend to agree with the gist of this security policy. It is always better to tell your less-computer-savvy users to avoid plugging in potential trouble into the network.
However, this does reminds me of a few things I wanted to rant about:
1. What about things like: External Hard Drives, USB sticks (and by extension, iPods or digital cameras)?
They can transfer viruses too. There was a news just this January where the USB digital picture frames many people got for $50 from Best Buy for their grand dad for Chrismas, and it was infecting their PCs.
http://www.news.com/8301-10789_3-9843574-57.html
Personally I think the network must be smart enough to detect virus troubles and drops the device from the network automatically, in a corporate environment, this goes for both "internal" as well as "external" machines.
Enterprise Security Policy by limiting who can or can't plug into the network is extremely naive, and possibly only give a false sense of security. I sincerely hope there's a second line of defense on the network beyond just this policy.
2. Licences on development machines
For many years, I do work on a laptop with all the tools already installed, licensed and configured correctly. So when I showed up at a new client/project I'm ready to go on day one. Trouble is, many clients have a similar requirement in not allowing external machines to be used on the network - usually that's a set back for development time with lots of "develop on laptop", "copy over on USB stick", "test on client network"... rinse and repeat. This is a workable solution, but it is time consuming and still requires a basic setup on the client's development computer (at least VS.NET)
I thought there are a lot of parallels between a consultant vs say a plumber.
Plumbers shows up at the project with their own hammer. The client doesn't have to buy a hammer for the plumber.
If a consultant shows up at the project with their own laptops. The client shouldn't have to buy a new laptop (or the tools on it) for the consultant.
What happens though, when the client won't let the plumber use the plumber's own hammers on his sink? How can the plumber do his work?
Oh by the way we're still waiting for a few more licences for Resharper.
I've been experimenting with the anonymous types we have in C# 3.0, here's my latest creation:
var actions = new[]
{
new { Name = ActionSave, Type = KnownActionType.Save },
new { Name = ActionCopy, Type = KnownActionType.Copy },
new { Name = ActionNew, Type = KnownActionType.New },
// snipped another 10 actions...
};
foreach (var action in actions)
{
Actions.Add(new Action(action.Name, action.Type));
}
C# happily compiled this for me, to my surprise. And it works just as I expected it to.
Even intellisense picked it up properly. See, strongly typed goodness.
The most amazing part I wasn't expecting is the C# compiler knowing that all the array items are the same anonymous type. So it must have worked that bit out somewhere.
---
Prior to the amazing var variable, you would to do this with nasty looking nested object[] setup. Like so:
(warning, untested code)
object actions = new object[]
{
new object[] { ActionSave, KnownActionType.Save },
new object[] { ActionCopy, KnownActionType.Copy },
new object[] { ActionNew, KnownActionType.New },
// snipped another 10 actions...
};
foreach (object action in actions)
{
// reall awful looking line next
Actions.Add(new Action((string)action[0], (KnownActionType)action[1]));
}
There are heaps of things wrong with this old way:
Yes. I think I'm going to do nested anonymous types next.
jliu
I look at how a small team can build amazing things with the latest tools we have in Office 365 & SharePoint. I'm a coder, developer, Office SharePoint MVP. I dream, then I rant.
Founder @ Flow Studio App
A poweruser tool to help every maker write better Microsoft Flows and manage them.
Office Apps and Services: SharePoint
Business Applications: Flow
This work by John Liu is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.
Permissions beyond the scope of this license may be available at /about-me/.