Differences between revisions 3 and 13 (spanning 10 versions)
Revision 3 as of 2010-01-11 13:37:59
Size: 2236
Comment:
Revision 13 as of 2010-02-22 11:19:30
Size: 2228
Comment: better make rule (thanks to Teemu Murtola)
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:
Add the following line to your Makefile
Line 3: Line 4:
Add the following line to your Makefile
Line 5: Line 5:
HGVERSION:= $(shell hg parents --template 'hgid: {node|short}' HGVERSION:= $(shell hg parents --template 'hgid: {node|short}')
Line 8: Line 8:
Line 15: Line 16:
Line 16: Line 18:
version.cc: hgstamp
hgstamp: update_hgstamp
update_hgsta
mp:
        [ -f hgstamp ] || touch hgstamp
        echo $(HGVERSION) | cmp -s hgstamp - || echo $(HGVERSION) > hgstamp
version.o: hgstamp
hgstamp: dummy
        [ -f $@ ] || touch $@
        echo $(HGVERSION) | cmp -s $@ - || echo $(HGVERSION) > $@

du
mmy: ;
Line 22: Line 25:
In this example version.cc depend has the extra dependency hgstamp, which is generated by the rule 'update_hgstamp'. This rule updates hgstamp if and only if the version has ''realy'' changed. In this example version.o has the extra dependency hgstamp. The hgstamp rule updates hgstamp if and only if the version has ''really'' changed.
To make sure the hgstamp rule will be executed every time, it depends on a dummy rule, which does nothing.
Line 26: Line 30:
Line 27: Line 32:
HGVERSION:= $(shell hg -R $(top_builddir) parents --template 'hgid: {node|short}' 2> /dev/null || grep node $(top_builddir)/.hg_archival.txt 2> /dev/null || true ) HGVERSION:= $(shell hg -R $(top_srcdir) parents --template 'hgid: {node|short}' 2> /dev/null || grep node $(top_srcdir)/.hg_archival.txt 2> /dev/null || true )
Line 30: Line 35:
version.cc: hgstamp
hgstamp: update_hgstamp
update_hgsta
mp:
        [ -f hgstamp ] || touch hgstamp
        echo $(HGVERSION) | cmp -s hgstamp - || echo $(HGVERSION) > hgstamp
version.o: hgstamp
hgstamp: dummy
        [ -f $@ ] || touch $@
        echo $(HGVERSION) | cmp -s $@ - || echo $(HGVERSION) > $@

du
mmy: ;
Line 37: Line 43:
* hg parents, the -R options is added to prevent hg to search in lower directories in the case we don't have a repository
* grabbing it from .hg_archival.txt, in case we are using a tarball made by hg archive
* undefined

 
* hg parents, the -R option is added to prevent hg to search in lower directories in the case we don't have a repository
 * grabbing it from .hg_archival.txt, in case we are using a tarball made by hg archive
 * undefined
Line 43: Line 50:
Line 45: Line 53:
hgid.tex: update_hgid
update_hgid:

        [ -f hgid.tex ] || touch hgid.tex
        echo '$(HGID)' | cmp -s hgid.tex - || echo '$(HGID)' > hgid.tex
hgid.tex: dummy
        [ -f $@ ] || touch $@
        echo '$(HGID)' | cmp -s $@ - || echo '$(HGID)' > $@

dummy: ;
Line 51: Line 60:
Line 56: Line 66:

----
CategoryHowTo

Simple

Add the following line to your Makefile

HGVERSION:= $(shell hg parents --template 'hgid: {node|short}')

and

-DHGVERSION="\"${HGVERSION}\""

to your CPPFLAGS. Now one can use the define HGVERSION inside the code.

Rebuild files using HGVERSION

Make rebuilds targets only if one of the dependencies is newer. That means even if the version has changed, due to a change somewhere, files using HGVERSION will not be rebuild automatically. To overcome this add new dependency in the Makefile to updated these files:

version.o: hgstamp
hgstamp: dummy
        [ -f $@ ] || touch $@
        echo $(HGVERSION) | cmp -s $@ - || echo $(HGVERSION) > $@

dummy: ;

In this example version.o has the extra dependency hgstamp. The hgstamp rule updates hgstamp if and only if the version has really changed. To make sure the hgstamp rule will be executed every time, it depends on a dummy rule, which does nothing.

Autotools

If you are using automake add the following lines to your Makefile.am

HGVERSION:= $(shell hg -R $(top_srcdir) parents --template 'hgid: {node|short}' 2> /dev/null || grep node $(top_srcdir)/.hg_archival.txt 2> /dev/null || true )
AM_CPPFLAGS = -DHGVERSION="\"${HGVERSION}\""

version.o: hgstamp
hgstamp: dummy
        [ -f $@ ] || touch $@
        echo $(HGVERSION) | cmp -s $@ - || echo $(HGVERSION) > $@

dummy: ;

The definition of HGVERSION is more robust here. It tries to get the version in the following order

  • hg parents, the -R option is added to prevent hg to search in lower directories in the case we don't have a repository
  • grabbing it from .hg_archival.txt, in case we are using a tarball made by hg archive
  • undefined

LaTeX

Just a add the following lines to your Makefile

HGID:=$(shell hg parents -R . --template "{node|short}" | sed 's/.*/\\renewcommand{\\hgid}{&}/')
hgid.tex: dummy
        [ -f $@ ] || touch $@
        echo '$(HGID)' | cmp -s $@ - || echo '$(HGID)' > $@

dummy: ;

and this lines to your main tex file

\newcommand{\hgid}{null}
\input{hgid}

now one can use the command \hgid to get the version everywhere.


CategoryHowTo

VersioningWithMake (last edited 2015-08-10 06:26:49 by follower)