On 5/11/05, Petr Baudis <pasky@ucw.cz> wrote: > Dear diary, on Tue, May 10, 2005 at 05:00:33PM CEST, I got a letter > where Jon Seymour <jon.seymour@gmail.com> told me that... > > Yes. And that's how it should be - the directory cache is just that - a > _cache_. No argument there. > So unlike the objects database which has well-defined format and is > supposed to be "public", you should view the directory cache as internal > git tools' structure. If you want to mess with it too, either use the > proper level of abstraction and call the git tools, or don't mess with > it at all. And you need to care about it only if you want the git tools > working on the same tree properly too - so in that case use the git > tools too. I agree in principle, though I'd like users to be able to easily switch between the Eclipse and git tools view of the workspace if they want to - who am I to say how a user should work? Eclipse does this kind of thing quite well with CVS precisely because it shares the workspace structures with the CVS command line tools rather than "re-inventing" the wheel. Yes, separation of concerns has been lost (two implementations of a CVS client), but the big win is that the tools behave like the user wants them to behave. The trickiest case here is when the user switches between toolsets mid-merge. I guess what I can do is this: user switch from eclipse -> to git-tools: 1. blow away existing git tools index 2. use git-read-tree to repeat the merge executed in eclipse (my workspace will track parents) 3. use git-update-cache --add/--remove to reflect merge actions that have occurred since the workspace deviated from the HEAD. Alternatively, I can just make Eclipse reflect cache changing actions out onto the git-tools, via an exec of those tools, as and when they occur. Making use of the git tools index going the other way isn't so easy to achieve because the git tools workspace as it stands doesn't track the merges that have occurred (i.e. which parents were used to form the current cache). However, that's not necessarily a big problem. I just rebuild my "cache" from scratch based on the merges I know about and treat every other difference from the HEAD as a user edit to the workspace. > > From your arguments, it's not clear to me what really is the big > problem with the git tools. They are _designed_ for automatic use > instead of human interaction - you can perceive them just as methods > with funny (but actually friendly to your programs) calling convention. > I am not really arguing that there is a big problem with the existing git tools. However, what I am arguing is that the existing workspace tools are just one way to manage the workspace (Eclipse might be another, as an example) and it would be helpful to keep this in mind, particularly when/if libification ever happens. jon. - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.htmlReceived on Wed May 11 10:50:33 2005
This archive was generated by hypermail 2.1.8 : 2005-05-11 10:50:34 EST