diff options
Diffstat (limited to 'Makefile.am')
-rw-r--r-- | Makefile.am | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 00000000..be8e9140 --- /dev/null +++ b/Makefile.am @@ -0,0 +1,123 @@ +### C source files to be built and distributed. + +JQ_INCS = jq_parser.h builtin.h bytecode.h compile.h execute.h \ + forkable_stack.h frame_layout.h jv.h jv_alloc.h jv_aux.h jv_dtoa.h \ + jv_parse.h jv_unicode.h locfile.h opcode.h opcode_list.h parser.y \ + jv_utf8_tables.h lexer.l + +JQ_SRC = opcode.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_alloc.c \ + jq_test.c ${JQ_INCS} + + +### C build options + +AM_CFLAGS = -Wextra -Wall -Wno-missing-field-initializers \ + -Wno-unused-parameter -Wno-unused-function + + +### 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 +lexer.c: lexer.l + 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 + + +### Building the jq binary + +main.c: config.h + +bin_PROGRAMS = jq +jq_SOURCES = ${JQ_SRC} main.c + + +### 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 + ( cd ${abs_srcdir}/docs; '$(BUNDLER)' exec rake manpage ) > $@ || { rm -f $@; false; } +jq.1.default: $(srcdir)/docs/default_manpage.md + ( 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 + 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 = config.h.in $(BUILT_SOURCES) $(man_MANS) $(TESTS) \ + $(TEST_LOG_COMPILER) gen_utf8_tables.py jq.spec \ + $(DOC_FILES) + +# 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 + +releasetag: + git tag -s "jq-$$(cat VERSION)" -m "jq release $$(cat VERSION)" + +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? +clean-local: + rm -f jq.1 |