summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile.pre.in15
-rw-r--r--Modules/getbuildinfo.c34
2 files changed, 34 insertions, 15 deletions
diff --git a/Makefile.pre.in b/Makefile.pre.in
index 0ce2afa685..020c86ed39 100644
--- a/Makefile.pre.in
+++ b/Makefile.pre.in
@@ -349,12 +349,9 @@ buildno: $(PARSER_OBJS) \
$(SIGNAL_OBJS) \
$(MODOBJS) \
$(srcdir)/Modules/getbuildinfo.c
- if test -d .svn; then \
- svnversion . >buildno; \
- elif test -f buildno; then \
- expr `cat buildno` + 1 >buildno1; \
- mv -f buildno1 buildno; \
- else echo 1 >buildno; fi
+ if test -d $(srcdir)/.svn; then \
+ svnversion $(srcdir) >buildno; \
+ fi
# Build static library
# avoid long command lines, same as LIBRARY_OBJS
@@ -446,7 +443,11 @@ Modules/Setup: $(srcdir)/Modules/Setup.dist
# Special rules for object files
Modules/getbuildinfo.o: $(srcdir)/Modules/getbuildinfo.c buildno
- $(CC) -c $(PY_CFLAGS) -DBUILD=\"`cat buildno`\" -o $@ $(srcdir)/Modules/getbuildinfo.c
+ if test -f buildno; then \
+ $(CC) -c $(PY_CFLAGS) -DBUILD=\"`cat buildno`\" -o $@ $(srcdir)/Modules/getbuildinfo.c ;\
+ else \
+ $(CC) -c $(PY_CFLAGS) -o $@ $(srcdir)/Modules/getbuildinfo.c ;\
+ fi
Modules/getpath.o: $(srcdir)/Modules/getpath.c Makefile
$(CC) -c $(PY_CFLAGS) -DPYTHONPATH='"$(PYTHONPATH)"' \
diff --git a/Modules/getbuildinfo.c b/Modules/getbuildinfo.c
index 8b1ca22f3a..446340badb 100644
--- a/Modules/getbuildinfo.c
+++ b/Modules/getbuildinfo.c
@@ -21,20 +21,38 @@
#endif
#ifndef BUILD
-#define BUILD "0"
+#define BUILD "$Revision$"
#endif
const char *
-Py_GetBuildInfo(void)
+Py_GetBuildNumber(void)
{
- static char buildinfo[50];
- PyOS_snprintf(buildinfo, sizeof(buildinfo),
- "%s, %.20s, %.9s", BUILD, DATE, TIME);
- return buildinfo;
+ static char buildno[20];
+ static int buildno_okay;
+
+ if (!buildno_okay) {
+ char *build = BUILD;
+ int len = strlen(build);
+
+ if (len > 13 &&
+ !strncmp(build, "$Revision: ", 11) &&
+ !strcmp(build + len - 2, " $"))
+ {
+ memcpy(buildno, build + 11, len - 13);
+ }
+ else {
+ memcpy(buildno, build, 19);
+ }
+ buildno_okay = 1;
+ }
+ return buildno;
}
const char *
-Py_GetBuildNumber(void)
+Py_GetBuildInfo(void)
{
- return BUILD;
+ static char buildinfo[50];
+ PyOS_snprintf(buildinfo, sizeof(buildinfo),
+ "#%s, %.20s, %.9s", Py_GetBuildNumber(), DATE, TIME);
+ return buildinfo;
}