2015-11-10 22:28:12 +08:00
|
|
|
# Makefile to generate the extension out of separate sql source files.
|
|
|
|
# Once a version is released, it is not meant to be changed. E.g: once version 0.0.1 is out, it SHALL NOT be changed.
|
2016-02-06 00:57:56 +08:00
|
|
|
EXTENSION = cdb_dataservices_client
|
2015-11-10 22:28:12 +08:00
|
|
|
EXTVERSION = $(shell grep default_version $(EXTENSION).control | sed -e "s/default_version[[:space:]]*=[[:space:]]*'\([^']*\)'/\1/")
|
|
|
|
|
2016-01-22 23:14:11 +08:00
|
|
|
# The new version to be generated from templates
|
2016-11-07 20:59:57 +08:00
|
|
|
SED = sed
|
|
|
|
ERB = erb
|
|
|
|
REPLACEMENTS = -i 's/$(EXTVERSION)/$(NEW_VERSION)/g'
|
2016-01-22 23:14:11 +08:00
|
|
|
NEW_EXTENSION_ARTIFACT = $(EXTENSION)--$(EXTVERSION).sql
|
|
|
|
|
2016-11-07 20:59:57 +08:00
|
|
|
# OLD_VERSIONS = $(wildcard old_versions/*.sql)
|
|
|
|
# DATA = $(NEW_EXTENSION_ARTIFACT) \
|
|
|
|
# $(OLD_VERSIONS) \
|
|
|
|
# cdb_dataservices_client--0.11.0--0.11.1.sql \
|
|
|
|
# cdb_dataservices_client--0.11.1--0.11.0.sql
|
|
|
|
OLD_VERSIONS = $(wildcard old_versions/*.sql)
|
|
|
|
DATA = $(NEW_EXTENSION_ARTIFACT) \
|
|
|
|
$(EXTENSION)--*--*.sql \
|
|
|
|
$(OLD_VERSIONS)
|
|
|
|
SOURCES_DATA_DIR = sql/
|
2016-01-22 23:14:11 +08:00
|
|
|
|
2016-01-22 17:37:40 +08:00
|
|
|
|
2016-04-20 17:17:30 +08:00
|
|
|
REGRESS = $(notdir $(basename $(wildcard test/sql/*test.sql)))
|
|
|
|
TEST_DIR = test/
|
2016-11-07 20:59:57 +08:00
|
|
|
REGRESS_OPTS = --inputdir='$(TEST_DIR)' --outputdir='$(TEST_DIR)' --user='postgres'
|
2015-11-10 22:28:12 +08:00
|
|
|
|
2016-11-07 20:59:57 +08:00
|
|
|
# DATA is a special variable used by postgres build infrastructure
|
|
|
|
# These are the files to be installed in the server shared dir,
|
|
|
|
# for installation from scratch, upgrades and downgrades.
|
|
|
|
# @see http://www.postgresql.org/docs/current/static/extend-pgxs.html
|
2015-11-10 22:28:12 +08:00
|
|
|
|
2015-11-18 23:17:36 +08:00
|
|
|
# The interface definition is used along with some templates to automatically generate code
|
2016-02-04 22:18:19 +08:00
|
|
|
RENDERER = renderer/sql-template-renderer
|
2016-04-20 17:17:30 +08:00
|
|
|
INTERFACE_FILE = renderer/interface.yaml
|
2016-02-04 22:18:19 +08:00
|
|
|
TEMPLATE_DIR = renderer/templates
|
2015-11-18 23:17:36 +08:00
|
|
|
TEMPLATE_FILES = $(wildcard $(TEMPLATE_DIR)/*.erb)
|
|
|
|
GENERATED_SQL_FILES = $(patsubst $(TEMPLATE_DIR)/%.erb, $(SOURCES_DATA_DIR)/%.sql, $(TEMPLATE_FILES))
|
|
|
|
|
2016-11-07 20:59:57 +08:00
|
|
|
# postgres build stuff
|
|
|
|
PG_CONFIG = pg_config
|
|
|
|
PGXS := $(shell $(PG_CONFIG) --pgxs)
|
|
|
|
include $(PGXS)
|
|
|
|
|
2015-11-18 23:17:36 +08:00
|
|
|
$(GENERATED_SQL_FILES): $(SOURCES_DATA_DIR)/%.sql: $(TEMPLATE_DIR)/%.erb $(INTERFACE_FILE) $(RENDERER)
|
|
|
|
$(RENDERER) $(INTERFACE_FILE) $< > $@
|
|
|
|
|
2015-11-19 01:38:06 +08:00
|
|
|
SOURCES_DATA = $(wildcard $(SOURCES_DATA_DIR)/*.sql) $(GENERATED_SQL_FILES)
|
2015-11-10 22:28:12 +08:00
|
|
|
|
2016-01-22 23:14:11 +08:00
|
|
|
$(NEW_EXTENSION_ARTIFACT): $(SOURCES_DATA)
|
2015-11-10 22:28:12 +08:00
|
|
|
rm -f $@
|
2015-11-19 01:38:06 +08:00
|
|
|
cat $(SOURCES_DATA_DIR)/*.sql >> $@
|
2015-11-10 22:28:12 +08:00
|
|
|
|
2016-11-07 20:59:57 +08:00
|
|
|
.PHONY: all
|
2015-11-19 01:38:06 +08:00
|
|
|
all: $(DATA)
|
2015-11-10 22:28:12 +08:00
|
|
|
|
2016-11-07 20:59:57 +08:00
|
|
|
.PHONY: release
|
|
|
|
release: $(EXTENSION).control $(SOURCES_DATA)
|
|
|
|
test -n "$(NEW_VERSION)" # $$NEW_VERSION VARIABLE MISSING. Eg. make release NEW_VERSION=0.x.0
|
2016-12-14 19:08:26 +08:00
|
|
|
git mv *.sql old_versions
|
2016-11-07 20:59:57 +08:00
|
|
|
$(SED) $(REPLACEMENTS) $(EXTENSION).control
|
2016-12-14 19:08:26 +08:00
|
|
|
git add $(EXTENSION).control
|
2016-11-07 20:59:57 +08:00
|
|
|
cat $(SOURCES_DATA_DIR)/*.sql > $(EXTENSION)--$(NEW_VERSION).sql
|
2016-12-14 19:08:26 +08:00
|
|
|
git add $(EXTENSION)--$(NEW_VERSION).sql
|
2016-11-07 20:59:57 +08:00
|
|
|
$(ERB) version=$(NEW_VERSION) upgrade_downgrade_template.erb > $(EXTENSION)--$(EXTVERSION)--$(NEW_VERSION).sql
|
|
|
|
$(ERB) version=$(EXTVERSION) upgrade_downgrade_template.erb > $(EXTENSION)--$(NEW_VERSION)--$(EXTVERSION).sql
|
|
|
|
|
2015-11-10 22:28:12 +08:00
|
|
|
# Only meant for development time, do not use once a version is released
|
2016-11-07 20:59:57 +08:00
|
|
|
.PHONY: devclean
|
2015-11-10 22:28:12 +08:00
|
|
|
devclean:
|
2016-01-22 23:14:11 +08:00
|
|
|
rm -f $(NEW_EXTENSION_ARTIFACT)
|
2015-11-19 01:38:06 +08:00
|
|
|
rm -f $(GENERATED_SQL_FILES)
|