views:

268

answers:

4

I am frequently having naming conflicts between a namespace and a class within that namespace and would like to know a best practice for handling this when it seems to make sense to use these names in the first place, besides adding random prefixes.

It seemed to make sense to have a Models.Technology namespace, with dozens of technology classes (ie. Weapon, Agricultural, Recycling technologies) and some related interfaces in it. I also decided to have a Technology abstract class, in the Technology namespace, from which all technologies derive.

However, this is forcing me to use code like this:

public Technology.Technology research(Technology.Technology tech) {...}

and likewise:

public Building.Building build(int count) {...}

By the way I did not name my namespace Technologies since I use that term elsewhere as a wrapper for a list of available technologies...

+12  A: 

Without more precise indications on when you encounter this problem it's hard to give you some general advice.

But I'm gonna suppose you have this problem when you have a base class in your namespace, with others classes inheriting from it. If that's the case you could call your class BaseTechnology (base class) or AbstractBuilding (abstract class) or IAnimal (interface). This even give you more clarity since you specify in the name of your type something important about it.

Ksempac
Thank you, that seems to be all I needed!
PRINCESS FLUFF
+1  A: 

Well, whether your name your namespaces like that nsMyNamespace or you name you class cMyClasse. I'm personnaly in favor of naming the namespace, because it's not something you use a lot in code.

You can also use TechnologyBase or AbstractTechnology for naming your main abstract class that conflict with the name of your namespace, which is what i recommend to keep the most logical naming convention.

Clement Herreman
A: 

another cope out, just call the namespace after the name of the company you are working for.

Phill
I don't think this will work because I'm talking about the last word of the namespace. ex: Microsoft.Stuff.Technology. And here Technology conflicts with a Technology abstract class in it.
PRINCESS FLUFF
Actually you could/should prefix all your namespaces with your companyname, but that doesn't solve the problem.
Henk Holterman
A: 

What about Technology.Tech

or:

HumanBeing.Human

or:

CocaCola.Coke ?

What I like to do is have a simple rule. Where I use the first two letters of a word, followed by the last two letters of that word like:

Technology.Tegy

It may not make any sense, but because the same rule always applies, it means less confusion, and there's no need to remember much, except for that one rule. This is just my preference. I, myself like things to look cryptic, so if that's not your style - then maybe this answer isn't for you.

I hope this helps... Atleast a little... :)

baeltazor