git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] Cogito chicken-and-egg problem
@ 2005-04-26 16:06 Pavel Roskin
  2005-04-26 16:38 ` Daniel Barkalow
  0 siblings, 1 reply; 4+ messages in thread
From: Pavel Roskin @ 2005-04-26 16:06 UTC (permalink / raw)
  To: git

Hello!

My patch for Makefile was misapplied, so installed commit-id is still
needed for "make" to succeed.

Shell commands are processed by make before being passed to the shell,
and $(...) is expanded by make before new PATH is set, as it is done in
the current Makefile.

Also, the dependency on commit-id was dropped from my patch for some
reason.  I believe it's still needed.  Also, we need a dependency on
cat-file, which is used by commit-id internally.

Signed-off-by: Pavel Roskin <proski@gnu.org>

Index: Makefile
===================================================================
--- f262000f302b749e485f5eb971e6aabefbb85680/Makefile  (mode:100644 sha1:4f01bbbbb3fd0e53e9ce968f167b6dae68fcfa92)
+++ uncommitted/Makefile  (mode:100644)
@@ -87,11 +87,11 @@
 http-pull: LIBS += -lcurl
 
 
-cg-version: $(VERSION)
+cg-version: $(VERSION) commit-id cat-file
 	@echo Generating cg-version...
 	@rm -f $@
 	@echo "#!/bin/sh" > $@
-	@PATH=.:$(PATH) echo "echo \"$(shell cat $(VERSION)) ($(shell commit-id))\"" >> $@
+	@echo "echo \"$(shell cat $(VERSION)) ($(shell PATH=.:$(PATH) ./commit-id))\"" >> $@
 	@chmod +x $@
 
 install: $(PROG) $(SCRIPTS) $(SCRIPT) $(GEN_SCRIPT)


-- 
Regards,
Pavel Roskin


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

* Re: [PATCH] Cogito chicken-and-egg problem
  2005-04-26 16:06 [PATCH] Cogito chicken-and-egg problem Pavel Roskin
@ 2005-04-26 16:38 ` Daniel Barkalow
  2005-04-26 17:02   ` Pavel Roskin
  0 siblings, 1 reply; 4+ messages in thread
From: Daniel Barkalow @ 2005-04-26 16:38 UTC (permalink / raw)
  To: Pavel Roskin; +Cc: git

On Tue, 26 Apr 2005, Pavel Roskin wrote:

> Hello!
> 
> My patch for Makefile was misapplied, so installed commit-id is still
> needed for "make" to succeed.
> 
> Shell commands are processed by make before being passed to the shell,
> and $(...) is expanded by make before new PATH is set, as it is done in
> the current Makefile.
> 
> Also, the dependency on commit-id was dropped from my patch for some
> reason.  I believe it's still needed.  Also, we need a dependency on
> cat-file, which is used by commit-id internally.

commit-id doesn't really use cat-file; the way it calls gitXnormid.sh
definitely suppresses that section. In fact, commit-id with no arguments
is simply an easy-to-remember way of doing "cat .git/HEAD" using a much
more complicated script. Earlier, I sent a patch to just do this, since it
avoids the whole issue.

(Also, .git/HEAD is a dependancy, since you want to redo the version
script if you commit; but if you don't have it, that's okay and just means
you're building from a tarball, which is described completely by VERSION)

	-Daniel
*This .sig left intentionally blank*


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

* Re: [PATCH] Cogito chicken-and-egg problem
  2005-04-26 16:38 ` Daniel Barkalow
@ 2005-04-26 17:02   ` Pavel Roskin
  2005-04-26 17:48     ` Daniel Barkalow
  0 siblings, 1 reply; 4+ messages in thread
From: Pavel Roskin @ 2005-04-26 17:02 UTC (permalink / raw)
  To: Daniel Barkalow; +Cc: git

Hello, Daniel!

On Tue, 2005-04-26 at 12:38 -0400, Daniel Barkalow wrote:

> > Also, the dependency on commit-id was dropped from my patch for some
> > reason.  I believe it's still needed.  Also, we need a dependency on
> > cat-file, which is used by commit-id internally.
> 
> commit-id doesn't really use cat-file; the way it calls gitXnormid.sh

There is gitXnormid.sh in the current cogito.  Please update your tree.

> definitely suppresses that section.

That's not what I see if I remove cat-file but leave commit-id in my
$HOME/bin:

