From 623faf1a22ebaffb05f6acfca649949c1a7a93df Mon Sep 17 00:00:00 2001 From: Mario de Frutos Date: Mon, 7 Nov 2016 13:59:57 +0100 Subject: [PATCH] Added make release option for client --- client/Makefile | 50 ++++++++++++++++++--------- client/upgrade_downgrade_template.erb | 5 +++ 2 files changed, 39 insertions(+), 16 deletions(-) create mode 100644 client/upgrade_downgrade_template.erb diff --git a/client/Makefile b/client/Makefile index 78a6996..fe6939d 100644 --- a/client/Makefile +++ b/client/Makefile @@ -4,29 +4,31 @@ EXTENSION = cdb_dataservices_client EXTVERSION = $(shell grep default_version $(EXTENSION).control | sed -e "s/default_version[[:space:]]*=[[:space:]]*'\([^']*\)'/\1/") # The new version to be generated from templates +SED = sed +ERB = erb +REPLACEMENTS = -i 's/$(EXTVERSION)/$(NEW_VERSION)/g' NEW_EXTENSION_ARTIFACT = $(EXTENSION)--$(EXTVERSION).sql + +# 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/ + + +REGRESS = $(notdir $(basename $(wildcard test/sql/*test.sql))) +TEST_DIR = test/ +REGRESS_OPTS = --inputdir='$(TEST_DIR)' --outputdir='$(TEST_DIR)' --user='postgres' # 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 -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 - - -REGRESS = $(notdir $(basename $(wildcard test/sql/*test.sql))) -TEST_DIR = test/ -REGRESS_OPTS = --inputdir='$(TEST_DIR)' --outputdir='$(TEST_DIR)' - -# postgres build stuff -PG_CONFIG = pg_config -PGXS := $(shell $(PG_CONFIG) --pgxs) -include $(PGXS) - -SOURCES_DATA_DIR = sql/ # The interface definition is used along with some templates to automatically generate code RENDERER = renderer/sql-template-renderer @@ -35,6 +37,11 @@ TEMPLATE_DIR = renderer/templates TEMPLATE_FILES = $(wildcard $(TEMPLATE_DIR)/*.erb) GENERATED_SQL_FILES = $(patsubst $(TEMPLATE_DIR)/%.erb, $(SOURCES_DATA_DIR)/%.sql, $(TEMPLATE_FILES)) +# postgres build stuff +PG_CONFIG = pg_config +PGXS := $(shell $(PG_CONFIG) --pgxs) +include $(PGXS) + $(GENERATED_SQL_FILES): $(SOURCES_DATA_DIR)/%.sql: $(TEMPLATE_DIR)/%.erb $(INTERFACE_FILE) $(RENDERER) $(RENDERER) $(INTERFACE_FILE) $< > $@ @@ -44,9 +51,20 @@ $(NEW_EXTENSION_ARTIFACT): $(SOURCES_DATA) rm -f $@ cat $(SOURCES_DATA_DIR)/*.sql >> $@ +.PHONY: all all: $(DATA) +.PHONY: release +release: $(EXTENSION).control $(SOURCES_DATA) + test -n "$(NEW_VERSION)" # $$NEW_VERSION VARIABLE MISSING. Eg. make release NEW_VERSION=0.x.0 + mv *.sql old_versions + $(SED) $(REPLACEMENTS) $(EXTENSION).control + cat $(SOURCES_DATA_DIR)/*.sql > $(EXTENSION)--$(NEW_VERSION).sql + $(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 + # Only meant for development time, do not use once a version is released +.PHONY: devclean devclean: rm -f $(NEW_EXTENSION_ARTIFACT) rm -f $(GENERATED_SQL_FILES) diff --git a/client/upgrade_downgrade_template.erb b/client/upgrade_downgrade_template.erb new file mode 100644 index 0000000..bc8eb7c --- /dev/null +++ b/client/upgrade_downgrade_template.erb @@ -0,0 +1,5 @@ +--DO NOT MODIFY THIS FILE, IT IS GENERATED AUTOMATICALLY FROM SOURCES +-- Complain if script is sourced in psql, rather than via CREATE EXTENSION +\echo Use "ALTER EXTENSION cdb_dataservices_client UPDATE TO '<%= version %>'" to load this file. \quit + +-- HERE goes your code to upgrade/downgrade