moved cog to compile time, now aware of its own version
This commit is contained in:
parent
b34430b9e2
commit
207599eab1
15
bootstrap
15
bootstrap
@ -4,19 +4,4 @@ if [ ! -d "m4" ]; then
|
||||
mkdir m4
|
||||
fi
|
||||
|
||||
export COG=$(command -v cog)
|
||||
[ -z "$COG"] && export COG=$(command -v cog.py)
|
||||
|
||||
if [ -z "$COG" ]; then
|
||||
echo "Please install the Cog code generator, probably with pip install cogapp"
|
||||
return 1
|
||||
fi
|
||||
|
||||
echo "cog found at $COG"
|
||||
for cogfile in $(find src -name "*.cog"); do
|
||||
decogged=${cogfile%.cog}
|
||||
echo "greasing cog for ${decogged}..."
|
||||
$COG -d -o ${decogged} ${cogfile}
|
||||
done
|
||||
|
||||
autoreconf --install
|
||||
|
10
configure.ac
10
configure.ac
@ -6,6 +6,16 @@ AC_CONFIG_MACRO_DIR([m4])
|
||||
AC_PROG_CXX
|
||||
AX_CXX_COMPILE_STDCXX_11
|
||||
|
||||
AC_PATH_PROG([COG], [cog], [not found])
|
||||
if test "$COG" == "not found" ; then
|
||||
AC_PATH_PROG([COGPY], [cog.py], [not found])
|
||||
if test "$COGPY" == "not found" ; then
|
||||
AC_MSG_ERROR(["Please install the Cog code generator, probably via "pip install cogapp"])
|
||||
fi
|
||||
COG="$COGPY"
|
||||
AC_SUBST(COG)
|
||||
fi
|
||||
|
||||
AX_BOOST_BASE([1.63], , [AC_MSG_ERROR([boost 1.63 required])])
|
||||
AX_BOOST_SYSTEM
|
||||
AX_BOOST_FILESYSTEM
|
||||
|
@ -1,4 +1,12 @@
|
||||
bin_PROGRAMS = cellar
|
||||
cellar_CPPFLAGS = $(BOOST_CPPFLAGS)
|
||||
cellar_LDFLAGS = $(BOOST_LDFLAGS) $(BOOST_SYSTEM_LIB) $(BOOST_FILESYSTEM_LIB)
|
||||
cellar_SOURCES = cellar.cpp fs.cpp bottles.cpp commands.cpp version.cpp
|
||||
cellar_SOURCES = cellar.cpp fs.cpp bottles.cpp commands.cpp
|
||||
|
||||
# Generated files
|
||||
nodist_cellar_SOURCES = version.cpp
|
||||
|
||||
CLEANFILES = version.cpp
|
||||
|
||||
version.cpp:
|
||||
$(COG) -d -o version.cpp version.cpp.cog
|
||||
|
@ -1,15 +1,44 @@
|
||||
// vim: filetype=cpp :
|
||||
#include <iostream>
|
||||
|
||||
#include "commands.hpp"
|
||||
#include "version.hpp"
|
||||
|
||||
using namespace std;
|
||||
using namespace cellar::version;
|
||||
|
||||
string cellar::version::short_version() {
|
||||
/*[[[cog
|
||||
import cog
|
||||
import os
|
||||
import configparser
|
||||
import datetime
|
||||
|
||||
print(os.getcwd())
|
||||
today = datetime.datetime.today()
|
||||
|
||||
cog.outl("return \"dummy cog file!\";")
|
||||
cparse = configparser.ConfigParser()
|
||||
cparse.read("../cogrc")
|
||||
config = cparse["version"]
|
||||
|
||||
if config.getboolean("release"):
|
||||
outstring = "version {0}, built {1}".format(config["release_version"], str(today))
|
||||
else:
|
||||
try:
|
||||
import subprocess
|
||||
cmdoutput = subprocess.check_output(["git", "symbolic-ref", "HEAD"]).decode().strip()
|
||||
gitbranch = cmdoutput.split("/")[2]
|
||||
|
||||
githash = subprocess.check_output(["git", "rev-parse", "HEAD"]).decode().strip()
|
||||
outstring = "{0} {1}, built {2}".format(gitbranch, githash, str(today))
|
||||
except:
|
||||
outstring = "exception raised when trying to read git data at precompile time"
|
||||
raise
|
||||
|
||||
cog.outl("return \"{0}\";".format(outstring))
|
||||
]]]*/
|
||||
//[[[end]]]
|
||||
}
|
||||
|
||||
void print_version(int argc, char** argv) {
|
||||
cout << short_version() << endl;
|
||||
}
|
||||
bool _ = cellar::commands::add_command("version", &print_version);
|
||||
|
Loading…
Reference in New Issue
Block a user