Skip to content

Commit

Permalink
Merge branch 'comptime-no-fail' into 'master'
Browse files Browse the repository at this point in the history
Minor comptime refactoring.

See merge request STJr/SRB2!1776

(cherry picked from commit dc02339)

9bfc82a Prevent comptime.* from failing compilation
a614865 Make comptime.sh conform to POSIX and less redundant, among other improvements
b7711b2 Pass argument list directly to functions that use them; quote arguments when used.
  • Loading branch information
HybridEidolon committed Nov 16, 2022
1 parent 84bc03d commit e6780f2
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 34 deletions.
54 changes: 22 additions & 32 deletions comptime.sh
Original file line number Diff line number Diff line change
@@ -1,54 +1,44 @@
#!/bin/bash -e
#!/bin/sh
path="."
if [ x"$1" != x ]; then
path="$1"
fi

versiongit() {
gitbranch=`git rev-parse --abbrev-ref HEAD`
gitversion=`git rev-parse HEAD`
cat <<EOF > $path/comptime.h
version() {
cat <<EOF > "$path/comptime.h"
// Do not edit! This file was autogenerated
// by the $0 script with git
//
const char* compbranch = "$gitbranch";
const char* comprevision = "${gitversion:0:8}";
const char* compbranch = "$1";
const char* comprevision = "$2";
EOF
exit 0
}

versionsvn() {
svnrevision=`svnversion -n $1`
cat <<EOF > $path/comptime.h
versiongit() {
gitbranch="$(git rev-parse --abbrev-ref HEAD)"
gitversion="$(git rev-parse HEAD | cut -c -8)"
version "$gitbranch" "$gitversion";
exit 0
}

// Do not edit! This file was autogenerated
// by the $0 script with subversion
//
const char* compbranch = "Subversion";
const char* comprevision = "r$svnrevision";
EOF
exit 0
versionsvn() {
svnrevision="$(svnversion -n "$1")"
version "Subversion" "r$svnrevision";
exit 0
}

versionfake() {
cat <<EOF > $path/comptime.h
// Do not edit! This file was autogenerated
// by the $0 script with an unknown or nonexist SCM
//
const char* compbranch = "Unknown";
const char* comprevision = "illegal";
EOF
version "Unknown" "illegal";
}

compversion() {
touch $path/comptime.c
versionfake
test -d $path/.svn && versionsvn
test -d $path/../.git && versiongit
exit 1
touch "$path/comptime.c"
versionfake
[ -d "$path/.svn" ] && versionsvn "$@"
[ -d "$path/../.git" ] && versiongit
exit 1
}

test -f $path/comptime.c && compversion
[ -f "$path/comptime.c" ] && compversion "$@"
exit 2
4 changes: 2 additions & 2 deletions src/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -357,9 +357,9 @@ $(dbg).txt : $(dbg)
# this really updates comptime.h
comptime.c ::
ifdef WINDOWSHELL
$(.)..\comptime.bat .
-$(.)..\comptime.bat .
else
$(.)../comptime.sh .
-$(.)../comptime.sh .
endif

# I wish I could make dependencies out of rc files :(
Expand Down

0 comments on commit e6780f2

Please sign in to comment.