Re-organize sources
[babeltrace.git] / src / common / Makefile.am
CommitLineData
578e048b
MJ
1AM_CPPFLAGS += -DINSTALL_LIBDIR=\"$(libdir)\"
2
3noinst_LTLIBRARIES = libbabeltrace2-common.la
4
5libbabeltrace2_common_la_SOURCES = \
6 assert.h \
7 assert.c \
8 common.c \
9 common.h \
10 logging.c \
11 logging.h
12
13noinst_HEADERS = \
14 align.h \
15 babeltrace.h \
16 list.h \
17 mmap-align.h \
18 version.h \
19 version.i
20
21##
22## This target generates an include file that contains the git version
23## string of the current branch, it must be continuously updated when
24## we build in the git repo and shipped in dist tarballs to reflect the
25## status of the tree when it was generated. If the tree is clean and
26## the current commit is tag a starting with "v", consider this a
27## release version and set an empty git version.
28##
29## Here is what the inline script does:
30##
31## First, delete any stale "version.i.tmp" file.
32##
33## If "bootstrap" and ".git" exists in the top source directory and the git
34## executable is available, get the current git version string in the form:
35##
36## "latest_tag"(-"number_of_commits_on_top")(-g"latest_commit_hash")(-dirty)
37##
38## And store it in "version.i.tmp", if the current commit is tagged, the tag
39## starts with "v" and the tree is clean, consider this a release version and
40## overwrite the git version with an empty string in "version.i.tmp".
41##
42## If we don't have a "version.i.tmp" nor a "version.i", generate an empty
43## string as a failover.
44##
45## If we don't have a "version.i" or we have both files and they are different,
46## copy "version.i.tmp" over "version.i". This way the dependent targets are
47## only rebuilt when the version string changes.
48##
49
50version_verbose = $(version_verbose_@AM_V@)
51version_verbose_ = $(version_verbose_@AM_DEFAULT_V@)
52version_verbose_0 = @echo " GEN " $@;
53
54version.i:
55 $(version_verbose)rm -f version.i.tmp; \
56 if (test -r "$(top_srcdir)/bootstrap" && test -r "$(top_srcdir)/.git") && \
57 test -x "`which git 2>&1;true`"; then \
58 GIT_VERSION_STR="`cd "$(top_srcdir)" && git describe --tags --dirty`"; \
59 GIT_CURRENT_TAG="`cd "$(top_srcdir)" && git describe --tags --exact-match --match="v[0-9]*" HEAD 2> /dev/null`"; \
60 echo "#define GIT_VERSION \"$$GIT_VERSION_STR\"" > version.i.tmp; \
61 if ! $(GREP) -- "-dirty" version.i.tmp > /dev/null && \
62 test "x$$GIT_CURRENT_TAG" != "x"; then \
63 echo "#define GIT_VERSION \"\"" > version.i.tmp; \
64 fi; \
65 fi; \
66 if test ! -f version.i.tmp; then \
67 if test ! -f version.i; then \
68 echo '#define GIT_VERSION ""' > version.i; \
69 fi; \
70 elif test ! -f version.i || \
71 test x"`cat version.i.tmp`" != x"`cat version.i`"; then \
72 mv version.i.tmp version.i; \
73 fi; \
74 rm -f version.i.tmp; \
75 true
76
77##
78## version.i is defined as a .PHONY target even if it's a real file,
79## we want the target to be re-run on every make.
80##
81.PHONY: version.i
82
83CLEANFILES = version.i.tmp
84
85##
86## Only clean "version.i" on dist-clean, we need to keep it on regular
87## clean when it's part of a dist tarball.
88##
89DISTCLEANFILES = version.i
This page took 0.03471 seconds and 4 git commands to generate.