proski@dv:~/src/cogito$ make cg-version
/home/proski/bin/commit-id: line 35: cat-file: command not found
Invalid id: f9f0459b5b39cf83143c91ae39b4eaf187cf678a
Generating cg-version...
proski@dv:~/src/cogito$

> In fact, commit-id with no arguments
> is simply an easy-to-remember way of doing "cat .git/HEAD" using a much
> more complicated script. Earlier, I sent a patch to just do this, since it
> avoids the whole issue.

That would be fine with me.

> (Also, .git/HEAD is a dependancy, since you want to redo the version
> script if you commit; but if you don't have it, that's okay and just means
> you're building from a tarball, which is described completely by VERSION)

It should be a conditional dependency, i.e. it should be a dependency
if .git exists.

It seems to me that the whole idea of including SHA1 in cg-version is
broken.  SHA1 is not human readable.  But if the maintainers insist on
having SHA1 in cg-version, I want it to be done without causing build
warnings for new users.

Here's an alternative patch.

Signed-off-by: Pavel Roskin <proski@gnu.org>

Index: Makefile
===================================================================
--- f262000f302b749e485f5eb971e6aabefbb85680/Makefile  (mode:100644 sha1:4f01bbbbb3fd0e53e9ce968f167b6dae68fcfa92)
+++ uncommitted/Makefile  (mode:100644)
@@ -87,12 +87,21 @@
 http-pull: LIBS += -lcurl
 
 
+ifneq (,$(wildcard .git))
+cg-version: $(VERSION) .git/HEAD
+	@echo Generating cg-version...
+	@rm -f $@
+	@echo "#!/bin/sh" > $@
+	@echo "echo \"$(shell cat $(VERSION)) ($(shell cat .git/HEAD))\"" >> $@
+	@chmod +x $@
+else
 cg-version: $(VERSION)
 	@echo Generating cg-version...
 	@rm -f $@
 	@echo "#!/bin/sh" > $@
-	@PATH=.:$(PATH) echo "echo \"$(shell cat $(VERSION)) ($(shell commit-id))\"" >> $@
+	@echo "echo \"$(shell cat $(VERSION))\"" >> $@
 	@chmod +x $@
+endif
 
 install: $(PROG) $(SCRIPTS) $(SCRIPT) $(GEN_SCRIPT)
 	install -m755 -d $(DESTDIR)$(bindir)


-- 
Regards,
Pavel Roskin


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

* Re: [PATCH] Cogito chicken-and-egg problem
  2005-04-26 17:02   ` Pavel Roskin
@ 2005-04-26 17:48     ` Daniel Barkalow
  0 siblings, 0 replies; 4+ messages in thread
From: Daniel Barkalow @ 2005-04-26 17:48 UTC (permalink / raw)
  To: Pavel Roskin; +Cc: git, Petr Baudis

On Tue, 26 Apr 2005, Pavel Roskin wrote:

> > (Also, .git/HEAD is a dependancy, since you want to redo the version
> > script if you commit; but if you don't have it, that's okay and just means
> > you're building from a tarball, which is described completely by VERSION)
> 
> It should be a conditional dependency, i.e. it should be a dependency
> if .git exists.

True.

> It seems to me that the whole idea of including SHA1 in cg-version is
> broken.  SHA1 is not human readable.  But if the maintainers insist on
> having SHA1 in cg-version, I want it to be done without causing build
> warnings for new users.

The idea is that it should appear if you're building a version that has
changes in its .git; in this case, VERSION is insufficient to tell you
which revision you have installed. If I've got cogito-0.8 + three untagged
commits from the remote repository + two local patches, I'd like to be
able to tell if the installed version is cogito-0.8 + two of the remote
patches. Possibly, it should also suppress the SHA1 if you've got a tagged
head, but identifying this situation is tricky, currently. Eventually, it
should be able to use a cg program to update VERSION from .git/HEAD and
include SHA1 for cases which aren't directly tagged.

> Here's an alternative patch.

I like your version.

	-Daniel
*This .sig left intentionally blank*


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

end of thread, other threads:[~2005-04-26 17:55 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-04-26 16:06 [PATCH] Cogito chicken-and-egg problem Pavel Roskin
2005-04-26 16:38 ` Daniel Barkalow
2005-04-26 17:02   ` Pavel Roskin
2005-04-26 17:48     ` Daniel Barkalow

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).