added showing commit hash on version page of info screen
authorHolger Schemel <info@artsoft.org>
Sat, 19 Sep 2020 01:05:28 +0000 (03:05 +0200)
committerHolger Schemel <info@artsoft.org>
Sat, 19 Sep 2020 01:06:43 +0000 (03:06 +0200)
.gitignore
Makefile
src/Makefile
src/config.c
src/config.h
src/screens.c

index e884cfc1140dcee76744a987e1d6db4367f2ef71..f0268317cbb5242ffe778155c9c3603f299f9569 100644 (file)
@@ -5,6 +5,7 @@
 
 # ignore automatically generated files
 src/conftime.h
+src/confhash.h
 src/conf_gfx.h
 src/conf_snd.h
 src/conf_mus.h
index 15e686a6b2cb67e43f5596c69dfa3d236ebec2a2..3e5877f063d467b511c5bcff015b9361542789a4 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -102,6 +102,9 @@ auto-conf:
 conf-time:
        @$(MAKE_CMD) conf-time
 
+conf-hash:
+       @$(MAKE_CMD) conf-hash
+
 run: all
        @$(MAKE_CMD) run
 
index 8f18fa7679f134fe705f121107479f52f2d745f6..0c8a9acd67dd748c3aace06677213a189a977fce 100644 (file)
@@ -192,6 +192,12 @@ SOURCE_DATE_EPOCH ?= $(shell test -d ../.git && test `git ls-files -m | wc -l` -
 # get source date string from either GNU / Linux or BSD / Mac OS X style "date"
 SOURCE_DATE_STRING := $(shell date -u -d "@$(SOURCE_DATE_EPOCH)" "+$(TIMESTAMP_FORMAT)"  2>/dev/null || date -u -r "$(SOURCE_DATE_EPOCH)" "+$(TIMESTAMP_FORMAT)" 2>/dev/null || date -u "+$(TIMESTAMP_FORMAT)")
 
+COMMIT_HASH_FILE = confhash.h
+COMMIT_HASH_NONE = "[changed files]"
+
+# get last Git commit hash, if no files were changed
+SOURCE_HASH_STRING ?= $(shell test -d ../.git && test `git ls-files -m | wc -l` -eq 0 && git show -s --format=%h || echo "$(COMMIT_HASH_NONE)")
+
 LIBGAME_DIR = libgame
 LIBGAME = $(LIBGAME_DIR)/libgame.a
 
@@ -224,7 +230,7 @@ GRAPHICS_DIR = ../graphics
 
 all: $(AUTOCONF) libgame_dir game_em_dir game_sp_dir game_mm_dir $(PROGNAME) graphics_dir
 
-$(PROGNAME): $(RNDLIBS) $(TIMESTAMP_FILE) $(OBJS) $(ICON)
+$(PROGNAME): $(RNDLIBS) $(TIMESTAMP_FILE) $(COMMIT_HASH_FILE) $(OBJS) $(ICON)
        $(CC) $(PROFILING) $(OBJS) $(ICON) $(RNDLIBS) $(LDFLAGS) -o $(PROGNAME)
 ifdef BUILD_DIST
        strip $(PROGNAME)
@@ -275,9 +281,16 @@ conf-time:
        @echo '#define SOURCE_DATE_STRING "$(SOURCE_DATE_STRING)"' \
        > $(TIMESTAMP_FILE)
 
+conf-hash:
+       @echo '#define SOURCE_HASH_STRING "$(SOURCE_HASH_STRING)"' \
+       > $(COMMIT_HASH_FILE)
+
 $(TIMESTAMP_FILE): $(SRCS) $(RNDLIBS)
        @$(MAKE) conf-time
 
+$(COMMIT_HASH_FILE): $(SRCS) $(RNDLIBS)
+       @$(MAKE) conf-hash
+
 $(ICON):
 #      $(CONVERT) $(ICON32X32) $(CONVERT_ICON_ARGS) $(ICONBASE).ico
        $(CONVERT) $(ICON_PATH)/*.png $(CONVERT_ICON_ARGS) $(ICONBASE).ico
index 8f3bd0845638167b3b8d08419c515308c765a667..d50ba68470e9a0cbd30b1584c3b125335f3c77d0 100644 (file)
@@ -13,6 +13,7 @@
 
 #include "config.h"
 #include "conftime.h"
+#include "confhash.h"
 
 
 char *getSourceDateString(void)
@@ -20,6 +21,11 @@ char *getSourceDateString(void)
   return SOURCE_DATE_STRING;
 }
 
+char *getSourceHashString(void)
+{
+  return SOURCE_HASH_STRING;
+}
+
 char *getProgramTitleString(void)
 {
   return program.program_title;
index 4b1a0e713eb5f4452450a09774b70463bf682221..06ae39e6d90e68ba8dd111c43f50bba28b441721 100644 (file)
@@ -15,6 +15,7 @@
 #include "main.h"
 
 char *getSourceDateString(void);
+char *getSourceHashString(void);
 char *getProgramTitleString(void);
 char *getProgramRealVersionString(void);
 char *getProgramVersionString(void);
index 41292512d1b1436b7871eb32e14bf32deb674735..6838dc9540ab8b3ec1e695091e7690c12a32eee8 100644 (file)
@@ -3692,6 +3692,10 @@ static void DrawInfoScreen_Version(void)
 
   DrawTextF(xstart1, ystart, font_head, "Source date");
   DrawTextF(xstart2, ystart, font_text, getSourceDateString());
+  ystart += ystep_line;
+
+  DrawTextF(xstart1, ystart, font_head, "Commit hash");
+  DrawTextF(xstart2, ystart, font_text, getSourceHashString());
   ystart += ystep_para;
 
   DrawTextF(xstart1, ystart, font_head, "Library");