[Lazarus] Support for dotted unit name

Hans-Peter Diettrich DrDiettrich1 at aol.com
Fri Nov 4 11:15:43 CET 2011


William Oliveira Ferreira schrieb:
> Sorry about my low knowlegde, maybe i am the most slow-learning mailer
> of this list but i don't understand the advantage of using dots on
> unit name. Could someon explain it to me?

It's not an advantage, only a relict from the (never finished) .NET
experiment. It's kind of emulation of the .NET namespaces or assemblies,
where e.g. System.System could denote the Delphi System unit in the .NET
namespace (or assembly) System.

As others already pointed out, dotted unit names can cause problems with 
Delphi qualified names. Without dotted unit names "a.b.c" 
(unit.object.method) is somewhat easy to parse, since only "a" has to be 
searched in the used units list. But with dotted names the search also 
must try to match "a.b" (or more) with a unit name. You may get wrong 
results, when unit "a" contains a record or object variable "b" with 
field "c", and a variable "a" in some other unit refers to an record (or 
object) with fields "b.c".

There exist more relicts from .NET, like Unicode names for identifiers. 
Since Delphi identifiers are case insensitive, the lookup of an 
identifier then can be quite time consuming. While with ASCII names only 
the "capital" bit must be cleared for all characters, in order to make 
an identifier name unique (all uppercase), no such simple mapping exists 
for non-ASCII characters. In C or C# all identifiers are case-sensitive, 
so that no ToUpper or ToLower are required before the lookup of an 
identifier, and consequently it doesn't matter whether an identifier 
contains strange characters. IMO it were better to make Delphi 
identifier names case sensitive at the same time, at least when they 
contain non-ASCII characters.

DoDi





More information about the Lazarus mailing list