All of lore.kernel.org
 help / color / mirror / Atom feed
* git clone -l
@ 2008-03-05  0:03 Daniel Barkalow
  2008-03-05  0:32 ` Junio C Hamano
  0 siblings, 1 reply; 4+ messages in thread
From: Daniel Barkalow @ 2008-03-05  0:03 UTC (permalink / raw)
  To: git; +Cc: Junio C Hamano

What, exactly, is -l supposed to do for clone? As far as I can tell, we 
automatically do the local magic if we can. Would it be okay to make 
"local" default to "if possible", have "-l" mean error if not possible, 
and have "--no-local" able to avoid using local magic even if we could use 
it?

	-Daniel
*This .sig left intentionally blank*

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: git clone -l
  2008-03-05  0:03 git clone -l Daniel Barkalow
@ 2008-03-05  0:32 ` Junio C Hamano
  2008-03-05  0:45   ` Daniel Barkalow
  2008-03-05  0:53   ` Brandon Casey
  0 siblings, 2 replies; 4+ messages in thread
From: Junio C Hamano @ 2008-03-05  0:32 UTC (permalink / raw)
  To: Daniel Barkalow; +Cc: git

Daniel Barkalow <barkalow@iabervon.org> writes:

> What, exactly, is -l supposed to do for clone? As far as I can tell, we 
> automatically do the local magic if we can. Would it be okay to make 
> "local" default to "if possible", have "-l" mean error if not possible, 
> and have "--no-local" able to avoid using local magic even if we could use 
> it?

It used to be that "-l" meant "When it is local, use hardlink if possible
otherwise copy without complaining, as either are cheaper than the pack
piped to unpack."  Lack of -l meant no local magic.

Recently lack of -l stopped to mean "no local magic".  We still do the
local magic, but we do not do hardlinks and instead do copies.  An "-l"
that asks clone across filesystems still falls back to copying but now
gets a warning.  "--no-hardlinks" does not have any significance anymore,
as that is what you would get for a local clone without -l.

The way to refuse local magic is to use file://$path/ explicitly; we do
not have --no-local.

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: git clone -l
  2008-03-05  0:32 ` Junio C Hamano
@ 2008-03-05  0:45   ` Daniel Barkalow
  2008-03-05  0:53   ` Brandon Casey
  1 sibling, 0 replies; 4+ messages in thread
From: Daniel Barkalow @ 2008-03-05  0:45 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: git

On Tue, 4 Mar 2008, Junio C Hamano wrote:

> Daniel Barkalow <barkalow@iabervon.org> writes:
> 
> > What, exactly, is -l supposed to do for clone? As far as I can tell, we 
> > automatically do the local magic if we can. Would it be okay to make 
> > "local" default to "if possible", have "-l" mean error if not possible, 
> > and have "--no-local" able to avoid using local magic even if we could use 
> > it?
> 
> It used to be that "-l" meant "When it is local, use hardlink if possible
> otherwise copy without complaining, as either are cheaper than the pack
> piped to unpack."  Lack of -l meant no local magic.
> 
> Recently lack of -l stopped to mean "no local magic".  We still do the
> local magic, but we do not do hardlinks and instead do copies.  An "-l"
> that asks clone across filesystems still falls back to copying but now
> gets a warning.  "--no-hardlinks" does not have any significance anymore,
> as that is what you would get for a local clone without -l.
> 
> The way to refuse local magic is to use file://$path/ explicitly; we do
> not have --no-local.

Ah, okay. I was having a hard time getting the not-using-local-magic case 
to be clearly not using local magic, but I think that was confusion on my 
part. Also, it looks like we need a test that not using -l is equivalent 
to --no-hardlinks.

Would it be okay to additionally block local magic, even with a local 
path, if "--no-local" is used? Using our parse-options code means 
--no-local is accepted anyway, and it's a bit confusing that it doesn't 
block default local magic. (Obviously, this won't break anything, since 
old code wouldn't have accepted it.)

	-Daniel
*This .sig left intentionally blank*

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: git clone -l
  2008-03-05  0:32 ` Junio C Hamano
  2008-03-05  0:45   ` Daniel Barkalow
@ 2008-03-05  0:53   ` Brandon Casey
  1 sibling, 0 replies; 4+ messages in thread
From: Brandon Casey @ 2008-03-05  0:53 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: Daniel Barkalow, git

Junio C Hamano wrote:
> Daniel Barkalow <barkalow@iabervon.org> writes:
> 
>> What, exactly, is -l supposed to do for clone? As far as I can tell, we 
>> automatically do the local magic if we can. Would it be okay to make 
>> "local" default to "if possible", have "-l" mean error if not possible, 
>> and have "--no-local" able to avoid using local magic even if we could use 
>> it?
> 
> It used to be that "-l" meant "When it is local, use hardlink if possible
> otherwise copy without complaining, as either are cheaper than the pack
> piped to unpack."  Lack of -l meant no local magic.
> 
> Recently lack of -l stopped to mean "no local magic".  We still do the
> local magic, but we do not do hardlinks and instead do copies.  An "-l"
> that asks clone across filesystems still falls back to copying but now
> gets a warning.  "--no-hardlinks" does not have any significance anymore,
> as that is what you would get for a local clone without -l.

Are you sure?
I thought this was changed by 3d5c418f so that hardlinking is done by default.

  Lack of -l means "do local magic and use hard links".
  Using -l makes git-clone print a warning when hard linking fails.
  --no-hardlinks disables hard linking and still does local magic.

-brandon


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2008-03-05  0:54 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-03-05  0:03 git clone -l Daniel Barkalow
2008-03-05  0:32 ` Junio C Hamano
2008-03-05  0:45   ` Daniel Barkalow
2008-03-05  0:53   ` Brandon Casey

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.