summaryrefslogtreecommitdiffstats
path: root/Makefile.am
blob: b3b8fa0f323feee0bc51a91a3fd0979a4e5df806 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
### C source files to be built and distributed.

LIBJQ_INCS = jq_parser.h builtin.h bytecode.h compile.h exec_stack.h	\
   jv_alloc.h jv_dtoa.h jv_parse.h jv_unicode.h locfile.h		\
   opcode_list.h parser.y jv_utf8_tables.h lexer.l

LIBJQ_SRC = locfile.c bytecode.c compile.c execute.c builtin.c jv.c	\
  jv_parse.c jv_print.c jv_dtoa.c jv_unicode.c jv_aux.c jv_file.c	\
  jv_alloc.c jq_test.c ${LIBJQ_INCS}


### C build options

AM_CFLAGS = -Wextra -Wall -Wno-missing-field-initializers	\
  -Wno-unused-parameter -Wno-unused-function

ACLOCAL_AMFLAGS = -I m4

### Generating the lexer and parser

# While there is some autoconf macro support for lex/flex, it doesn't support
# header file creation so we'll use good old make
BUILT_SOURCES = lexer.h lexer.c parser.h parser.c version.h
lexer.c: lexer.l
	$(AM_V_LEX) flex -o lexer.c --header-file=lexer.h $<
lexer.h: lexer.c

# Tell YACC (bison) autoconf macros that you want a header file created.
# If the --warnings=all fails, you probably have an old version of bison
# OSX ships an old bison, so update with homebrew or macports
AM_YFLAGS = --warnings=all -d

### libjq

lib_LTLIBRARIES = libjq.la
libjq_la_SOURCES = ${LIBJQ_SRC}
libjq_la_LIBADD = -lm
if HAVE_LD_VERSION_SCRIPT
libjq_la_LDFLAGS = -Wl,--version-script=$(srcdir)/libjq.map -version-info 1:4:0
endif

include_HEADERS = jv.h jq.h


### Building the jq binary

# Remake the version.h header file if, and only if, the git ID has changed
.PHONY: .FORCE
.FORCE:
generate_ver = ver="`{ $(srcdir)/scripts/version || echo '$(VERSION)' ; } | sed 's/.*/\#define JQ_VERSION \"&\"/'`"
.remake-version-h: .FORCE
	@ $(generate_ver); test "x`cat version.h 2>/dev/null`" = "x$$ver" || touch .remake-version-h
version.h: .remake-version-h
	$(AM_V_GEN) $(generate_ver); echo "$$ver" > $@

bin_PROGRAMS = jq
jq_SOURCES = main.c
jq_LDFLAGS = -static-libtool-libs
jq_LDADD = libjq.la -lm

### Tests (make check)

TESTS = tests/all.test
TEST_LOG_COMPILER = ${srcdir}/tests/run


### Building the manpage

# If ENABLE_DOCS is not set, just copy jq.1.default to jq.1
# The real_docs target succeeds (possibly after building jq.1) only if ENABLE_DOCS is set
# Thus, making "dist" depend on "real_docs" ensures that we never build a tarball with
# a stub manpage.

man_MANS = jq.1
.PHONY: real_docs
if ENABLE_DOCS
jq.1: $(srcdir)/docs/content/3.manual/manual.yml
	$(AM_V_GEN) ( cd ${abs_srcdir}/docs; '$(BUNDLER)' exec rake manpage ) > $@ || { rm -f $@; false; }
jq.1.default: $(srcdir)/docs/default_manpage.md
	$(AM_V_GEN) ( cd ${abs_srcdir}/docs; '$(BUNDLER)' exec rake manpage_default ) > $@ || { rm -f $@; false; }
real_docs: jq.1
	if cmp jq.1 $(srcdir)/jq.1.default > /dev/null; then\
	  rm -f jq.1; $(MAKE) $(AM_MAKEFLAGS) jq.1;\
	fi
else
jq.1: $(srcdir)/jq.1.default
	$(AM_V_GEN) cp $^ $@
real_docs:
	@echo "Ruby dependencies not found, cannot build manpage." > /dev/stderr
	@echo "Follow the instructions in docs/README.md to install them" > /dev/stderr
	@echo "and then rerun ./configure" > /dev/stderr
	false
endif


### Packaging

docs/site.yml: configure.ac
	sed 's/^jq_version: .*/jq_version: "$(VERSION)"/' $@ > $@.new
	mv $@.new $@

install-binaries: $(BUILT_SOURCES)
	$(MAKE) $(AM_MAKEFLAGS) install-exec

# Ensure "make dist" fails when we can't build the real manpage
dist-hook: real_docs

DOC_FILES = docs/content docs/public docs/templates docs/site.yml	\
            docs/Gemfile docs/Gemfile.lock docs/Rakefile docs/README.md \
            docs/default_manpage.md jq.1.default

# setup is only used by distribution developers, not package developers.
# Still, as a matter of allowing patching, its not a bad idea to distribute 
# the developer setup script in the tarball.
EXTRA_DIST = $(man_MANS) $(TESTS) $(TEST_LOG_COMPILER)		\
	gen_utf8_tables.py jq.spec $(DOC_FILES) scripts/version	\
	parser.h parser.c lexer.h lexer.c libjq.map

# README.md is expected in Github projects, good stuff in it, so we'll 
# distribute it and install it with the package in the doc directory.
docdir = ${datadir}/doc/${PACKAGE}
dist_doc_DATA = README.md COPYING AUTHORS README

RELEASE ?= 1
rpm: jq
	@echo "Packaging jq as an RPM ..."
	mkdir -p rpm/SOURCES rpm/BUILD rpm/BUILDROOT rpm/RPMS rpm/SPECS
	cp jq-$$(cat VERSION).tar.gz rpm/SOURCES/
	rpmbuild -tb --define "_topdir ${PWD}/rpm" --define "_prefix /usr" --define "myver $$(cat VERSION)" --define "myrel ${RELEASE}" rpm/SOURCES/jq-$$(cat VERSION).tar.gz
	find rpm/RPMS/ -name "*.rpm" -exec mv {} ./ \;
	rm -rf rpm

dist-clean-local:
	rm -f ${BUILT_SOURCES}

# Not sure why this doesn't get cleaned up automatically, guess
# automake used to man pages which are hand coded?
# 'make clean' doesn't delete the manpage if it can't be rebuilt
.PHONY: clean-local-docs
clean-local-docs:
if ENABLE_DOCS
	rm -f jq.1
endif 

clean-local: clean-local-docs
	rm -f version.h .remake-version-h