On Sat, Jun 02, 2007 at 09:34:26AM -0700, Linus Torvalds wrote: > On Sat, 2 Jun 2007, Sven Verdoolaege wrote: > > On Fri, Jun 01, 2007 at 09:29:58AM -0700, Linus Torvalds wrote: > > > [module "infrastructure"] > > > submodule = lib > > > submodule = build > > > > > > [submodule "lib"] > > > url = git://xyzzy/lib-1.2.3 > > > > > > [submodule "build"] > > > url = git://xyzzy/build-0.61 > > > > > > > > > IOW, in the above case, we have *three* modules: > > > > > > - module "infrastructure", that is the union of submodules/paths "lib" > > > and "build" > > > - module "lib" (== submodule/path "lib") > > > - module "build" (== submodule/path "build") > > > > If there are three modules, then why is one in the "module" section > > and the other two in the "submodule" section? > > Because there are: > > - *two* actual submodules (== path), namely "lib" and "build". > > - each submodule always is *implicitly* a module too > > - we have a *named* (aka explicit) module "infrastructure" that is a > higher-level name for one or more submodules (in this case two). > > So the implicit modules could have been written out: > > [module "lib"] > submodule = "lib" # aka 'path = "lib"' > > [module "build"] > submodule = "build" # aka 'path = "build"' > > but my suggestion was that if the module name and the path name are the > same, you don't need to say it. > > (And quite frankly, I think it reads better as "submodule" than as "path", > but maybe that threw you). I did indeed glance over the "submodule == path" in your mail (and it seems Junio did so too). I thought it was more or less agreed that the URL should be associated to the logical module rather than the path (which you call "submodule" here). See http://article.gmane.org/gmane.comp.version-control.git/47567 . Personally, I find your section names confusing. Both your "submodule"s and "module"s are submodules from the point of view of the project containing the .gitmodules. And anything in the "submodule" section is only a (proper) submodule of some other module if there happens to be a "module" containing it. What's wrong with the following? [module "infrastructure"] submodule = lib submodule = build [module "lib"] url = git://xyzzy/lib-1.2.3 [module "build"] url = git://xyzzy/build-0.61 A module with a "url" attribute can be cloned from that url. A module with one or more "submodule" attributes requires these modules as well. > > Why not allow a module to both contain smaller modules and be contained > > in a bigger module? > > Because the "module" definition is _different_ from the "submodule" > definition. >From the point of view of the user, they are the same. They can both be used as an argument to git submodule checkout > The "module" definition is just a level of indirection. But why limit yourself to _one_ level of indirection? If you call everything a "module" (or everything a "submodule") then you get multiple levels of indirection for free. skimo - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html