Suggestion: Object filenames should be fully-qualified module names

Chris Nicholson-Sauls ibisbasenji at gmail.com
Sat Jan 20 10:57:42 PST 2007


Kirk McDonald wrote:
> I originally heard this idea proposed by Gregor Richards in #d, and I
> think it should become DMD's default behavior. If it is not the default 
> behavior, then it should at least be available as an option.
> 
> Perhaps my biggest grievance with both the DMD and GDC compilers is
> their handling of object files. DMD's default behavior is to dump all
> object files into the current directory. If the -od option is specified,
> the object files will be placed into the specified directory instead. If
> -op is specified, the object files are placed alongside the original 
> source files.
> 
> The default behavior and using -od on its own both fail if any two 
> source files in the project have the same name, even if they are in 
> different packages. Using -op by itself is unappealing for two reasons:
> 
> 1) It is not unreasonable to expect a system to place libraries in 
> directories to which the user does not have write access. Placing object 
> files alongside the source files would therefore fail.
> 
> 2) It pollutes the source directories with object files. I much prefer 
> keeping my object files somewhere to the side, in a designated "build" 
> directory. This makes keeping projects in version control much easier, 
> as I can simply exclude the one directory to keep object files out of 
> version control.
> 
> Specifying both -op and -od causes things to get a little more 
> interesting. Take the following:
> 
> test.d
> testpkg
>   test.d
> 
> // test.d
> module test;
> import testpkg.test : foo;
> void main() {
>     foo();
> }
> 
> // testpkg/test.d
> module testpkg.test;
> import std.stdio : writefln;
> void foo() { writefln("foo"); }
> 
> If we compile with this:
> 
> $ dmd test.d testpkg/test.d -op -odbuild
> 
> The "build" directory has the following structure:
> 
> build
>   test.obj
>   testpkg
>     test.obj
> 
> This is all and well. However, if we compile like this:
> 
> $ dmd test.d /path/to/testpkg/test.d -op -odbuild
> 
> Then DMD doesn't know what to do, and it places testpkg/test.obj 
> alongside the source file. (More specifically, the full path is "joined" 
> to the path specified by -od, which works out to just being the full path.)
> 
> This ambiguity can be disposed of if an object file's name is its 
> fully-qualified module name. If this were true, then we could just say
> 
> $ dmd test.d testpkg/test.d -odbuild
> 
> and the result would be the build directory looking like this:
> 
> build
>   test.obj
>   testpkg.test.obj
> 
> I find this very clean and simple. Since the compiler fails anyway if 
> two modules have the same name, there should not ever be overlaps in 
> object file names with this scheme. The -op option could probably be 
> safely deprecated.
> 
> As someone pointed out in #d, this would fail on NTFS if the module's 
> fully-qualified name exceeds 255 characters. Though I cannot recall ever 
> using a module whose name even approached that limit, this should be 
> solved in most cases by truncating the filename at the start. 
> (Hopefully, the last 255 characters are unique.) If the object file 
> would fail to be unique even then, it can probably be safely declared 
> the coder's fault for using a stupid naming scheme.
> 

Personally, I would love it.  (I already use a little utility to do this to DDoc output, 
changing pkg/Module.html to pkg.Module.html.)

-- Chris Nicholson-Sauls



More information about the Digitalmars-d mailing list