aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-04-16 23:56:31 +0000
committerNick Mathewson <nickm@torproject.org>2007-04-16 23:56:31 +0000
commitbfac679cd4209ea441211bcb5c5e210c6264e8c7 (patch)
tree541e482d67428e9c0015a4cd358ca9961f4413a8 /src
parent362fbc79d276864c4b2b68ed9cf3bb8ba534985e (diff)
downloadtor-bfac679cd4209ea441211bcb5c5e210c6264e8c7.tar.gz
tor-bfac679cd4209ea441211bcb5c5e210c6264e8c7.zip
A hack I've been wanting for a while: when building a -dev version
from an SVN repository, use the current svn revision in the platform string and in the output of --version. svn:r9976
Diffstat (limited to 'src')
-rw-r--r--src/or/Makefile.am14
-rw-r--r--src/or/config.c10
-rw-r--r--src/or/router.c15
-rw-r--r--src/or/test.c2
-rw-r--r--src/or/tor_main.c4
5 files changed, 42 insertions, 3 deletions
diff --git a/src/or/Makefile.am b/src/or/Makefile.am
index 9991a67a2e..8e2011017e 100644
--- a/src/or/Makefile.am
+++ b/src/or/Makefile.am
@@ -28,3 +28,17 @@ test_LDADD = ../common/libor.a ../common/libor-crypto.a
noinst_HEADERS = or.h eventdns.h eventdns_tor.h
+tor_main.o: micro-revision.i
+
+micro-revision.i: FORCE
+ rm -f micro-revision.i; \
+ if test -d ../../.svn ; then \
+ svn info ../.. | \
+ sed -n 's/^Revision: \([0-9][0-9]*\).*/"\1"/p' > micro-revision.i \
+ || true; \
+ fi; \
+ if test ! -f micro-revision.i; then \
+ echo '""' > micro-revision.i; \
+ fi
+
+FORCE:
diff --git a/src/or/config.c b/src/or/config.c
index c7b7fdf24b..568cd934be 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -2982,6 +2982,8 @@ check_nickname_list(const char *lst, const char *name, char **msg)
return r;
}
+extern const char tor_svn_revision[]; /* from main.c */
+
/** Read a configuration file into <b>options</b>, finding the configuration
* file location based on the command line. After loading the options,
* validate them for consistency, then take actions based on them.
@@ -3018,7 +3020,13 @@ options_init_from_torrc(int argc, char **argv)
}
if (argc > 1 && (!strcmp(argv[1],"--version"))) {
- printf("Tor version %s.\n",VERSION);
+ char vbuf[128];
+ if (tor_svn_revision && strlen(tor_svn_revision)) {
+ tor_snprintf(vbuf, sizeof(vbuf), " (r%s)", tor_svn_revision);
+ } else {
+ vbuf[0] = 0;
+ }
+ printf("Tor version %s%s.\n",VERSION,vbuf);
if (argc > 2 && (!strcmp(argv[2],"--version"))) {
print_svn_version();
}
diff --git a/src/or/router.c b/src/or/router.c
index 3c3255a49d..ad7ad96a24 100644
--- a/src/or/router.c
+++ b/src/or/router.c
@@ -1172,6 +1172,8 @@ router_guess_address_from_dir_headers(uint32_t *guess)
return -1;
}
+extern const char tor_svn_revision[]; /* from main.c */
+
/** Set <b>platform</b> (max length <b>len</b>) to a NUL-terminated short
* string describing the version of Tor and the operating system we're
* currently running on.
@@ -1179,8 +1181,17 @@ router_guess_address_from_dir_headers(uint32_t *guess)
void
get_platform_str(char *platform, size_t len)
{
- tor_snprintf(platform, len, "Tor %s on %s",
- VERSION, get_uname());
+ char svn_version_buf[128];
+ if (!strcmpend(VERSION, "-dev") &&
+ tor_svn_revision && strlen(tor_svn_revision)) {
+ tor_snprintf(svn_version_buf, sizeof(svn_version_buf), " (r%s)",
+ tor_svn_revision);
+ } else {
+ svn_version_buf[0] = 0;
+ }
+
+ tor_snprintf(platform, len, "Tor %s%s on %s",
+ VERSION, svn_version_buf, get_uname());
return;
}
diff --git a/src/or/test.c b/src/or/test.c
index 73de80fe57..98a10f8d9c 100644
--- a/src/or/test.c
+++ b/src/or/test.c
@@ -5,6 +5,8 @@
const char test_c_id[] =
"$Id$";
+const char tor_svn_revision[] = "";
+
/**
* \file test.c
* \brief Unit tests for many pieces of the lower level Tor modules.
diff --git a/src/or/tor_main.c b/src/or/tor_main.c
index f6309057c9..c4fb3139ad 100644
--- a/src/or/tor_main.c
+++ b/src/or/tor_main.c
@@ -5,6 +5,10 @@
const char tor_main_c_id[] =
"$Id$";
+const char tor_svn_revision[] =
+#include "micro-revision.i"
+ "";
+
/**
* \file tor_main.c
* \brief Stub module containing a main() function. Allows unit