Sign in
|
Join
ISerializable - Roy Osherove's Blog
Unit Testing, Agile Development, Leadership & .NET - By Roy Osherove
This Blog
Home
About
Syndication
RSS
Atom
Comments RSS
Search
Go
Navigation
Home
Blogs
News
My new book is out!
The Art Of Unit Testing
Buy and read it as I write it.
I work at:
Your ad here
The Art Of Unit Testing Book
Roy's Cool Tools
Subscribe!
Subscribe to ISerializable by Email
About
Hire me
Ask me
On my bookshelf
About me
Ego trip
Roy's Tools
5 Whys - a blog for team leaders
Key.bo - a search engine wiki for keyboard shortcuts
unit testing
ruby styff
All Developer Songs
It's Time for Violence
Que Sera Sera
Articles
3: Oops! Typed Datasets
Are
scalable!
4: Introduction To Regular Expressions
5: Practical Parsing Using Groups in Regular Expressions
6: UI Threading Helper Classes
Make Your App Support Plugins 2 - Dynamic Search (MSDN)
Winforms Data Binding Lessons Learned
Make Your App Support Plugins (MSDN)
1: Introduction to Typed Datasets
2: Typed Datasets Are No Silver Bullet
My articles on MSDNAA
7: Solving VS.NET Debugger Problems
Make your log files searchable using Regex and the XML classes (MSDN)
Introduction to TDD with NUnit
Fun with Unit Tests – Testing abstract classes
New: Creating a generic Site-To-RSS tool
.Net scripting
- the practical way
Simplified Database Unit testing using Enterprise Services
Creating custom test attributes easily with NUnit 2.2.1
Cool tools every .Net Dev should be aware of
Cool Tools every .Net developer should be aware of
New: The case for staged delivery and Agile methodologies
My .Net Deep Dive lectures on video
New: Defensive event publishing in .Net, part 1
Test Feasibility Matrix
Depenedency Breaking Issues
*new* Achieving And Recognizing Testable Software Designs – Part I
Favorite Blogs
The Morning Brew
Martin Fowler
Scott Hanselman
Joel On Software
.NET Weblogs
Microsoft Israel Community
The Runtime
Daniel Moth
Oren Eini
Jimmy Bogard
CodeBetter
Dustin Campbell
Guy Kawasaki
Stephen Toub
Research @ Intel
Udi Dahan
The Typemock Insider
My Projects
Vs.Net Settings import.export Add-in
SchemaHelper - auto-detect & create data relations
Proxy handling using ProxyFactory and ProxyInfo
BackgroundWorker implementation
XtUnit: An Unofficial Unit Testing Extensibility Framework - Add new attributes to NUnit or MbUnit e
Intercetpion Application Block
Extensibility Application Block
The Regulator
VS.Net 2003 registry tweaker
My Tools page
Regular Expressions
RegEx Lib
Expresso
Regex Blogs
Sites : .Net
.Net Tools List
.NetWebLogs Forums
Winforms FAQ
.Net Debugging Resources
.Net WebCasts & Others
.NetWeblogs Archive
MSDN Magazine
Design Patterns in C#
.Net Rocks Radio
.Net Resources
Howto: .Net common tasks
VB.Net blogs on MSDN
.NetSlackers
Sites : Misc
Regular Expression Library
MSR Downloads
Win2k3 Tweak Guide
About Microsoft Interviews
Tech Interview Riddles
Feedster
Amazon Light
C:\Utils
Sites : Unit Testing & XP
NUnitASP
Tips and techniques with NUnit
NUnit
NUnit Addin
XProgramming
MSDN Mag:Simplify Data Layer Unit Testing using Enterprise Services
Tags
.NET
.Net 2.0
.Net Original
.Net Quotations
.NetWeblogs Site
Addin Contest
ADO.Net
Agile
Agile Israel News
Agile Related
altnet
altnetconf
altnetisrael
Architecture
Art Of Unit Testing
ASP.NET
BDD
Blogging
C#
CLR
Community
Community News
Cool Articles
Cool sites
Cool Tools
Extensibility
Family
FeatureFocus
Free book chapters
General Software Development
Interview
Lean
Mobile
MSBuild
NDC09-Video
Off Topic
Open Source
Other
Product Reviews
Project Management
racer
Recommended books
Reflection
Regex
Regular Expressions
review
Security
Sharepoint
Silverlight
SOA
Songs
SQL Server
tdd
Team Agile News
Team System
TechEd 05
Testing Guidelines
TestReview
Threading
Tips & Tricks
Typed Datasets
Typemock
Unit Testing
Visual Studio
web
web services
WebCast
Windows Forms
WinFX
Recent Posts
How to: Move your blog off of weblogs.asp.net (aka ‘This Blog has moved’)
test – ignore
Bounty: 500$ is you can convert my blog to squarespace
Join me for a live webinar on unit testing with Isolator++ this thursday
What’s coming in Test Lint 1.5
Archives
November 2010 (2)
October 2010 (4)
September 2010 (4)
August 2010 (3)
July 2010 (2)
June 2010 (5)
May 2010 (6)
April 2010 (6)
March 2010 (4)
February 2010 (5)
January 2010 (11)
December 2009 (7)
November 2009 (7)
October 2009 (5)
September 2009 (6)
August 2009 (21)
July 2009 (7)
June 2009 (11)
May 2009 (13)
April 2009 (5)
March 2009 (21)
February 2009 (4)
January 2009 (2)
December 2008 (5)
November 2008 (6)
October 2008 (13)
September 2008 (4)
August 2008 (13)
July 2008 (19)
June 2008 (5)
May 2008 (17)
April 2008 (11)
March 2008 (13)
February 2008 (16)
January 2008 (21)
December 2007 (8)
November 2007 (18)
October 2007 (17)
September 2007 (15)
August 2007 (19)
July 2007 (18)
June 2007 (33)
May 2007 (16)
April 2007 (10)
March 2007 (15)
February 2007 (10)
January 2007 (11)
December 2006 (22)
November 2006 (18)
October 2006 (19)
September 2006 (30)
August 2006 (19)
July 2006 (27)
June 2006 (26)
May 2006 (32)
April 2006 (15)
March 2006 (20)
February 2006 (33)
January 2006 (23)
December 2005 (22)
November 2005 (41)
October 2005 (21)
September 2005 (7)
August 2005 (28)
July 2005 (41)
June 2005 (60)
May 2005 (14)
April 2005 (51)
March 2005 (31)
February 2005 (17)
January 2005 (63)
December 2004 (45)
November 2004 (35)
October 2004 (28)
September 2004 (36)
August 2004 (21)
July 2004 (44)
June 2004 (63)
May 2004 (62)
April 2004 (78)
March 2004 (64)
February 2004 (55)
January 2004 (67)
December 2003 (34)
November 2003 (67)
October 2003 (68)
September 2003 (113)
August 2003 (56)
July 2003 (112)
June 2003 (71)
May 2003 (136)
April 2003 (52)
March 2003 (81)
February 2003 (77)
Microsoft solves my RTM Bug (By Design..)
My blog has moved. You can view this post at the following address:
http://www.osherove.com/blog/2005/11/10/microsoft-solves-my-rtm-bug-by-design.html
Published
Thursday, November 10, 2005 7:09 PM by
RoyOsherove
Filed under:
.Net 2.0
Comments
Thursday, November 10, 2005 12:34 PM by
Wesner Moise
#
re: Microsoft solves my RTM Bug (By Design..)
I don't think that this repros in C#. VB must behave different in C#. C# is explicit; the root namespace does not affect how code is compiled in C#.
In my projects, the namespace you write is the same as the namespace you ultimately get regardless of the root namespace. global in C# works differently from what you mentioned here. The root namespace is the default name emitted in source files; otherwise typing namespace X.Y if the root namespace is X would yield X.X.Y.
The problem that globals solve in C# is when you define a namespace X.System and System automatically defaults to the nearest enclosing scope rather than the top level namespace. A root namespace is never automatically inserted before a namespace.
By automatically prefixing namespaces, VB is likely trying to be different from C# in order either to hide the concept of namespaces from VB programmers or to retain source compatibility with earlier versions.
Thursday, November 10, 2005 12:41 PM by
Roy Osherove
#
re: Microsoft solves my RTM Bug (By Design..)
Wesner: I've added to the post a repro in C#.
Thursday, November 10, 2005 1:01 PM by
Avner Kashtan
#
re: Microsoft solves my RTM Bug (By Design..)
This is a good example of where C#'s explictness comes in handy. In the C# repro, it's much clearer that what you're doing is defining a System namespace under the ConsoleApplication1 namespace, and not referring to the global System namespace.
The UNCLEAR point, in C# as well as VB, is the scoping rules that say that the compiler always evaluates namespaces from the inside out. It will start at the current scope and go up the namespace hierarchy until it finds a namespace that matches the requests namespace (in this case System) and looks for the typename there.
I do admit that if I hadn't heard Juval Lowy explain this precise feature a few months ago, I would have been as stumped as you are. :)
Thursday, November 10, 2005 1:43 PM by
BlackTigerX
#
re: Microsoft solves my RTM Bug (By Design..)
is it even a good practice to "extend" on the .NET framework namespaces?
Friday, November 11, 2005 5:03 AM by
Eran Sandler
#
re: Microsoft solves my RTM Bug (By Design..)
Excuse me for being an ass about it, BUT isn't the whole idea of namespaces is to make sure no on steps on each other?
Even if I wanted to extend the .NET framework I would never use the same namespaces, ever.
I would probably use something like MyCompany.System.Compoenet or something like that.
Sure, it might mess up the fact that I might (and that depends on my using statement in C#) have to alias System (the .NET System namespace) and call it DotNetSystem or something, but its reasonable and is understandable and has been like this since VS 2002.
Saturday, November 12, 2005 1:57 AM by
bnaya@wisemobility.com (Bnaya)
#
Re: Microsoft solves my RTM Bug (By Design..)
It’s not easy to post your own mistake
(Even when you right about the bad indication)
You’re doing great community job by having
The courage to post such things
TNX
Monday, November 14, 2005 9:03 AM by
Roy Osherove
#
re: Microsoft solves my RTM Bug (By Design..)
most of the time, yes. But sometimes you'd like to add an ability on an existing component and using the same namespace.
Besides, jsut suppose this was by accident. It's still almost impossible to realize your mistake.
Wednesday, November 16, 2005 12:24 PM by Andrew Webb
#
re: Microsoft solves my RTM Bug (By Design..)
I was really worried about this 'bug' when I first heard about it. But to be honest, I would never dream of writing:-
namespace ConsoleApplication167
{
namespace System
{
}
// etc.
}
And if problems did arise, I would *immediately* suspect my nested namespace definition of "System", and get rid of it. However, I think that overall there is reasonable evidence that the IDE is not quite ready for full-on production use, and will wait for a Service Pack. "Be neither the first to adopt the new, nor the last to relinquish the old."
Friday, December 02, 2005 9:47 AM by
Diego
#
re: Microsoft solves my RTM Bug (By Design..)
I learned this same lesson 30 minutes ago. I have not found that easy-to-find help topic you mention. I had to guess myself that the namespace I declared inside code were appended to the root namespace of the project. I am ok with the fact that this is a defined behavior in VB, however, I am not convinced that there is no bug in the way this hides previously defined namespaces.
For instance, I have a project like this:
references: Company.dll wich is a company wide component that embedes some classes in the "Company" namespace (I know this is not a good practice, but this is our legacy).
root namespace: Company.Application
namespace Company.Application.Process
'this actually creates Comapny.Application.Company.Application.Process
class1
sub method1
end sub
end class1
end namespace
'this second class is not wrapped in a namespace, only root namespace is used
class2
sub method2
dim a as Company.frameworkClass1
'this cannot resolve to a class that is located in the Company.dll
'Intellisense shows that at this stage that only
'Company.Application.Process is visible. I have to resort to
'Global.Company.frameworkClass1
end sub
end class2
Of course this is not what I was tryin to do. I should define namespace Process and not namespace Company.Application.Process because Company.Application will be appended anyway. In the end, I would like Microsoft to allow a definition like this:
namespace Global.Company.Application.Porcess
or even
namespace Global
This would would be a nice way to bypass the root namespace. In my view the root namespace should be a convinience feature to reduce the ammount of code for the assembly, not such a hard restriction you cannot choose to include something that is out of the root namespace in the same assembly.
Make sense?